• <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
                完整的轉(zhuǎn)換方法需要intel提供免費翻印下載的那本手冊。手冊過于精簡,因此這里給出的例子用于輔助對手冊進行理解。假設(shè)讀者閱讀過intel提供的手冊,或其他相關(guān)資料。

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

                下面對指令A(yù)DD [EDX*8+EBX+256],EBX進行翻譯。x86的32位CPU所用的指令集結(jié)構(gòu)是:Prefix | OpCode | ModR/M | SIB | Displacement | Immediate。

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

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

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

                第三個字節(jié)是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的順序組合起來,得到第三個字節(jié)的值:11010011=D3H

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

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

                接下里看一看Prefix的意思。如果寫的指令是ADD [EDX*8+EBX+256],BX的話,BX是16位,因此32位指針指向的也是16位的兩個字節(jié),所以使用如下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的調(diào)試其中復(fù)制出來的結(jié)果:
             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腳本引擎:將匯編指令轉(zhuǎn)換為機器碼 2009-02-16 00:56 | erfg
            那有這方面的相關(guān)資料啊?
            把參考文獻也注明好嗎?  回復(fù)  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機器碼 2009-02-16 02:33 | 陳梓瀚(vczh)
            @erfg
            Intel的官方主頁上有手冊下載,還可以填一份表格然后讓他免費將印刷版寄給你。  回復(fù)  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機器碼 2009-02-16 17:15 | 夢在天涯
            高深啊!  回復(fù)  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機器碼 2009-02-16 19:17 | kals
            @陳梓瀚(vczh)
            好申請嗎?  回復(fù)  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機器碼 2009-02-16 21:48 | 陳梓瀚(vczh)
            @kals
            基本有求必應(yīng)  回復(fù)  更多評論
              
            国产欧美久久久精品影院| 韩国无遮挡三级久久| 人妻丰满?V无码久久不卡| 久久精品成人免费国产片小草| 欧美大战日韩91综合一区婷婷久久青草| 日韩亚洲国产综合久久久| 99久久无色码中文字幕人妻| 69久久夜色精品国产69| 久久国产高清一区二区三区| 久久天天躁狠狠躁夜夜avapp| 久久91综合国产91久久精品| 中文字幕精品无码久久久久久3D日动漫| 漂亮人妻被黑人久久精品| 国产精品成人久久久久三级午夜电影| 国产精品久久久久久久久软件| 久久天堂电影网| 精品久久久久中文字幕日本| 久久免费看黄a级毛片| 色综合久久综精品| 精品久久久久久国产潘金莲 | 久久国产一片免费观看| 一本色道久久HEZYO无码| 久久久噜噜噜久久中文字幕色伊伊| 久久久久亚洲av无码专区喷水| 性高湖久久久久久久久AAAAA| 国产福利电影一区二区三区,免费久久久久久久精 | 波多野结衣中文字幕久久| 奇米影视7777久久精品| 久久精品国产乱子伦| 亚洲国产成人精品女人久久久| 麻豆精品久久精品色综合| 日产精品久久久久久久性色| 色综合久久最新中文字幕| 7777精品伊人久久久大香线蕉| 久久免费大片| 欧美亚洲另类久久综合婷婷 | 国产成人AV综合久久| 国产999精品久久久久久| 狠狠久久综合| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久久久国产一级毛片高清版|