• <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>
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統(tǒng)計

            • 隨筆 - 21
            • 文章 - 0
            • 評論 - 2
            • 引用 - 0

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            AT&T指令集

            GAS中每個操作都是有一個字符的后綴,表明操作數(shù)的大小。

            C聲明

            GAS后綴

            大小(字節(jié))

            char

            b

            1

            short

            w

            2

            (unsigned) int / long / char*

            l

            4

            float

            s

            4

            double

            l

            8

            long double

            t

            10/12

            注意:GAL使用后綴“l”同時表示4字節(jié)整數(shù)和8字節(jié)雙精度浮點數(shù),這不會產(chǎn)生歧義因為浮點數(shù)使用的是完全不同的指令和寄存器。

             

             

            操作數(shù)格式:

            格式

            操作數(shù)值

            名稱

            樣例(GAS = C語言)

            $Imm

            Imm

            立即數(shù)尋址

            $1 = 1

            Ea

            R[Ea]

            寄存器尋址

            %eax = eax

            Imm

            M[Imm]

            絕對尋址

            0x104 = *0x104

            Ea

            M[R[Ea]]

            間接尋址

            %eax= *eax

            Imm(Ea)

            M[Imm+R[Ea]]

            (基址+偏移量)尋址

            4(%eax) = *(4+eax)

            Ea,Eb

            M[R[Ea]+R[Eb]]

            變址

            (%eax,%ebx) = *(eax+ebx)

            ImmEa,Eb

            M[Imm+R[Ea]+R[Eb]]

            尋址

            9(%eax,%ebx)= *(9+eax+ebx)

            (,Ea,s)

            M[R[Ea]*s]

            伸縮化變址尋址

            (,%eax,4)= *(eax*4)

            Imm(,Ea,s)

            M[Imm+R[Ea]*s]

            伸縮化變址尋址

            0xfc(,%eax,4)= *(0xfc+eax*4)

            (Ea,Eb,s)

            M(R[Ea]+R[Eb]*s)

            伸縮化變址尋址

            (%eax,%ebx,4) = *(eax+ebx*4)

            Imm(Ea,Eb,s)

            M(Imm+R[Ea]+R[Eb]*s)

            伸縮化變址尋址

            8(%eax,%ebx,4) = *(8+eax+ebx*4)

            注:M[xx]表示在存儲器中xx地址的值,R[xx]表示寄存器xx的值,這種表示方法將寄存器、內(nèi)存都看出一個大數(shù)組的形式。

             

             

            數(shù)據(jù)傳送指令:

            指令

            效果

            描述

            movl S,D

            D <-- S

            傳雙字

            movw S,D

            D <-- S

            傳字

            movb S,D

            D <-- S

            傳字節(jié)

            movsbl S,D

            D <-- 符號擴展S

            符號位填充(字節(jié)->雙字)

            movzbl S,D

            D <-- 零擴展S

            零填充(字節(jié)->雙字)

            pushl S

            R[%esp] <-- R[%esp] – 4;

            M[R[%esp]] <-- S

            壓棧

            popl D

            D <-- M[R[%esp]]

            R[%esp] <-- R[%esp] + 4;

            出棧

            注:均假設(shè)棧往低地址擴展。

             

             

            算數(shù)和邏輯操作地址:

            指令

            效果

            描述

            leal S,D

            D = &S

            movl地版,S地址入DD僅能是寄存器

            incl D

            D++

            1

            decl D

            D--

            1

            negl D

            D = -D

            取負

            notl D

            D = ~D

            取反

            addl S,D

            D = D + S

            subl S,D

            D = D – S

            imull S,D

            D = D*S

            xorl S,D

            D = D ^ S

            異或

            orl S,D

            D = D | S

            andl S,D

            D = D & S

            sall k,D

            D = D << k

            左移

            shll k,D

            D = D << k

            左移(sall)

            sarl k,D

            D = D >> k

            算數(shù)右移

            shrl k,D

            D = D >> k

            邏輯右移

             

             

            特殊算術(shù)操作:

            指令

            效果

            描述

            imull S

            R[%edx]:R[%eax] = S * R[%eax]

            無符號64位乘

            mull S

            R[%edx]:R[%eax] = S * R[%eax]

            有符號64位乘

            cltd S

            R[%edx]:R[%eax] = 符號位擴展R[%eax]

            轉(zhuǎn)換為4字節(jié)

            idivl S

            R[%edx] = R[%edx]:R[%eax] % S;

            R[%eax] = R[%edx]:R[%eax] / S;

            有符號除法,保存余數(shù)和商

            divl S

            R[%edx] = R[%edx]:R[%eax] % S;

            R[%eax] = R[%edx]:R[%eax] / S;

            無符號除法,保存余數(shù)和商

            注:64位數(shù)通常存儲為,高32位放在edx,低32位放在eax

             

             

            條件碼:

            條件碼寄存器描述了最近的算數(shù)或邏輯操作的屬性。

            CF:進位標(biāo)志,最高位產(chǎn)生了進位,可用于檢查無符號數(shù)溢出。

            OF:溢出標(biāo)志,二進制補碼溢出——正溢出或負溢出。

            ZF:零標(biāo)志,結(jié)果為0

            SF:符號標(biāo)志,操作結(jié)果為負。

             

             

            比較指令:

            指令

            基于

            描述

            cmpb S2,S1

            S1 – S2

            比較字節(jié),差關(guān)系

            testb S2,S1

            S1 & S2

            測試字節(jié),與關(guān)系

            cmpw S2,S1

            S1 – S2

            比較字,差關(guān)系

            testw S2,S1

            S1 & S2

            測試字,與關(guān)系

            cmpl S2,S1

            S1 – S2

            比較雙字,差關(guān)系

            testl S2,S1

            S1 & S2

            測試雙字,與關(guān)系

             

             

            訪問條件碼指令:

            指令

            同義名

            效果

            設(shè)置條件

            sete D

            setz

            D = ZF

            相等/

            setne D

            setnz

            D = ~ZF

            不等/非零

            sets D

             

            D = SF

            負數(shù)

            setns D

             

            D = ~SF

            非負數(shù)

            setg D

            setnle

            D = ~(SF ^OF) & ZF

            大于(有符號>

            setge D

            setnl

            D = ~(SF ^OF)

            小于等于(有符號>=)

            setl D

            setnge

            D = SF ^ OF

            小于(有符號<)

            setle D

            setng

            D = (SF ^ OF) | ZF

            小于等于(有符號<=)

            seta D

            setnbe

            D = ~CF & ~ZF

            超過(無符號>)

            setae D

            setnb

            D = ~CF

            超過或等于(無符號>=)

            setb D

            setnae

            D = CF

            低于(無符號<)

            setbe D

            setna

            D = CF | ZF

            低于或等于(無符號<=)

             

             

            跳轉(zhuǎn)指令:

            指令

            同義名

            跳轉(zhuǎn)條件

            描述

            jmp   Label

             

            1

            直接跳轉(zhuǎn)

            jmp   *Operand

             

            1

            間接跳轉(zhuǎn)

            je     Label

            jz

            ZF

            等于/

            jne    Label

            jnz

            ~ZF

            不等/非零

            js     Label

             

            SF

            負數(shù)

            jnz    Label

             

            ~SF

            非負數(shù)

            jg     Label

            jnle

            ~(SF^OF) & ~ZF

            大于(有符號>)

            jge    Label

            jnl

            ~(SF ^ OF)

            大于等于(有符號>=)

            jl     Label

            jnge

            SF ^ OF

            小于(有符號<

            jle     Label

            jng

            (SF ^ OF) | ZF

            小于等于(有符號<=)

            ja     Label

            jnbe

            ~CF & ~ZF

            超過(無符號>)

            jae    Label

            jnb

            ~CF

            超過或等于(無符號>=)

            jb     Label

            jnae

            CF

            低于(無符號<)

            jbe    Label

            jna

            CF | ZF

            低于或等于(無符號<=)

             

             

            轉(zhuǎn)移控制指令:(函數(shù)調(diào)用):

            指令

            描述

            call    Label

            過程調(diào)用,返回地址入棧,跳轉(zhuǎn)到調(diào)用過程起始處,返回地址是call后面那條指令的地址

            call    *Operand

            leave

            為返回準(zhǔn)備好棧,為ret準(zhǔn)備好棧,主要是彈出函數(shù)內(nèi)的棧使用及%ebp

             

             

            GCCC中潛入?yún)R編代碼:

            asm( code-string [:output-list [ : input-list [ :overwrite-list]]]);

            注意,后面的參數(shù)(如overwrite-list)如果為空則不要相應(yīng)的“:”,而如果前面參數(shù)(如output-list)為空則需要用“:”占位。

            如:

            asm ("..."

                :                    //output需要占位

                : "r" (src)       //后面的Overwrites不能寫,我測試的結(jié)果是寫了編譯不過

            };


            如:

            Int ok_umul(unsigned x,unsigned y,unsigned *dest)

            {

              int result;

            asm(“movl %2 , %%eax; mull %3; movl %%eax,%0;\

                       setae %dl; movzbl %%dl,%1”

                       :  “=r” (*dest)  ,  “=r” (result)         //output

                       :  “r” (x)  ,  “r” (y)                         //inputs

                       :  “%ebx”  , “%edx”                        //Overwrites

            );

             

            return result;

            }

            我們用%0--%n表示輸入的參數(shù),從前往后統(tǒng)一編號(如上例中*dest表示%0,reset是%1,x是%2,y是%3),”r”表示整數(shù)寄存器,”=”表示對其進行了賦值。%eax要寫成%%eax,這是c語言字符串的規(guī)則,別忘了code-string就是一個c語言的字符串。

            posted on 2009-12-08 15:48 ChinaPanda 閱讀(1875) 評論(1)  編輯 收藏 引用

            評論

            # re: AT&T指令集 2011-08-31 18:05 樓主

            不錯,樓主是有心人
              回復(fù)  更多評論    

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            国内精品九九久久精品| a级毛片无码兔费真人久久| 久久乐国产综合亚洲精品| 色播久久人人爽人人爽人人片aV| 中文成人久久久久影院免费观看| 亚洲香蕉网久久综合影视| 一本一道久久精品综合| 久久精品国产男包| 国产精品久久久久影院色| 伊人久久一区二区三区无码| 久久99精品久久久久久hb无码 | 亚洲国产二区三区久久| 欧美激情精品久久久久久久九九九| 99久久精品免费看国产一区二区三区 | 亚洲国产成人久久综合一区77 | 亚洲精品无码久久久久sm| 日韩欧美亚洲综合久久影院d3| 99久久香蕉国产线看观香| 久久精品国产99国产精偷| 怡红院日本一道日本久久| 国产精品久久久久免费a∨| 91久久精品国产免费直播| 一本久久知道综合久久| 思思久久好好热精品国产| 激情久久久久久久久久| 久久精品国产99国产电影网| 久久香综合精品久久伊人| 亚洲精品无码专区久久久| 麻豆久久久9性大片| 色婷婷噜噜久久国产精品12p| 精品无码人妻久久久久久 | 欧美一级久久久久久久大| 91精品国产综合久久四虎久久无码一级| 亚洲精品乱码久久久久久久久久久久| 久久亚洲视频| 2021国内久久精品| 77777亚洲午夜久久多人| 综合网日日天干夜夜久久| 色综合久久久久综合体桃花网| 人妻丰满AV无码久久不卡| 久久人人爽爽爽人久久久|