亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? disassembler.c

?? 這是一個開放源代碼的與WINNT/WIN2K/WIN2003兼容的操作系統(tǒng)
?? C
?? 第 1 頁 / 共 2 頁
字號:

             case _Ev :                                         // modR/M used - bW = 1
                bW = 1;
                goto _E;

             case _Ew :                                         // always USHORT size
                pDis->dwFlags &= ~DIS_DATA32;
                bW = 1;
                goto _E;

             case _Ms :                                         // fword ptr (sgdt,sidt,lgdt,lidt)
                sPtr = sFwordPtr;
                goto _E1;

             case _Mq :                                         // qword ptr (cmpxchg8b)
                sPtr = sQwordPtr;
                goto _E1;

             case _Mp :                                         // 32 or 48 bit pointer (les,lds,lfs,lss,lgs)
             case _Ep :                                         // Always a memory pointer (call, jmp)
                if( pDis->dwFlags & DIS_DATA32 )
                    sPtr = sFwordPtr;
                else
                    sPtr = sDwordPtr;
                goto _E1;

             _E:
                 // Do registers first so that the rest may be done together
                 if( bMod == 3 )
                 {
                      // Registers depending on the w field and data size
                      nPos+=PICE_sprintf(pDis->szDisasm+nPos, "%s", sRegs1[DIS_GETDATASIZE(pDis->dwFlags)][bW][bRm] );

                      break;
                 }

                 if( bW==0 )
                     sPtr = sBytePtr;
                 else
                     if( pDis->dwFlags & DIS_DATA32 )
                         sPtr = sDwordPtr;
                     else
                         sPtr = sWordPtr;

             case _M  :                                         // Pure memory pointer (lea,invlpg,floats)
                if( bMod == 3 ) goto IllegalOpcode;

             _E1:

                 if( sPtr )
                     nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sPtr );

             case _Ma :                                         // Used by bound instruction, skip the pointer info

                 // Print the segment if it is overriden
                 //
                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"%s", sSegOverride[ bSegOverride ] );

                 //
                 // Special case when sib UCHAR is present in 32 address encoding
                 //
                 if( (bRm==4) && (pDis->dwFlags & DIS_ADDRESS32) )
                 {
                      //
                      // Get the s-i-b UCHAR and parse it
                      //
                      bSib = NEXTUCHAR;

                      bSs = bSib >> 6;
                      bIndex = (bSib >> 3) & 7;
                      bBase = bSib & 7;

                      // Special case for base=5 && mod==0 -> fetch 32 bit offset
                      if( (bBase==5) && (bMod==0) )
                      {
                          dwULONG = NEXTULONG;
                          if(ScanExportsByAddress(&pSymbolName,dwULONG))
                          {
                              nPos += PICE_sprintf( pDis->szDisasm+nPos,"[%s", pSymbolName );
                          }
                          else
                          {
                              nPos += PICE_sprintf( pDis->szDisasm+nPos,"[%08X", (unsigned int) dwULONG );
                          }
                      }
                      else
                          nPos += PICE_sprintf( pDis->szDisasm+nPos,"[%s", sGenReg16_32[ 1 ][ bBase ] );

                      // Scaled index, no index if bIndex is 4
                      if( bIndex != 4 )
                          nPos += PICE_sprintf( pDis->szDisasm+nPos,"+%s%s", sScale[ bSs ], sGenReg16_32[ 1 ][ bIndex ] );
                      else
                          if(bSs != 0)
                              nPos += PICE_sprintf( pDis->szDisasm+nPos,"<INVALID MODE>" );

                      // Offset 8 bit or 32 bit
                      if( bMod == 1 )
                      {
                          bUCHAR = NEXTUCHAR;
                          if( (signed char)bUCHAR < 0 )
                                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"-%02X", 0-(signed char)bUCHAR );
                          else
                                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"+%02X", bUCHAR );
                      }

                      if( bMod == 2 )
                      {
                          dwULONG = NEXTULONG;
                          nPos += PICE_sprintf( pDis->szDisasm+nPos,"+%08X", (unsigned int) dwULONG );
                      }

                      // Wrap up the instruction
                      nPos += PICE_sprintf( pDis->szDisasm+nPos,"]" );
                      break;
                 }

                 //
                 // 16 or 32 address bit cases with mod zero, one or two
                 //
                 // Special cases when r/m is 5 and mod is 0, immediate d16 or d32
                 if( bMod==0 && ((bRm==6 && !(pDis->dwFlags & DIS_ADDRESS32)) || (bRm==5 && (pDis->dwFlags & DIS_ADDRESS32))) )
                 {
                      if( pDis->dwFlags & DIS_ADDRESS32 )
                      {
                          dwULONG = NEXTULONG;
                          if(ScanExportsByAddress(&pSymbolName,dwULONG))
                              nPos += PICE_sprintf( pDis->szDisasm+nPos,"[%s]", pSymbolName );
                          else
                              nPos += PICE_sprintf( pDis->szDisasm+nPos,"[%08X]", (unsigned int) dwULONG );
                      }
                      else
                      {
                          wUSHORT = NEXTUSHORT;
                          nPos += PICE_sprintf( pDis->szDisasm+nPos,"[%04X]", wUSHORT );
                      }

                      break;
                 }

                 // Print the start of the line
                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"[%s", sAdr1[DIS_GETADDRSIZE(pDis->dwFlags)][ bRm ] );

                 // Offset (8 or 16) or (8 or 32) bit - 16, 32 bits are unsigned
                 if( bMod==1 )
                 {
                      bUCHAR = NEXTUCHAR;
                      if( (signed char)bUCHAR < 0 )
                             nPos += PICE_sprintf( pDis->szDisasm+nPos,"-%02X", 0-(signed char)bUCHAR );
                      else
                             nPos += PICE_sprintf( pDis->szDisasm+nPos,"+%02X", bUCHAR );
                 }

                 if( bMod==2 )
                 {
                      if( pDis->dwFlags & DIS_ADDRESS32 )
                      {
                          dwULONG = NEXTULONG;
                          nPos += PICE_sprintf( pDis->szDisasm+nPos,"+%08X", (unsigned int) dwULONG );
                      }
                      else
                      {
                          wUSHORT = NEXTUSHORT;
                          nPos += PICE_sprintf( pDis->szDisasm+nPos,"+%04X", wUSHORT );
                      }
                 }

                 // Wrap up the instruction
                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"]" );

             break;

             case _Gb :                                         // general, UCHAR register
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sRegs1[0][0][ bReg ] );
             break;

             case _Gv :                                         // general, (d)USHORT register
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sGenReg16_32[DIS_GETDATASIZE(pDis->dwFlags)][ bReg ] );
             break;

             case _Yb :                                         // ES:(E)DI pointer
             case _Yv :
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s%s", sSegOverrideDefaultES[ bSegOverride ], sYptr[DIS_GETADDRSIZE(pDis->dwFlags)] );
             break;

             case _Xb :                                         // DS:(E)SI pointer
             case _Xv :
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s%s", sSegOverrideDefaultDS[ bSegOverride ], sXptr[DIS_GETADDRSIZE(pDis->dwFlags)] );
             break;

             case _Rd :                                         // general register double USHORT
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sGenReg16_32[ 1 ][ bRm ] );
             break;

             case _Rw :                                         // register USHORT
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sGenReg16_32[ 0 ][ bMod ] );
             break;

             case _Sw :                                         // segment register
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sSeg[ bReg ] );
             break;

             case _Cd :                                         // control register
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sControl[ bReg ] );
             break;

             case _Dd :                                         // debug register
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sDebug[ bReg ] );
             break;

             case _Td :                                         // test register
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sTest[ bReg ] );
             break;


             case _Jb :                                         // immediate UCHAR, relative offset
                 bUCHAR = NEXTUCHAR;
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "short %08X", (unsigned int)(pDis->bpTarget + (signed char)bUCHAR + bInstrLen) );
             break;

             case _Jv :                                         // immediate USHORT or ULONG, relative offset
                 if( pDis->dwFlags & DIS_DATA32 )
                 {
                      dwULONG = NEXTULONG;
                      if(ScanExportsByAddress(&pSymbolName,(unsigned int)(pDis->bpTarget + (signed long)dwULONG + bInstrLen)))
                        nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", pSymbolName );
                      else
                        nPos += PICE_sprintf( pDis->szDisasm+nPos, "%08X", (unsigned int)(pDis->bpTarget + (signed long)dwULONG + bInstrLen) );
                 }
                 else
                 {
                     wUSHORT = NEXTUSHORT;
                     if(ScanExportsByAddress(&pSymbolName,(unsigned int)(pDis->bpTarget + (signed short)wUSHORT + bInstrLen)))
                        nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", pSymbolName );
                     else
                        nPos += PICE_sprintf( pDis->szDisasm+nPos, "%08X", (unsigned int)(pDis->bpTarget + (signed short)wUSHORT + bInstrLen) );
                 }
             break;

             case _O  :                                         // Simple USHORT or ULONG offset
                  if( pDis->dwFlags & DIS_ADDRESS32 )           // depending on the address size
                  {
                      dwULONG = NEXTULONG;
                      nPos += PICE_sprintf( pDis->szDisasm+nPos,"%s[%08X]", sSegOverride[ bSegOverride ], (unsigned int) dwULONG );
                  }
                  else
                  {
                      wUSHORT = NEXTUSHORT;
                      nPos += PICE_sprintf( pDis->szDisasm+nPos,"%s[%04X]", sSegOverride[ bSegOverride ], wUSHORT );
                  }
             break;

             case _Ib :                                         // immediate UCHAR
                 bUCHAR = NEXTUCHAR;
                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"%02X", bUCHAR );
             break;

             case _Iv :                                         // immediate USHORT or ULONG
                 if( pDis->dwFlags & DIS_DATA32 )
                 {
                      dwULONG = NEXTULONG;
                      nPos += PICE_sprintf( pDis->szDisasm+nPos, "%08X", (unsigned int) dwULONG );
                 }
                 else
                 {
                     wUSHORT = NEXTUSHORT;
                     nPos += PICE_sprintf( pDis->szDisasm+nPos, "%04X", wUSHORT );
                 }
             break;

             case _Iw :                                         // Immediate USHORT
                 wUSHORT = NEXTUSHORT;
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%04X", wUSHORT );
             break;

             case _Ap :                                         // 32 bit or 48 bit pointer (call far, jump far)
                 if( pDis->dwFlags & DIS_DATA32 )
                 {
                      dwULONG = NEXTULONG;
                      wUSHORT = NEXTUSHORT;
                      nPos += PICE_sprintf( pDis->szDisasm+nPos, "%04X:%08X", wUSHORT, (unsigned int) dwULONG );
                 }
                 else
                 {
                     dwULONG = NEXTULONG;
                     nPos += PICE_sprintf( pDis->szDisasm+nPos, "%08X", (unsigned int) dwULONG );
                 }
             break;

             case _1 :                                          // numerical 1
                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"1" );
             break;

             case _3 :                                          // numerical 3
                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"3" );
             break;

                                                                // Hard coded registers
             case _DX: case _AL: case _AH: case _BL: case _BH: case _CL: case _CH:
             case _DL: case _DH: case _CS: case _DS: case _ES: case _SS: case _FS:
             case _GS:
                 nPos += PICE_sprintf( pDis->szDisasm+nPos,"%s", sRegs2[ *pArg - _DX ] );
             break;

             case _eAX: case _eBX: case _eCX: case _eDX:
             case _eSP: case _eBP: case _eSI: case _eDI:
                 nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s", sGenReg16_32[DIS_GETDATASIZE(pDis->dwFlags)][ *pArg - _eAX ]);
             break;

             case _ST:                                          // Coprocessor ST
                nPos += PICE_sprintf( pDis->szDisasm+nPos,"%s", sST[9] );
             break;

            case _ST0:                                         // Coprocessor ST(0) - ST(7)
            case _ST1:
            case _ST2:
            case _ST3:
            case _ST4:
            case _ST5:
            case _ST6:
            case _ST7:
               nPos += PICE_sprintf( pDis->szDisasm+nPos,"%s", sST[ *pArg - _ST0 ] );
            break;

            case _AX:                                           // Coprocessor AX
                nPos += PICE_sprintf( pDis->szDisasm+nPos,"%s", sGenReg16_32[0][0] );
            break;
        }
    }

