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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? disassembler.c

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

Copyright (c) 2000-2001 Goran Devic
Modified (c) 2001 Klaus P. Gerlicher

Module Name:

    disassembler.c

Abstract:

    line disassembler

Environment:

    LINUX 2.2.X
    Kernel mode only

Author:

    Goran Devic

Revision History:

  17-Mar-2000:  Original                                        (Goran Devic)
  26-Apr-2000:  Major rewrite, added coprocessor instructions   (Goran Devic)
  04-Nov-2000:  Modified for LinIce                             (Goran Devic)
  05-Jan-2001:  Modified for pICE                               (Klaus P. Gerlicher)


Copyright notice:

  This file may be distributed under the terms of the GNU Public License.

--*/

/*******************************************************************************
*   Include Files                                                             *
******************************************************************************/
#include "remods.h"
#include "precomp.h"

#include "disassemblerdata.h"           // Include its own data

/******************************************************************************
*
*   This structure is used to pass parameters and options to the
*   line disassembler.
*
******************************************************************************/
typedef struct
{
    ULONG dwFlags;              // Generic flags (described below)
    USHORT wSel;                  // Selector to use to fetch code
    UCHAR *bpTarget;             // Target pointer to disassemble
    UCHAR *szDisasm;             // String where to put ascii result
    UCHAR Codes[20];             // Buffer where to store code UCHARs

    UCHAR bAsciiLen;             // Length of the ascii result
    UCHAR bInstrLen;             // Instruction lenght in UCHARs

    int nDisplacement;          // Scanner: possible constant displacement
    int nScanEnum;              // Scanner: specific flags SCAN_*

} TDisassembler;

// dwFlags contains a set of boolean flags with the following functionality

#define DIS_DATA32          0x0001  // Data size 16/32 bits (0/1)
#define   DIS_GETDATASIZE(flags) ((flags)&DIS_DATA32)
#define DIS_ADDRESS32       0x0002  // Address size 16/32 bits (0/1)
#define   DIS_GETADDRSIZE(flags) (((flags)&DIS_ADDRESS32)?1:0)

#define DIS_SEGOVERRIDE     0x0004  // Default segment has been overriden

#define DIS_REP             0x0100  // Return: REP prefix found (followed by..)
#define DIS_REPNE           0x0200  // Return: REPNE prefix found
#define   DIS_GETREPENUM(flags)  (((flags)>>8)&3)
#define DIS_ILLEGALOP       0x8000  // Return: illegal opcode


/******************************************************************************
*                                                                             *
*   Global Variables                                                          *
*                                                                             *
******************************************************************************/


/******************************************************************************
*                                                                             *
*   External functions (optional)                                             *
*                                                                             *
******************************************************************************/

/******************************************************************************
*                                                                             *
*   Local Defines, Variables and Macros                                       *
*                                                                             *
******************************************************************************/
UCHAR GetUCHAR(ULONG addr)
{
    if(IsAddressValid(addr))
        return *(PUCHAR)addr;
    else
        return 0x82; // INVALID OPCODE
}

static UCHAR GetNextUCHAR(USHORT sel, UCHAR *offset, UCHAR *pCode)
{
    pCode[0] = GetUCHAR((ULONG) offset + 0) & 0xFF;

    return( pCode[0] );
}

static USHORT GetNextUSHORT(USHORT sel, UCHAR *offset, UCHAR *pCode)
{
    pCode[0] = GetUCHAR((ULONG) offset + 0) & 0xFF;
    pCode[1] = GetUCHAR((ULONG) offset + 1) & 0xFF;

    return( *(USHORT *) pCode );
}

static ULONG GetNextULONG(USHORT sel, UCHAR *offset, UCHAR *pCode)
{
    pCode[0] = GetUCHAR((ULONG) offset + 0) & 0xFF;
    pCode[1] = GetUCHAR((ULONG) offset + 1) & 0xFF;
    pCode[2] = GetUCHAR((ULONG) offset + 2) & 0xFF;
    pCode[3] = GetUCHAR((ULONG) offset + 3) & 0xFF;

    return( *(ULONG *) pCode );
}


#define NEXTUCHAR    GetNextUCHAR( pDis->wSel, bpTarget, bpCode); bpCode += 1; bpTarget += 1; bInstrLen += 1

#define NEXTUSHORT    GetNextUSHORT( pDis->wSel, bpTarget, bpCode); bpCode += 2; bpTarget += 2; bInstrLen += 2

#define NEXTULONG   GetNextULONG(pDis->wSel, bpTarget, bpCode); bpCode += 4; bpTarget += 4; bInstrLen += 4


/******************************************************************************
*                                                                             *
*   Functions                                                                 *
*                                                                             *
******************************************************************************/

