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

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

?? disasm.pas

?? SrcDecompiler is about creating a Delphi program decompiler. The program is written for Delphi 4 or
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
unit DisAsm;

interface

uses
  SysUtils, Classes;

type
  EDisAsmError = class(Exception);
  TRegister = (rEax, rEcx, rEdx, rEbx, rEsp, rEbp, rEsi, rEdi);
  TdaRef = record
    MultiplyReg1: Integer;
    ARegister1: TRegister;
    MultiplyReg2: Integer;
    ARegister2: TRegister;
    Immidiate: PChar;
  end;

  TJumpInstrProc = procedure (Param: Pointer; ValueAddress, JumpAddress: PChar; var Result: string);
  TCallInstrProc = procedure (Param: Pointer; ValueAddress, CallAddress: PChar; var Result: string);
  TAddressRefProc = procedure (Param: Pointer; ValueAddress, RefAddress: PChar; var Result: string);
  TRefProc = procedure (Param: Pointer; Ref: TdaRef; RefSize: Integer; var Result: string);
  TImmidiateDataProc = procedure (Param: Pointer; ValueAddress: PChar; OperandSize: Integer; Sigend: Boolean; var Result: string);

  TDisAsm = class(TObject)
  public
    OnJumpInstr: TJumpInstrProc;
    OnCallInstr: TCallInstrProc;
    OnAddressRef: TAddressRefProc;
    OnRef: TRefProc;
    OnImmidiateData: TImmidiateDataProc;
    Param: Pointer;
    function GetInstruction(Address: PChar; var Size: Integer): string;
  end;

const
  modrmReg = $38;  // Reg part of the ModRM byte, ??XXX???
  modrmMod = $C0;  // Mod part of the ModRM byte, XX??????
  modrmRM =  $07;  // RM part of the ModRM byte,  ?????XXX

function SignedIntToHex(Value: Integer; Digits: Integer): string;
function FindFirstSimpleCallTo(CallAddress, SearchAddress: PChar; SearchSize: Integer): PChar;
function FindLastSimpleCallTo(CallAddress, SearchAddress: PChar; SearchSize: Integer): PChar;

implementation

uses
  Windows, DisAsmTables;

// Convert an Integer to a string including a + or - and $ character.
function SignedIntToHex(Value: Integer; Digits: Integer): string;
begin
  if Value < 0 then
    Result := '-$' + IntToHex(-Integer(Value), Digits)
  else
    Result := '+$' + IntToHex(Integer(Value), Digits);
end;

// Reads the instruction at Address and return the Size and the assembler string
// representing the instruction.
function TDisAsm.GetInstruction(Address: PChar; var Size: Integer): string;

var
  Ref: TdaRef;

{ Reading is getting the value at Address + Size and then increment Size
  with the size of the read value }

  function ReadDWord: DWord;
  begin
    if IsBadReadPtr(Address, 4) then
      raise EDisAsmError.Create('Not enough code.');
    Result := PDWord(Address + Size)^;
    Inc(Size, 4);
  end;

  function ReadWord: Word;
  begin
    if IsBadReadPtr(Address, 2) then
      raise EDisAsmError.Create('Not enough code.');
    Result := PWord(Address + Size)^;
    Inc(Size, 2);
  end;

  function ReadByte: Byte;
  begin
    if IsBadReadPtr(Address, 1) then
      raise EDisAsmError.Create('Not enough code.');
    Result := PByte(Address + Size)^;
    Inc(Size, 1);
  end;

  function GetRefAddress: string;
  var
    RefAddress: PChar;
  begin
    RefAddress := PChar(ReadDWord);
    Ref.Immidiate := Ref.Immidiate + Integer(RefAddress);
    Result := '$' + IntToHex(DWord(RefAddress), 4);
    if Assigned(OnAddressRef) then
      OnAddressRef(Param, Address + Size - 4, RefAddress, Result);
    Result := '^' + Chr(Length(Result)) + Result;
  end;

// Only read the ModRM byte the first time it is asked.
// After that return the previous read ModRM byte
var
  XHasModRM: Boolean;
  XModRM: Byte;

  function ModRM: Byte;
  begin
    if not XHasModRM then
    begin
      XModRM := ReadByte;
      XHasModRM := True;
    end;
    Result := XModRM;
  end;