DisEnd:

    // Set the returning values and return with the bInstrLen field

    pDis->bAsciiLen = (UCHAR) nPos;
    pDis->bInstrLen = bInstrLen;

    return bInstrLen;
}

/******************************************************************************
*                                                                             *
*   BOOLEAN Disasm(PULONG pOffset,PUCHAR pchDst)                              *
*                                                                             *
*   entry point for disassembly from other modules                            *
******************************************************************************/
BOOLEAN Disasm(PULONG pOffset,PUCHAR pchDst)
{
    TDisassembler dis;

    dis.dwFlags  = DIS_DATA32 | DIS_ADDRESS32;
    dis.bpTarget = (UCHAR*)*pOffset;
    dis.szDisasm = pchDst;
    dis.wSel = CurrentCS;

    *pOffset += (ULONG)Disassembler( &dis);
    return TRUE;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美电视剧在线观看完整版| 欧美日韩精品久久久| 国产色产综合色产在线视频| 精品一区二区免费看| 欧美精品一区二区三区在线| 国产原创一区二区三区| 亚洲国产精品99久久久久久久久 | 欧美三级电影一区| 亚洲图片欧美综合| 制服丝袜一区二区三区| 国产一区二区在线观看免费 | 国产精品嫩草影院com| 99精品在线免费| 亚洲国产精品久久久久婷婷884 | 精品一区二区在线播放| 国产天堂亚洲国产碰碰| 在线视频一区二区三| 免费成人美女在线观看.| 国产精品网站导航| 欧美日韩在线不卡| 国产又黄又大久久| 一区二区三区国产精华| 欧美一区二区日韩| 成人激情视频网站| 天堂av在线一区| 欧美激情综合五月色丁香小说| 91久久精品一区二区三区| 久久99精品久久久久久动态图| 中文成人av在线| 欧美日韩国产美女| 成人动漫一区二区在线| 日韩在线卡一卡二| 亚洲国产精品v| 欧美一级xxx| 色综合一个色综合| 国产成人午夜99999| 亚洲福利一二三区| 18成人在线观看| 久久综合999| 欧美疯狂做受xxxx富婆| 不卡视频免费播放| 国产在线观看一区二区| 亚洲一区在线观看网站| 国产精品狼人久久影院观看方式| 91精品国产一区二区人妖| 99re亚洲国产精品| 国产在线视频精品一区| 日韩高清不卡一区二区| 日韩久久一区二区| 亚洲国产精品黑人久久久| 欧美一区二区三区免费视频| 99re成人精品视频| 国产精品一区二区免费不卡| 午夜精品福利一区二区蜜股av| 国产精品乱人伦| 久久久久9999亚洲精品| 日韩欧美不卡在线观看视频| 欧美日韩久久久一区| 色狠狠色狠狠综合| 91亚洲国产成人精品一区二区三| 国产一区二区三区免费在线观看| 日韩精品高清不卡| 一区二区三区在线看| 亚洲国产高清不卡| 亚洲国产高清aⅴ视频| 久久久亚洲精华液精华液精华液| 日韩精品专区在线影院重磅| 欧美日韩国产经典色站一区二区三区| 在线看国产日韩| 色八戒一区二区三区| 91在线免费视频观看| 972aa.com艺术欧美| av在线播放成人| 99免费精品视频| 色偷偷久久人人79超碰人人澡| 91在线观看一区二区| 99在线精品免费| 一道本成人在线| 欧美日韩亚洲综合一区| 7777精品伊人久久久大香线蕉完整版| 欧美日韩一区二区在线视频| 欧美日韩在线不卡| 欧美一卡二卡在线观看| 欧美成人综合网站| 久久精品人人爽人人爽| 国产日韩精品一区| 亚洲精品水蜜桃| 亚洲大片精品永久免费| 蜜桃视频一区二区三区| 精品一区二区三区的国产在线播放| 韩国一区二区在线观看| 国产精品自产自拍| av在线播放不卡| 欧美在线免费观看亚洲| 91精品欧美综合在线观看最新| 日韩一区二区三区视频在线| 亚洲精品一区二区三区影院| 国产精品久久久久久久久久久免费看 | 美女看a上一区| 国产69精品一区二区亚洲孕妇| 成人高清免费观看| 在线观看一区二区视频| 51精品久久久久久久蜜臀| 精品国产网站在线观看| 国产精品久久久久久久久快鸭| 一区二区三区丝袜| 久久精品二区亚洲w码| 9色porny自拍视频一区二区| 欧美性色欧美a在线播放| 欧美精品一区二区三区久久久| 国产精品美日韩| 日韩不卡一区二区三区| 丁香激情综合国产| 欧美日韩亚洲综合在线 | 午夜久久久久久久久久一区二区| 久久成人精品无人区| 91丨porny丨户外露出| 日韩免费视频一区二区| 国产精品短视频| 免费观看一级特黄欧美大片| av在线播放不卡| 精品久久久网站| 亚洲一区二区视频| 成人丝袜高跟foot| 日韩欧美精品在线| 亚洲一区二区在线播放相泽| 国产精品自拍三区| 欧美一区二区三区电影| 一区免费观看视频| 激情综合网激情| 欧美欧美欧美欧美| 亚洲色图欧洲色图婷婷| 激情另类小说区图片区视频区| 在线看日本不卡| 国产精品久久久久一区二区三区| 另类专区欧美蜜桃臀第一页| av中文字幕一区| 欧美激情一区在线| 国产一区二区三区四区在线观看| 欧美日韩一区二区在线观看视频| 国产精品高清亚洲| 国产91丝袜在线播放| 欧美xfplay| 日本女人一区二区三区| 91福利在线看| 亚洲精品久久7777| 91在线国产福利| 国产精品嫩草久久久久| 国产精品一级在线| 精品日产卡一卡二卡麻豆| 肉丝袜脚交视频一区二区| 欧美性色黄大片| 亚洲国产欧美在线| 在线观看区一区二| 一区二区三区久久| 欧美专区亚洲专区| 亚洲一区二区三区激情| 一本一道久久a久久精品综合蜜臀| 欧美国产日本视频| 大美女一区二区三区| 日本一区二区免费在线观看视频| 国产在线播放一区| 久久久91精品国产一区二区三区| 久久av老司机精品网站导航| 91精品国产综合久久精品app| 亚洲成人av中文| 3d动漫精品啪啪1区2区免费| 污片在线观看一区二区| 在线不卡欧美精品一区二区三区| 图片区小说区国产精品视频| 777午夜精品免费视频| 全部av―极品视觉盛宴亚洲| 日韩一卡二卡三卡| 精品一区二区三区在线观看 | 制服丝袜亚洲色图| 奇米影视一区二区三区小说| 日韩欧美一级二级三级| 久久国产精品区| 国产欧美一区二区在线| 99精品偷自拍| 亚洲国产另类av| 日韩欧美久久一区| 成人一区二区三区在线观看| 亚洲欧洲精品一区二区三区| 色哦色哦哦色天天综合| 亚洲高清在线视频| 欧美一区二区黄| 国产精品99久久不卡二区| 国产精品久久久久久久久免费相片| hitomi一区二区三区精品| 亚洲精品国产精华液| 欧美日韩另类国产亚洲欧美一级| 久久国产综合精品| 国产精品久久综合| 欧美日韩国产成人在线免费| 韩国一区二区三区| 亚洲日本护士毛茸茸| 777亚洲妇女| 成人动漫一区二区三区| 日日摸夜夜添夜夜添亚洲女人|