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

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

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

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

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

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

                第三個(gè)字節(jié)是SIB,用來(lái)表達(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來(lái)表示,因此8=3)。將它們按照Scale Index Base的順序組合起來(lái),得到第三個(gè)字節(jié)的值:11010011=D3H

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

                于是這個(gè)指令的2進(jìn)制碼就是01 9C D3 00 01 00 00

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

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

                如何檢查上面的翻譯對(duì)不對(duì)呢?只需要打開(kāi)vc2008,將匯編代碼寫(xiě)在__asm{ }里面,然后下個(gè)斷點(diǎn),運(yùn)行之后用ctrl+alt+D,并在右鍵菜單打開(kāi)show code bytes選項(xiàng)即可。這里附上從vc2008的調(diào)試其中復(fù)制出來(lái)的結(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) 閱讀(3667) 評(píng)論(5)  編輯 收藏 引用 所屬分類: JIT

            評(píng)論:
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 00:56 | erfg
            那有這方面的相關(guān)資料啊?
            把參考文獻(xiàn)也注明好嗎?  回復(fù)  更多評(píng)論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 02:33 | 陳梓瀚(vczh)
            @erfg
            Intel的官方主頁(yè)上有手冊(cè)下載,還可以填一份表格然后讓他免費(fèi)將印刷版寄給你。  回復(fù)  更多評(píng)論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 17:15 | 夢(mèng)在天涯
            高深啊!  回復(fù)  更多評(píng)論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 19:17 | kals
            @陳梓瀚(vczh)
            好申請(qǐng)嗎?  回復(fù)  更多評(píng)論
              
            # re: JIT腳本引擎:將匯編指令轉(zhuǎn)換為機(jī)器碼 2009-02-16 21:48 | 陳梓瀚(vczh)
            @kals
            基本有求必應(yīng)  回復(fù)  更多評(píng)論
              
            国产亚洲精品美女久久久| 色综合久久无码五十路人妻| 国产激情久久久久久熟女老人 | 久久精品欧美日韩精品| 久久精品国产99久久久古代 | 91精品国产高清久久久久久国产嫩草| 人妻精品久久无码区| 成人久久免费网站| 久久亚洲日韩精品一区二区三区| 久久天天躁狠狠躁夜夜2020一| 久久这里有精品| 99久久精品国产一区二区 | 久久亚洲国产精品123区| 久久久久无码专区亚洲av| 久久人人爽人人精品视频| 欧美麻豆久久久久久中文| 香港aa三级久久三级老师2021国产三级精品三级在 | 97久久精品人人做人人爽| 激情综合色综合久久综合| 欧洲国产伦久久久久久久 | 久久99精品国产自在现线小黄鸭| 国产亚洲婷婷香蕉久久精品| 99久久免费国产精品| 天天做夜夜做久久做狠狠| 亚洲日本va中文字幕久久| 国内精品人妻无码久久久影院| 麻豆精品久久精品色综合| 午夜精品久久久久久久无码| 久久久亚洲欧洲日产国码二区| 久久这里只有精品久久| 久久最新免费视频| 国产精品久久久久久久| 四虎影视久久久免费| 久久91精品久久91综合| 久久亚洲AV无码精品色午夜| 久久精品国产久精国产| 无码任你躁久久久久久久| 久久免费精品视频| 亚洲va中文字幕无码久久 | 久久婷婷综合中文字幕| 免费精品久久天干天干|