// Only read the Sib byte the first time it is asked.
// After that return the previous read Sib byte
var
  XHasSib: Boolean;
  XSib: Byte;

  function Sib: Byte;
  begin
    if not XHasSib then
    begin
      XSib := ReadByte;
      XHasSib := True;
    end;
    Result := XSib;
  end;

var
  DeffOperandSize: Integer;// Default = 4, but may be changed by operand prefix.
  AddressSize: Integer;    // Default = 4, but may be changed by operand prefix.
  OperandSize: Integer;    // Default = 0
  SegOverride: Boolean;
  SegName: string;
  MustHaveSize: Boolean;

  // Operand anlayser.
  function Operand(AddrMethod, OperandType, EnhOperandType: char): string;

    // Returns the name of the register specified by Reg using OperandType
    // to determen the size.
    function GetRegName(Reg: Byte): string;
    const
      ByteRegs1: array[0..3] of char = 'acdb';
      ByteRegs2: array[0..1] of char = 'lh';
      WordRegs1: array[0..7] of char = 'acdbsbsd';
      WordRegs2: array[0..4] of char = 'xxpi';
    begin
      if OperandSize = 1 then
        Result := ByteRegs1[Reg mod 4] + ByteRegs2[Reg div 4]
      else
      begin
        if OperandSize = 4 then
          Result := 'e'
        else
          Result := '';
        Result  := Result + WordRegs1[Reg] + WordRegs2[Reg div 2];
      end;
    end;

    // Returns the description of the effective address in the ModRM byte.
    function GetEffectiveAddress(EAMustHaveSize: Boolean): string;
    var
      RM: Byte;
      AMod: Byte;

      function ReadSib: string;
      var
        SI: Byte;
        SS: Byte;
        Base: Byte;
      begin
        Base := Sib and $07;        {?????XXX}
        SI := (Sib shr 3) and $07;  {??XXX???}
        SS := (Sib shr 6) and $03;  {XX??????}

        // Save register used by Base
        case Base of
          0: Result := '[eax';
          1: Result := '[ecx';
          2: Result := '[edx';
          3: Result := '[ebx';
          4: Result := '[esp';
          5: if AMod <> 0 then
               Result := '[ebp'
             else
               Result := '[' + GetRefAddress;
          6: Result := '[esi';
          7: Result := '[edi';
        end;
        if (Base <> 5) or (AMod = 0) then
        begin
          Ref.ARegister2 := TRegister(Base);
          Ref.MultiplyReg2 := 1;
        end;

        // result register Scaled Index
        case SI of
          0: Result := Result + '+eax';
          1: Result := Result + '+ecx';
          2: Result := Result + '+edx';
          3: Result := Result + '+ebx';
          5: Result := Result + '+ebp';
          6: Result := Result + '+esi';
          7: Result := Result + '+edi';
        end;
        if SI <> 4 then
          Ref.ARegister1 := TRegister(SI);

        // No SS when SI = 4
        if SI <> 4 then
          // Save modification made by SS
          case SS of
            0: begin Result := Result + '';   Ref.MultiplyReg1 := 1; end;
            1: begin Result := Result + '*2'; Ref.MultiplyReg1 := 2; end;
            2: begin Result := Result + '*4'; Ref.MultiplyReg1 := 4; end;
            3: begin Result := Result + '*8'; Ref.MultiplyReg1 := 8; end;
          end;
      end;

    var
      I: Integer;
    begin
      RM := ModRM and modrmRM;
      AMod := ModRm and modrmMod shr 6;

      // Effective address is a register;
      if AMod = 3 then
      begin
        Result := GetRegName(RM);
        Exit;
      end;

      Result := '%s' + Chr(OperandSize);

      // override seg name
      if SegOverride then
        Result := Result + SegName + ':';

      // Include the Size if it is other than 4
      if (OperandSize <> 4) and (OperandSize <> 0) then
        MustHaveSize := True;

      if AddressSize = 4 then
      begin
        // disp32.
        if (AMod = 0) and (RM = 5) then
        begin
          Result := Result + '[' + GetRefAddress + ']';
          if Assigned(OnRef) then
            OnRef(Param, Ref, OperandSize, Result);
          Exit;
        end;
      end
      else
      begin
        // disp16
        if (AMod = 0) and (RM = 6) then
        begin
          Result := Result + '[' + GetRefAddress + ']';
          if Assigned(OnRef) then
            OnRef(Param, Ref, OperandSize, Result);
          Exit;
        end;
      end;

      // Analyse RM Value.
      if AddressSize = 2 then
        case RM of
          0: Result := Result + '[bx+si';
          1: Result := Result + '[bx+di';
          2: Result := Result + '[bp+si';
          3: Result := Result + '[bp+di';
          4: Result := Result + '[si';
          5: Result := Result + '[di';
          6: Result := Result + '[bp';
          7: Result := Result + '[bx';
        end
      else
      begin
        case RM of
          0: Result := Result + '[eax';
          1: Result := Result + '[ecx';
          2: Result := Result + '[edx';
          3: Result := Result + '[ebx';
          4: Result := Result + ReadSIB;
          5: Result := Result + '[ebp';
          6: Result := Result + '[esi';
          7: Result := Result + '[edi';
        end;
        if RM <> 4 then
        begin
          Ref.ARegister1 := TRegister(RM);
          Ref.MultiplyReg1 := 1;
        end;
      end;

      // possible disp value dependent of Mod.
      case AMod of
        // no disp
        0: Result := Result + ']';
        // disp8
        1: begin
             I := ShortInt(ReadByte);
             Result := Result + SignedIntToHex(I, 2) + ']';
             Inc(Ref.Immidiate, I);
           end;
        // disp32 or disp16
        2: Result := Result + '+' + GetRefAddress + ']';
      end;

      // Call the OnRef proc.
      if Assigned(OnRef) then
        OnRef(Param, Ref, OperandSize, Result);
    end;

  var
   I: Integer;
  begin
    Result := '';
    // Save the operand size using the DeffOperandSize and SubType
    case OperandType of
      // two Word or two DWord, only used by BOUND
      'a': if DeffOperandSize = 2 then
             OperandSize := 4

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色偷偷成人一区二区三区91| 成人午夜电影小说| 亚洲自拍与偷拍| 亚洲乱码国产乱码精品精的特点 | 日本中文在线一区| 午夜精品久久久久久久| 日本亚洲天堂网| 国产在线播放一区三区四| 久久精品二区亚洲w码| 国内精品伊人久久久久av影院 | 本田岬高潮一区二区三区| 国产麻豆精品一区二区| 成人一区二区三区在线观看| 成人av影院在线| 91麻豆精东视频| 在线不卡欧美精品一区二区三区| 欧美高清视频不卡网| 国产精品久久久久久亚洲毛片 | 日精品一区二区| 国产综合色产在线精品| zzijzzij亚洲日本少妇熟睡| 91丨国产丨九色丨pron| 欧美日韩视频第一区| 日韩一区二区三区在线视频| 久久青草欧美一区二区三区| 自拍偷自拍亚洲精品播放| 亚洲一区二区三区在线播放| 精品一区二区综合| 97精品久久久午夜一区二区三区| 欧美日韩国产一区| 国产欧美一区二区三区沐欲| 亚洲一级在线观看| 国产乱国产乱300精品| 色94色欧美sute亚洲13| 久久影院电视剧免费观看| 中文字幕日韩一区| 久久精品国产久精国产| 色婷婷综合中文久久一本| 欧美不卡在线视频| 亚洲午夜影视影院在线观看| 国产精品影音先锋| 欧美疯狂性受xxxxx喷水图片| 国产亚洲1区2区3区| 天堂资源在线中文精品| youjizz国产精品| 亚洲精品一区二区三区蜜桃下载| 亚洲综合一区在线| eeuss国产一区二区三区| 日韩午夜中文字幕| 亚洲一区影音先锋| 9色porny自拍视频一区二区| 欧美一区午夜视频在线观看| 国产欧美日韩在线| 亚洲午夜久久久久中文字幕久| 国产电影一区在线| 日韩一区二区免费在线电影| 亚洲尤物在线视频观看| 成人激情校园春色| 欧美激情综合五月色丁香| 久热成人在线视频| 日韩一级成人av| 亚洲电影在线免费观看| 99久久免费视频.com| 亚洲国产精品成人综合 | 欧美日韩在线电影| 亚洲美腿欧美偷拍| www.亚洲免费av| 国产精品久久久久四虎| 成人午夜在线视频| 国产视频在线观看一区二区三区| 精品一区二区影视| 久久影院电视剧免费观看| 久久精品国产亚洲aⅴ| 日韩视频在线你懂得| 免费在线观看一区| 欧美zozozo| 国产真实乱子伦精品视频| 日韩欧美国产电影| 国产精品一二三四区| 国产日韩av一区| 成人福利电影精品一区二区在线观看| 精品sm捆绑视频| 风间由美一区二区三区在线观看| 中文在线一区二区| 91一区二区三区在线观看| 亚洲男人的天堂在线aⅴ视频| 日本黄色一区二区| 婷婷亚洲久悠悠色悠在线播放| 在线电影院国产精品| 久久 天天综合| 欧美激情在线免费观看| 色诱亚洲精品久久久久久| 香蕉久久夜色精品国产使用方法 | 久久蜜桃一区二区| 高清不卡一二三区| 一区二区三区免费在线观看| 欧美精品色一区二区三区| 欧美bbbbb| 国产精品网站导航| 欧美日韩一区二区三区免费看| 日本在线不卡视频| 国产欧美日本一区视频| 在线免费不卡电影| 久国产精品韩国三级视频| 中文字幕第一页久久| 欧美日韩在线三级| 国产a精品视频| 爽好久久久欧美精品| 国产亚洲精久久久久久| 欧美在线观看视频一区二区 | 欧美一级高清片| 成人三级在线视频| 欧美aaaaaa午夜精品| 国产精品久久久久影院色老大| 3d动漫精品啪啪| 91在线看国产| 国产激情一区二区三区四区| 亚洲最大色网站| 国产丝袜欧美中文另类| 7777精品久久久大香线蕉| 成人精品小蝌蚪| 黄页视频在线91| 亚洲高清三级视频| 亚洲色图欧洲色图婷婷| 久久嫩草精品久久久久| 欧美日韩国产精品成人| 成人午夜精品在线| 久久er99热精品一区二区| 亚洲一区二区三区国产| 亚洲视频免费观看| 国产亚洲欧洲997久久综合| 3751色影院一区二区三区| 99久久99久久精品国产片果冻| 久久66热偷产精品| 香蕉成人啪国产精品视频综合网 | 欧美日本在线播放| 成人丝袜18视频在线观看| 国内精品在线播放| 美女脱光内衣内裤视频久久网站| 亚洲午夜一区二区| 一区2区3区在线看| 亚洲伦在线观看| 成人免费在线视频观看| 欧美激情一区二区| 国产精品色哟哟| 中文字幕第一区综合| 国产精品三级电影| 国产精品视频一区二区三区不卡| 久久久久88色偷偷免费| 久久精品视频一区二区三区| 久久色在线观看| 国产欧美日韩久久| 国产精品萝li| 中文字幕在线不卡视频| 亚洲嫩草精品久久| 亚洲国产cao| 日韩经典一区二区| 美女视频黄频大全不卡视频在线播放| 偷窥国产亚洲免费视频| 免费成人在线观看视频| 国产一区二区在线影院| 国产精品88888| 波多野结衣欧美| 欧美亚一区二区| 91精品欧美久久久久久动漫 | 亚洲图片你懂的| 亚洲视频综合在线| 五月天中文字幕一区二区| 秋霞午夜鲁丝一区二区老狼| 美女一区二区在线观看| 国产激情一区二区三区桃花岛亚洲| 国产精品99久久久久久宅男| 99久久免费视频.com| 欧美日韩国产bt| 精品国产亚洲在线| 中文字幕中文在线不卡住| 一区二区视频免费在线观看| 免费av成人在线| 成人一区在线观看| 欧美日韩国产一二三| 久久久91精品国产一区二区三区| 亚洲天堂中文字幕| 日韩成人午夜电影| 成人激情开心网| 欧美日韩国产a| 欧美激情在线观看视频免费| 亚洲综合一区二区三区| 国产在线精品免费av| 欧美性大战久久| 精品99999| 亚洲动漫第一页| 成人美女在线观看| 欧美一级片免费看| 亚洲黄色免费网站| 国产精品18久久久久久久久| 欧美日韩国产系列| 18欧美亚洲精品| 国产美女精品在线| 538在线一区二区精品国产| **性色生活片久久毛片|