/******************************************************************************
*                                                                             *
*   UCHAR Disassembler( TDisassembler *pDis );                                 *
*                                                                             *
*******************************************************************************
*
*   This is a generic Intel line disassembler.
*
*   Where:
*       TDisassembler:
*           bpTarget is the address of instruction to disassemble
*           szDisasm is the address of the buffer to print a line into
*           dwFlags contains the default operand and address bits
*           pCode is the address to store code UCHARs (up to 16)
*
*   Disassembled instruction is stored as an ASCIIZ string pointed by
*   szDisasm pointer (from the pDis structure).
*
*   Returns:
*       TDisassembler:
*           *szDisasm contains the disassembled instruction string
*           bAsciiLen is set to the length of the printed string
*           bInstrLen is set to instruction length in UCHARs
*           dwFlags - has operand and address size flags adjusted
*                   - DIS_ILLEGALOP set if that was illegal instruction
*       UCHAR - instruction length in UCHARs
*
******************************************************************************/
UCHAR Disassembler( TDisassembler *pDis )
{
    TOpcodeData *p;             // Pointer to a current instruction record
    UCHAR   *bpTarget;           // Pointer to the target code to be disassembled
    UCHAR   *bpCode;             // Pointer to code UCHARs
    ULONG   arg;                // Argument counter
    char   *sPtr;               // Message selection pointer
    int     nPos;               // Printing position in the output string
    UCHAR   *pArg;               // Pointer to record where instruction arguments are
    ULONG   dwULONG;            // Temporary ULONG storage
    USHORT    wUSHORT;              // Temporary USHORT storage
    UCHAR    bUCHAR;              // Temporary UCHAR storage
    UCHAR    bInstrLen;          // Current instruction lenght in UCHARs
    UCHAR    bOpcode;            // Current opcode that is being disassembled
    UCHAR    bSegOverride;       // 0 default segment. >0, segment index
    UCHAR    bMod=0;             // Mod field of the instruction
    UCHAR    bReg=0;             // Register field of the instruction
    UCHAR    bRm=0;                // R/M field of the instruction
    UCHAR    bW;                 // Width bit for the register selection

    UCHAR    bSib;               // S-I-B UCHAR for the instruction
    UCHAR    bSs;                // SS field of the s-i-b UCHAR
    UCHAR    bIndex;             // Index field of the s-i-b UCHAR
    UCHAR    bBase;              // Base field of the s-i-b UCHAR
    LPSTR    pSymbolName;        // used to symbolic name of value

    bInstrLen = 0;              // Reset instruction lenght to zero
    bSegOverride = 0;           // Set default segment (no override)
    nPos = 0;                   // Reset printing position
    sPtr = NULL;                // Points to no message by default
    bpTarget = pDis->bpTarget;  // Set internal pointer to a target address
    bpCode = pDis->Codes;       // Set internal pointer to code UCHARs

    do
    {
        bOpcode = NEXTUCHAR;     // Get the first opcode UCHAR from the target address
        p = &Op1[bOpcode];      // Get the address of the instruction record

        if( p->flags & DIS_SPECIAL )
        {
            // Opcode is one of the special ones, so do what needs to be done there

            switch( p->name )
            {
                case _EscD8:
                case _EscD9:
                case _EscDA:
                case _EscDB:
                case _EscDC:
                case _EscDD:
                case _EscDE:
                case _EscDF:        // Coprocessor escape: UCHARs D8 - DF
                    bOpcode = NEXTUCHAR;             // Get the modRM UCHAR of the instruction

                    if( bOpcode < 0xC0 )
                    {
                        // Opcodes 00-BF use Coproc1 table

                        bReg = (bOpcode >> 3) & 7;
                        p = &Coproc1[ p->name - _EscD8 ][ bReg ];

                        goto StartInstructionParseMODRM;
                    }
                    // Opcodes C0-FF use Coproc2 table

                    p = &Coproc2[ p->name - _EscD8 ][ bOpcode - 0xC0 ];

                goto StartInstructionNoMODRM;

                case _S_ES:         // Segment override
                case _S_CS:
                case _S_SS:
                case _S_DS:
                case _S_FS:
                case _S_GS:
                    bSegOverride = p->name - _S_ES + 1;
                continue;

                case _OPSIZ:        // Operand size override - toggle
                    pDis->dwFlags ^= DIS_DATA32;
                continue;

                case _ADSIZ:        // Address size override - toggle
                    pDis->dwFlags ^= DIS_ADDRESS32;
                continue;

                case _REPNE:        // REPNE/REPNZ prefix
                    pDis->dwFlags |= DIS_REPNE;
                continue;

                case _REP:          // REP/REPE/REPZ prefix
                    pDis->dwFlags |= DIS_REP;
                continue;

                case _2BESC:        // 2 UCHAR escape code 0x0F
                    bOpcode = NEXTUCHAR;             // Get the second UCHAR of the instruction
                    p = &Op2[bOpcode];              // Get the address of the instruction record

                    if( !(p->flags & DIS_SPECIAL) ) goto StartInstruction;
                    if( p->name < _GRP6 ) goto IllegalOpcode;

                case _GRP1a:        // Additional groups of instructions
                case _GRP1b:
                case _GRP1c:
                case _GRP2a:
                case _GRP2b:
                case _GRP2c:
                case _GRP2d:
                case _GRP2e:
                case _GRP2f:
                case _GRP3a:
                case _GRP3b:
                case _GRP4:
                case _GRP5:
                case _GRP6:
                case _GRP7:
                case _GRP8:
                case _GRP9:

                    bOpcode = NEXTUCHAR;             // Get the Mod R/M UCHAR whose...
                                                    // bits 3,4,5 select instruction

                    bReg = (bOpcode >> 3) & 7;
                    p = &Groups[p->name - _GRP1a][ bReg ];

                    if( !(p->flags & DIS_SPECIAL) ) goto StartInstructionParseMODRM;

                case _NDEF :        // Not defined or illegal opcode
                    goto IllegalOpcode;

                default :;          // Should not happen
            }
        }
        else
            goto StartInstruction;
    }
    while( bInstrLen < 15 );

IllegalOpcode:

    nPos += PICE_sprintf( pDis->szDisasm+nPos, "invalid");
    pDis->dwFlags |= DIS_ILLEGALOP;

    goto DisEnd;

StartInstruction:

    // If this instruction needs additional Mod R/M UCHAR, fetch it

    if( p->flags & DIS_MODRM )
    {
        // Get the next UCHAR (modR/M bit field)
        bOpcode = NEXTUCHAR;

        bReg = (bOpcode >> 3) & 7;

StartInstructionParseMODRM:

        // Parse that UCHAR and get mod, reg and rm fields
        bMod = bOpcode >> 6;
        bRm  = bOpcode & 7;
    }

StartInstructionNoMODRM:

    // Print the possible repeat prefix followed by the instruction

    if( p->flags & DIS_COPROC )
        nPos += PICE_sprintf( pDis->szDisasm+nPos, "%-6s ", sCoprocNames[ p->name ]);
    else
        nPos += PICE_sprintf( pDis->szDisasm+nPos, "%s%-6s ",
                sRep[DIS_GETREPENUM(pDis->dwFlags)],
                sNames[ p->name + (DIS_GETNAMEFLAG(p->flags) & DIS_GETDATASIZE(pDis->dwFlags)) ] );

    // Do instruction argument processing, up to 3 times

    pArg = &p->dest;

    for( arg=p->args; arg!=0; arg--, pArg++, arg? nPos += PICE_sprintf( pDis->szDisasm+nPos,", ") : 0 )
    {
        switch( *pArg )
        {
             case _Eb :                                         // modR/M used - bW = 0
                bW = 0;
                goto _E;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区三区在线看| 丁香天五香天堂综合| 久久精品久久久精品美女| 国产专区综合网| 欧美在线三级电影| 国产日韩欧美亚洲| 日本v片在线高清不卡在线观看| av不卡免费电影| 日韩免费电影一区| 国产一区 二区| 欧美日韩国产综合久久| 综合婷婷亚洲小说| 懂色av噜噜一区二区三区av| 欧美浪妇xxxx高跟鞋交| 国产精品国产三级国产| 国产精品资源网| 911精品国产一区二区在线| 亚洲美女偷拍久久| 成人网页在线观看| 久久美女艺术照精彩视频福利播放 | 欧美一区二区视频在线观看| 国产精品丝袜久久久久久app| 美女脱光内衣内裤视频久久影院| 91成人免费电影| 亚洲嫩草精品久久| 不卡的av中国片| 中文av一区二区| 成人免费av网站| 国产精品私房写真福利视频| 国产高清在线观看免费不卡| 欧美精品一区二区在线观看| 久久精品国产在热久久| 91精品国产欧美日韩| 午夜精品福利一区二区三区av| 欧美亚洲综合在线| 午夜欧美在线一二页| 欧美精品丝袜中出| 日韩福利电影在线| 日韩三级视频中文字幕| 老司机免费视频一区二区| 91精品国产综合久久精品 | 欧洲色大大久久| 亚洲一区二区三区四区五区中文| 欧美在线观看一二区| 一区二区三区四区中文字幕| 欧美视频精品在线观看| 婷婷六月综合亚洲| 精品国产sm最大网站免费看| 国产精品中文字幕日韩精品| 国产欧美一区二区三区鸳鸯浴| 成人av中文字幕| 樱花草国产18久久久久| 91精品久久久久久久久99蜜臂| 蜜臀久久99精品久久久久宅男| 精品国产91乱码一区二区三区| 国产精品一区二区果冻传媒| 国产精品家庭影院| 欧美日韩三级一区二区| 久久精品国产久精国产| 国产精品免费视频观看| 在线亚洲一区二区| 免费视频最近日韩| 国产精品不卡在线观看| 欧美剧在线免费观看网站| 一本久道久久综合中文字幕| 亚洲6080在线| 国产亚洲精品资源在线26u| 91网址在线看| 蜜桃视频在线观看一区| 国产精品沙发午睡系列990531| 欧洲一区在线电影| 国产高清不卡二三区| 玉足女爽爽91| 久久午夜电影网| 欧美午夜不卡在线观看免费| 国产精品综合久久| 爽好久久久欧美精品| 中文字幕欧美日韩一区| 911精品产国品一二三产区| 成人黄色小视频| 美美哒免费高清在线观看视频一区二区| 亚洲国产成人在线| 日韩精品中文字幕一区| 91福利在线看| 成人黄色综合网站| 韩国成人精品a∨在线观看| 亚洲精品乱码久久久久久| 精品久久久久久久人人人人传媒 | 粉嫩av一区二区三区在线播放| 亚洲国产成人精品视频| 国产精品伦理在线| 久久久天堂av| 欧美一区二区视频免费观看| 欧美怡红院视频| 99久久婷婷国产综合精品电影| 久久激情综合网| 亚洲国产aⅴ天堂久久| 中文字幕亚洲一区二区av在线| 欧美一级片在线观看| 91成人国产精品| 91蜜桃传媒精品久久久一区二区| 国产成人亚洲综合a∨猫咪| 日韩成人dvd| 午夜欧美在线一二页| 亚洲自拍与偷拍| 亚洲免费观看高清完整版在线观看| 国产日产精品1区| 国产亚洲女人久久久久毛片| 亚洲精品在线观看网站| 日韩久久免费av| 欧美电影免费观看高清完整版在线| 欧美人动与zoxxxx乱| 欧美亚洲图片小说| 在线观看免费一区| 欧美三级午夜理伦三级中视频| 在线中文字幕一区二区| 在线观看免费一区| 欧美日韩黄色影视| 欧美性生活一区| 欧美三级电影网| 欧美日韩不卡视频| 欧美一区二区久久久| 69堂国产成人免费视频| 日韩午夜激情免费电影| 亚洲精品一区二区精华| 2023国产一二三区日本精品2022| 久久夜色精品国产噜噜av| 欧美精品一区二区三区一线天视频 | 日韩精品电影在线观看| 免费成人在线观看视频| 国产综合色产在线精品 | 婷婷开心久久网| 美腿丝袜亚洲一区| 国产乱一区二区| 91丨九色丨尤物| 欧美日韩夫妻久久| 亚洲精品一线二线三线| 国产色一区二区| 亚洲色图20p| 日韩成人午夜精品| 国产永久精品大片wwwapp| 不卡欧美aaaaa| 在线视频观看一区| 日韩一区二区精品| 国产精品成人免费精品自在线观看 | 久热成人在线视频| 成人高清免费观看| 欧美美女一区二区| 久久精品视频网| 亚洲国产成人va在线观看天堂| 美女诱惑一区二区| 91视频一区二区| 日韩欧美精品在线| 亚洲图片另类小说| 蜜桃av一区二区| 91网站在线播放| 日韩一区二区三免费高清| 国产精品免费丝袜| 美美哒免费高清在线观看视频一区二区| 国产不卡视频在线播放| 欧美吞精做爰啪啪高潮| 久久久久久久久久久电影| 亚洲精品网站在线观看| 国产在线一区观看| 欧美性猛交xxxxxxxx| 亚洲国产精品激情在线观看| 肉丝袜脚交视频一区二区| 成人app网站| 精品国产网站在线观看| 亚洲一区二区影院| eeuss鲁片一区二区三区在线观看| 欧美放荡的少妇| 亚洲免费av在线| 国产一区二区三区| 91精品国产综合久久精品图片 | 午夜久久福利影院| 99麻豆久久久国产精品免费| 日韩视频一区二区| 日韩在线播放一区二区| 在线观看av不卡| 亚洲欧美激情视频在线观看一区二区三区 | 高清不卡在线观看av| 欧美一区二区人人喊爽| 亚洲影院在线观看| 91在线视频免费91| 国产精品国产三级国产aⅴ原创| 激情五月播播久久久精品| 欧美老年两性高潮| 亚洲国产成人精品视频| 91福利在线免费观看| 亚洲女同女同女同女同女同69| 日韩欧美另类在线| 日韩国产欧美视频| 欧美福利一区二区| 日韩av在线播放中文字幕| 欧美精品一二三区| 日韩精品三区四区| 777午夜精品视频在线播放| 亚洲国产欧美在线人成| 精彩视频一区二区|