zoukankan      html  css  js  c++  java
  • x86汇编语言指令集

    一、数据传输指令
         1. 通用数据传送指令.
    MOV     (MOVe) 传送字或字节.
    MOVS    (MOVe String)     串传送指令
    MOVSX    先符号扩展,再传送.
    MOVZX    先零扩展,再传送.
    PUSH     把字压入堆栈.
    POP      把字弹出堆栈.
    PUSHA    把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈.
    POPA     把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈.
    PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈.
    POPAD    把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈.
    BSWAP    交换32位寄存器里字节的顺序
    XCHG    (eXCHanG)交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)
    CMPXCHG比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )
    XADD     先交换再累加.( 结果在第一个操作数里 )
    XLAT    (TRANSLATE) 字节查表转换.
    ── BX 指向一张 256 字节的表的起点, AL 为表的索引值 (0-255,即0-FFH); 返回 AL 为查表结果. ( [BX+AL]->AL )
          2. 输入输出端口传送指令.
    IN       I/O端口输入. ( 语法: IN 累加器, {端口号│DX} )
    OUT      I/O端口输出. ( 语法: OUT {端口号│DX},累加器 )
          输入输出端口由立即方式指定时, 其范围是 0-255; 由寄存器 DX 指定时,其范围是 0-65535.
          3. 目的地址传送指令.
    LEA     (Load Effective Address)装入有效地址.
        例: LEA DX,string ;把偏移地址存到DX.
    LDS     (Load DS with pointer)传送目标指针,把指针内容装入DS.
        例: LDS SI,string ;把段地址:偏移地址存到DS:SI.
    LES     (Load ES with pointer)传送目标指针,把指针内容装入ES.
        例: LES DI,string ;把段地址:偏移地址存到ES:DI.
    LFS 传送目标指针,把指针内容装入FS.
        例: LFS DI,string ;把段地址:偏移地址存到FS:DI.
    LGS 传送目标指针,把指针内容装入GS.
        例: LGS DI,string ;把段地址:偏移地址存到GS:DI.
    LSS 传送目标指针,把指针内容装入SS.
        例: LSS DI,string ;把段地址:偏移地址存到SS:DI.
          4. 标志传送指令.
    LAHF    (Load AH with Flags)标志寄存器传送,把标志装入AH.
    SAHF    (Store AH into Flgs)标志寄存器传送,把AH内容装入标志寄存器.
    PUSHF (PUSH the Flags)标志入栈.
    POPF    (POP the Flags)标志出栈.
    PUSHD    32位标志入栈.
    POPD     32位标志出栈.

    二、算术运算指令
    ───────────────────────────────────────
      ADD 加法.
    ADC    带进位加法.
    INC    加 1.
    AAA    加法的ASCII码调整.非压缩的BCD码加法十进制调整指令
    DAA    加法的十进制调整.压缩的BCD码加法十进制调整指令
    SUB    (SUBtract)减法.
    SBB    (SuVtrach with borrow)带借位减法.
    DEC    (DECrement)减 1.
    NEC    (NEGate)求反(以 0 减之).
    CMP    (CoMPare)比较.(两操作数作减法,仅修改标志位,不回送结果).
    AAS    减法的ASCII码调整.非压缩的BCD码加法十进制调整指令
    DAS    减法的十进制调整.压缩的BCD码减法十进制调整指令
    MUL    (unsinged MULtiple)无符号乘法.
    IMUL (sIgned MUL tiple)整数乘法.
        以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算),
    AAM    乘法的ASCII码调整.
    DIV    (unsigned DIVide)无符号除法.
    IDIV (sIgned DIVide)整数除法.
        以上两条,结果回送:商回送AL,余数回送AH, (字节运算);或 商回送AX,余数回送DX, (字运算).
    AAD    除法的ASCII码调整.
    CBW    (Count Byte to Word)字节转换为字. (把AL中字节的符号扩展到AH中去)
    CWD    (Count Word to Doble word)字转换为双字. (把AX中的字的符号扩展到DX中去)
    CWDE 字转换为双字. (把AX中的字符号扩展到EAX中去)
    CDQ    双字扩展. (把EAX中的字的符号扩展到EDX中去)

    三、逻辑运算指令
    ───────────────────────────────────────
      AND 与运算.
    or     或运算.
    XOR    异或运算.
    NOT    取反.
    TEST 测试.(两操作数作与运算,仅修改标志位,不回送结果).
    SHL    (SHift logical Letf)逻辑左移.
    SAL    算术左移.(=SHL)
    SHR    (SHift logical Right)逻辑右移.
    SAR    算术右移.(=SHR)
    ROL    (Rotate Left )循环左移.
    ROR    (Rotate Right)循环右移.
    RCL    (Rotate Left through Carry)通过进位的循环左移.
    RCR    (Rotate Right through Carry)通过进位的循环右移.
        以上八种移位指令,其移位次数可达255次.
        移位一次时, 可直接用操作码. 如 SHL AX,1.
        移位>1次时, 则由寄存器CL给出移位次数.
         如 MOV CL,04
            SHL AX,CL

    四、串指令
    ───────────────────────────────────────
    DS:SI    源串段寄存器 :源串变址.
    ES:DI    目标串段寄存器:目标串变址.
    CX       重复次数计数器.
    AL/AX    扫描值.
    D标志    0表示重复操作中SI和DI应自动增量; 1表示应自动减量.
    Z标志    用来控制扫描或比较操作的结束.
    MOVS     串传送.
    ( MOVSB 传送字符. MOVSW 传送字. MOVSD 传送双字. )
    CMPS     (CoMPare String)串比较.
    ( CMPSB 比较字符. CMPSW 比较字. )
    SCAS     (SCAn String)串扫描指令.
    把AL或AX的内容与目标串作比较,比较结果反映在标志位.
    LODS 装入串.
    把源串中的元素(字或字节)逐一装入AL或AX中.
    ( LODSB 传送字符. LODSW 传送字. LODSD 传送双字. )
    STOS     (STOre into String)保存串.
    是LODS的逆过程.
    REP (REPeat)当CX/ECX<>0时重复.
    REPE/REPZ (REPeat while Equal/Zero)当ZF=1或比较结果相等,且CX/ECX<>0时重复.
    REPNE/REPNZ (REPeat while Not Equal/Zero)当ZF=0或比较结果不相等,CX/ECX<>0时重复.
    REPC     当CF=1且CX/ECX<>0时重复.
    REPNC    当CF=0且CX/ECX<>0时重复.

    五、程序转移指令
    ───────────────────────────────────────
     1>无条件转移指令 (长转移)
    JMP    无条件转移指令
    CALL 过程调用
    RET/RETF过程返回.
        2>条件转移指令 (短转移,-128到+127的距离内)
    ( 当且仅当(SF XOR OF)=1时,OP1<OP2 )
    JA/JNBE 不小于或不等于时转移.
    JAE/JNB 大于或等于转移.
    JB/JNAE 小于转移.
    JBE/JNA 小于或等于转移.
    以上四条,测试无符号整数运算的结果(标志C和Z).
    JG/JNLE 大于转移.
    JGE/JNL 大于或等于转移.
    JL/JNGE 小于转移.
    JLE/JNG 小于或等于转移.
    以上四条,测试带符号整数运算的结果(标志S,O和Z).
    JE/JZ     等于转移.
    JNE/JNZ 不等于时转移.
    JC    有进位时转移.
    JNC 无进位时转移.
    JNO 不溢出时转移.
    JNP/JPO 奇偶性为奇数时转移.
    JNS 符号位为 "0" 时转移.
    JO    溢出转移.
    JP/JPE 奇偶性为偶数时转移.
    JS    符号位为 "1" 时转移.
        3>循环控制指令(短转移)
    LOOP CX不为零时循环.
    LOOPE/LOOPZ CX不为零且标志Z=1时循环.
    LOOPNE/LOOPNZ CX不为零且标志Z=0时循环.
    JCXZ CX为零时转移.
    JECXZ ECX为零时转移.
        4>中断指令
    INT    中断指令
    INTO 溢出中断
    IRET 中断返回
        5>处理器控制指令
    HLT    处理器暂停, 直到出现中断或复位信号才继续.
    WAIT 当芯片引线TEST为高电平时使CPU进入等待状态.
    ESC    转换到外处理器.
    LOCK 封锁总线.
    NOP    空操作.
    STC    置进位标志位.
    CLC    清进位标志位.
    CMC    进位标志取反.
    STD    (SeT Direction flag)置方向标志位.
    CLD    (CLear Direction flag)清方向标志位.
    STI    置中断允许位.
    CLI    清中断允许位.

    六、伪指令
    ───────────────────────────────────────
      DW 定义字(2字节).
    PROC    定义过程.
    ENDP    过程结束.
    SEGMENT 定义段.
    ASSUME 建立段寄存器寻址.
    ENDS 段结束.
    END    程序结束.

    8088 汇编跳转
    cmp a,b 比较a与b
    mov a,b 把b的值送给a
    ret 返回主程序
    nop 无作用,英文“no operation”的简写,意思是“do nothing”
    call 调用子程序
    je 或jz 若相等则跳
    jne或jnz 若不相等则跳
    jmp 无条件跳
    jb 若小于则跳
    ja 若大于则跳
    jg 若大于则跳
    jge 若大于等于则跳
    jl 若小于则跳
    jle 若小于等于则跳
    pop 出栈
    push 压栈

    MOV
    功能: 把源操作数送给目的操作数
    语法: MOV 目的操作数,源操作数
    格式: MOV r1,r2
    MOV r,m
    MOV m,r
    MOV r,data

    XCHG
    功能: 交换两个操作数的数据
    语法: XCHG
    格式: XCHG r1,r2 XCHG m,r XCHG r,m

    PUSH,POP
    功能: 把操作数压入或取出堆栈
    语法: PUSH 操作数 POP 操作数
    格式: PUSH r PUSH M PUSH data POP r POP m

    PUSHF,POPF,PUSHA,POPA
    功能: 堆栈指令群
    格式: PUSHF POPF PUSHA POPA

    LEA,LDS,LES
    功能: 取地址至寄存器
    语法: LEA r,m LDS r,m LES r,m

    XLAT(XLATB)
    功能: 查表指令
    语法: XLAT XLAT m


    算数运算指令

    ADD,ADC
    功能: 加法指令
    语法: ADD OP1,OP2 ADC OP1,OP2
    格式: ADD r1,r2 ADD r,m ADD m,r ADD r,data
    影响标志: C,P,A,Z,S,O

    SUB,SBB
    功能:减法指令
    语法: SUB OP1,OP2 SBB OP1,OP2
    格式: SUB r1,r2 SUB r,m SUB m,r SUB r,data SUB m,data
    影响标志: C,P,A,Z,S,O

    INC,DEC
    功能: 把OP的值加一或减一
    语法: INC OP DEC OP
    格式: INC r/m DEC r/m
    影响标志: P,A,Z,S,O

    NEG
    功能: 将OP的符号反相(取二进制补码)
    语法: NEG OP
    格式: NEG r/m
    影响标志: C,P,A,Z,S,O

    MUL,IMUL
    功能: 乘法指令
    语法: MUL OP IMUL OP
    格式: MUL r/m IMUL r/m
    影响标志: C,P,A,Z,S,O(仅IMUL会影响S标志)

    DIV,IDIV
    功能:除法指令
    语法: DIV OP IDIV OP
    格式: DIV r/m IDIV r/m

    CBW,CWD
    功能: 有符号数扩展指令
    语法: CBW CWD

    AAA,AAS,AAM,AAD
    功能: 非压BCD码运算调整指令
    语法: AAA AAS AAM AAD
    影响标志: A,C(AAA,AAS) S,Z,P(AAM,AAD)

    DAA,DAS
    功能: 压缩BCD码调整指令
    语法: DAA DAS
    影响标志: C,P,A,Z,S

    位运算指令集

    AND,OR,XOR,NOT,TEST
    功能: 执行BIT与BIT之间的逻辑运算
    语法: AND r/m,r/m/data OR r/m,r/m/data XOR r/m,r/m/data TEST r/m,r/m/data NOT r/m
    影响标志: C,O,P,Z,S(其中C与O两个标志会被设为0) NOT指令不影响任何标志位

    SHR,SHL,SAR,SAL
    功能: 移位指令
    语法: SHR r/m,data/CL SHL r/m,data/CL SAR r/m,data/CL SAL r/m,data/CL
    影响标志: C,P,Z,S,O

    ROR,ROL,RCR,RCL
    功能: 循环移位指令
    语法: ROR r/m,data/CL ROL r/m,data/CL RCR r/m,data/CL RCL r/m,data/CL
    影响标志: C,P,Z,S,O

    程序流程控制指令集

    CLC,STC,CMC
    功能: 设定进位标志
    语法: CLC STC CMC
    标志位: C

    CLD,STD
    功能: 设定方向标志
    语法: CLD STD
    标志位: D

    CLI,STI
    功能: 设定中断标志
    语法: CLI STI
    标志位: I

    CMP
    功能: 比较OP1与OP2的值
    语法: CMP r/m,r/m/data
    标志位: C,P,A,Z,O

    JMP
    功能: 跳往指定地址执行
    语法: JMP 地址

    JXX
    功能: 当特定条件成立则跳往指定地址执行
    语法: JXX 地址
    注:
       A: ABOVE,当C=0,Z=0时成立
       B: BELOW,当C=1时成立
       C: CARRY,当弁时成立 CXZ: CX寄存器的值为0(ZERO)时成立
       E: EQUAL,当Z=1时成立
       G: GREATER(大于),当Z=0且S=0时成立
       L: LESS(小于),当S不为零时成立
       N: NOT(相反条件),需和其它符号配合使用
       O: OVERFLOW,O=1时成立
       P: PARITY,P=1时成立
       PE: PARITY EVEN,P=1时成立
       PO: PARITY ODD,P=0时成立
       S: SIGN,S=1时成立
       Z: ZERO,Z=1时成立
    LOOP
    功能: 循环指令集
    语法: LOOP 地址

    LOOPE(Z)
    地址 LOOPNE(Z) 地址
    标志位: 无

    CALL,RET
    功能: 子程序调用,返回指令
    语法: CALL 地址 RET RET n
    标志位: 无

    INT,IRET
    功能: 中断调用及返回指令
    语法: INT n IRET
    标志位: 在执行INT时,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器

    字符串操作指令集

    MOVSB,MOVSW,MOVSD
    功能: 字符串传送指令
    语法: MOVSB MOVSW MOVSD
    标志位: 无

    CMPSB,CMPSW,CMPSD
    功能: 字符串比较指令
    语法: CMPSB CMPSW CMPSD
    标志位: C,P,Z,S,O

    SCASB,SCASW
    功能: 字符串搜索指令
    语法: SCASB SCASW
    标志位: C,P,Z,S,O

    LODSB,LODSW,STOSB,STOSW
    功能: 字符串载入或存贮指令
    语法: LODSB LODSW STOSB STOSW
    标志位: 无

    REP,REPE,REPNE
    功能: 重复前缀指令集
    语法: REP 指令S REPE 指令S REPNE 指令S
    标志位: 依指令S而定

  • 相关阅读:
    WCF进行大数据传输时的相关配置(转)
    自定义绑定(转)
    菜鸟学TSQLSQL2005读书笔记1
    再别康桥英文及译文
    自定义绑定2
    我要读的书
    菜鸟学TSQLSQL2005读书笔记
    Bad Habbits
    实践测试驱动开发
    针对接口写测试用例
  • 原文地址:https://www.cnblogs.com/loopever/p/2979512.html
Copyright © 2011-2022 走看看