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

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

                下面對指令A(yù)DD [EDX*8+EBX+256],EBX進(jìn)行翻譯。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進(jìn)行翻譯(見手冊)。
            1 01/r                ADD,r/m32,r32

                r/m32代表由寄存器表達(dá)式計算而成的指針數(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,用來表達(dá)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進(jìn)制碼就是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進(jìn)制碼就是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) 閱讀(3666) 評論(5)  編輯 收藏 引用 所屬分類: JIT

            評論:
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 00:56 | erfg
            那有這方面的相關(guān)資料啊?
            把參考文獻(xiàn)也注明好嗎?  回復(fù)  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 02:33 | 陳梓瀚(vczh)
            @erfg
            Intel的官方主頁上有手冊下載,還可以填一份表格然后讓他免費將印刷版寄給你。  回復(fù)  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 17:15 | 夢在天涯
            高深啊!  回復(fù)  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 19:17 | kals
            @陳梓瀚(vczh)
            好申請嗎?  回復(fù)  更多評論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 21:48 | 陳梓瀚(vczh)
            @kals
            基本有求必應(yīng)  回復(fù)  更多評論
              
            亚洲国产精品无码成人片久久| 国产精品99久久久久久猫咪 | 99久久精品国产一区二区三区 | 久久久久国产日韩精品网站| 久久精品国产亚洲AV香蕉| 亚洲精品久久久www| 久久亚洲2019中文字幕| a级毛片无码兔费真人久久| 国产美女久久久| 午夜不卡888久久| 久久精品www| 久久久国产精品| 欧美久久久久久午夜精品| 久久综合久久性久99毛片| 久久中文字幕无码专区| 久久久亚洲精品蜜桃臀| 日本精品一区二区久久久| 久久久受www免费人成| 久久久一本精品99久久精品88| 久久亚洲日韩看片无码| 久久精品国产亚洲av麻豆图片| 午夜久久久久久禁播电影| 狠狠色丁香久久婷婷综合五月| 国产精品一久久香蕉国产线看 | 久久综合九色综合97_久久久| 久久99国产精品久久99果冻传媒| 中文精品久久久久国产网址| 久久久久久噜噜精品免费直播| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 狠狠综合久久综合中文88| 欧美国产精品久久高清| 久久精品成人欧美大片| 97久久精品午夜一区二区| 国产激情久久久久影院| 色综合久久天天综线观看| 国产精品欧美久久久天天影视| 久久99精品国产99久久6男男| 国内精品久久久久伊人av| 精品人妻伦一二三区久久| 国产色综合久久无码有码| 日本三级久久网|