• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-341  評論-2670  文章-0  trackbacks-0
                完整的轉換方法需要intel提供免費翻印下載的那本手冊。手冊過于精簡,因此這里給出的例子用于輔助對手冊進行理解。假設讀者閱讀過intel提供的手冊,或其他相關資料。

                x86中大多數指令的16位與32位版本(指的是寄存器而不是地址)的opcode都是相同的。如果將一個字節66H加載指令前的話,使用“與缺省不同的位數”。也就是說,用的操作系統是32位的話,那么使用66H前綴就代表需要對16位的寄存器進行操作。

                下面對指令ADD [EDX*8+EBX+256],EBX進行翻譯。x86的32位CPU所用的指令集結構是:Prefix | OpCode | ModR/M | SIB | Displacement | Immediate。

                指令名ADD,第一個參數為dword ptr [EDX*8+EBX+256],第二個參數為EBX。因此應該使用下面的opcode進行翻譯(見手冊)。
            1 01/r                ADD,r/m32,r32

                r/m32代表由寄存器表達式計算而成的指針數值所指向的內存中記載的32位數字,而r32則代表一個32位。這里用的是r/m32和r32而不是r/m16和r/16,因此不需要66H前綴,因此指令的第一個字節是01H

                第二個字節是ModR/M碼,這一個字節指的是操作數的形式。我們需要一個r/m32與r/32,因此ModR/M的前兩位是10,因為Mod=10下面的R/M位為100的時候可以使用[SIB+disp32]作為參數,也就是[EDX*8+EBX+256]了,此時SIB=EDX*8+EBX,disp32=256=00 01 00 00。這時我們確定了5個位。再看看opcode,有/r標志,也就是說digit那3個位將用來記住第二個參數EBX,EBX的代號是3,也就是011。將Mod=10,digit=011,R/M=100連起來得到第二個字節的值:10011100=9CH

                第三個字節是SIB,用來表達EDX*8+EBX。SIB所表示的是Index*Scale+Base,其中Index=EDX=2=010,Base=EBX=3=011,Scale=8=3=11(這里1,2,4,8分別用0,1,2,3來表示,因此8=3)。將它們按照Scale Index Base的順序組合起來,得到第三個字節的值:11010011=D3H

                接下來就是disp32了。disp32=256,很容易得出這4個字節分別是00H 01H 00H 00H

                于是這個指令的2進制碼就是01 9C D3 00 01 00 00

                接下里看一看Prefix的意思。如果寫的指令是ADD [EDX*8+EBX+256],BX的話,BX是16位,因此32位指針指向的也是16位的兩個字節,所以使用如下opcode:
            1 01/r                ADD,r/m16,r16

                翻譯過程與上面一致,但是需要加上66H前綴使之使用它16位版本的指令。因此這個指令的2進制碼就是66 01 9C D3 00 01 00 00了。

                如何檢查上面的翻譯對不對呢?只需要打開vc2008,將匯編代碼寫在__asm{ }里面,然后下個斷點,運行之后用ctrl+alt+D,并在右鍵菜單打開show code bytes選項即可。這里附上從vc2008的調試其中復制出來的結果:
             1    106:     __asm
             2    107:     {
             3    108:         INT 3
             4 011A7186 CC               int         3    
             5    109:         ADC AL,8
             6 011A7187 14 08            adc         al,8 
             7    110:         ADC AX,8
             8 011A7189 66 83 D0 08      adc         ax,8 
             9    111:         ADC EAX,8
            10 011A718D 83 D0 08         adc         eax,8 
            11    112:         ADD AL,10
            12 011A7190 04 0A            add         al,0Ah 
            13    113:         ADD AX,10
            14 011A7192 66 83 C0 0A      add         ax,0Ah 
            15    114:         ADD EAX,10
            16 011A7196 83 C0 0A         add         eax,0Ah 
            17    115:         ADD AL,DL
            18 011A7199 02 C2            add         al,dl 
            19    116:         ADD AX,DX
            20 011A719B 66 03 C2         add         ax,dx 
            21    117:         ADD EAX,EDX
            22 011A719E 03 C2            add         eax,edx 
            23    118:         ADD BL,[EDX]
            24 011A71A0 02 1A            add         bl,byte ptr [edx] 
            25    119:         ADD BX,[EDX*2]
            26 011A71A2 66 03 1C 55 00 00 00 00 add         bx,word ptr [edx*2
            27    120:         ADD EBX,[EDX*4+8]
            28 011A71AA 03 1C 95 08 00 00 00 add         ebx,dword ptr [edx*4+8
            29    121:         ADD [EDX*8+EBX],BL
            30 011A71B1 00 1C D3         add         byte ptr [ebx+edx*8],bl 
            31    122:         ADD [EDX*8+EBX],BX
            32 011A71B4 66 01 1C D3      add         word ptr [ebx+edx*8],bx 
            33    123:         ADD [EDX*8+EBX+256],BX
            34 011A71B8 66 01 9C D3 00 01 00 00 add         word ptr [ebx+edx*8+100h],bx 
            35    124:         ADD [EDX*8+EBX+256],EBX
            36 011A71C0 01 9C D3 00 01 00 00 add         dword ptr [ebx+edx*8+100h],ebx 
            37    125:         BSWAP EAX
            38 011A71C7 0F C8            bswap       eax  
            39    126:         BSWAP EDI
            40 011A71C9 0F CF            bswap       edi  
            41    127:     }
            posted on 2009-02-15 23:45 陳梓瀚(vczh) 閱讀(3674) 評論(5)  編輯 收藏 引用 所屬分類: JIT

            評論:
            # re: JIT腳本引擎:將匯編指令轉換為機器碼 2009-02-16 00:56 | erfg
            那有這方面的相關資料啊?
            把參考文獻也注明好嗎?  回復  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉換為機器碼 2009-02-16 02:33 | 陳梓瀚(vczh)
            @erfg
            Intel的官方主頁上有手冊下載,還可以填一份表格然后讓他免費將印刷版寄給你。  回復  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉換為機器碼 2009-02-16 17:15 | 夢在天涯
            高深啊!  回復  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉換為機器碼 2009-02-16 19:17 | kals
            @陳梓瀚(vczh)
            好申請嗎?  回復  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉換為機器碼 2009-02-16 21:48 | 陳梓瀚(vczh)
            @kals
            基本有求必應  回復  更多評論
              
            囯产极品美女高潮无套久久久 | 国内精品久久久久国产盗摄| 精品久久久久中文字| 欧美精品一区二区久久 | 无码人妻少妇久久中文字幕| 久久精品国产99久久久| 中文字幕亚洲综合久久2| 日韩十八禁一区二区久久| 94久久国产乱子伦精品免费 | 尹人香蕉久久99天天拍| 亚洲狠狠婷婷综合久久蜜芽| 中文字幕精品久久| 97久久久久人妻精品专区| 麻豆一区二区99久久久久| 欧美粉嫩小泬久久久久久久| 99精品久久精品| 亚洲综合精品香蕉久久网| 久久激情亚洲精品无码?V| 欧美日韩精品久久久久| 国产亚洲精久久久久久无码 | 2021国产成人精品久久| 国产成人精品久久亚洲| 国产福利电影一区二区三区,免费久久久久久久精 | 成人国内精品久久久久影院| 2021国产精品午夜久久| 狠狠色婷婷久久综合频道日韩| 国内精品人妻无码久久久影院导航| 久久激情五月丁香伊人| 中文无码久久精品| 一级A毛片免费观看久久精品| 亚洲国产天堂久久综合| 久久精品视频免费| 久久99国产精品一区二区| 久久亚洲综合色一区二区三区| 亚洲七七久久精品中文国产| 欧洲成人午夜精品无码区久久 | 嫩草影院久久国产精品| 国产99久久精品一区二区| 中文字幕久久久久人妻| 久久发布国产伦子伦精品 | 久久天天躁狠狠躁夜夜网站 |