[推荐] 汇编语言8086和8088指令集合

    技术2022-07-03  143

    详细描述: 8086指令 一、数据传输指令 二、算术运算指令 三、逻辑运算指令 四、串指令 五、程序转移指令 六、伪指令 8088指令 一、状态寄存器 二、 直接标志转移(8位寻址) 三、间接标志转移(8位寻址) 四、无条件转移指令 五、16位/32位寻址方式 六、浮点指令 一、数据传输指令它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据.1. 通用数据传送指令.MOV 传送字或字节.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 交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )XADD 先交换再累加.( 结果在第一个操作数里 )XLAT 字节查表转换.── 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 装入有效地址.例: LEA DX,string ;把偏移地址存到DX.LDS 传送目标指针,把指针内容装入DS.例: LDS SI,string ;把段地址:偏移地址存到DS:SI.LES 传送目标指针,把指针内容装入ES.例: LES DI,string ;把段地址:偏移地址存到ESI.LFS 传送目标指针,把指针内容装入FS.例: LFS DI,string ;把段地址:偏移地址存到FSI.LGS 传送目标指针,把指针内容装入GS.例: LGS DI,string ;把段地址:偏移地址存到GSI.LSS 传送目标指针,把指针内容装入SS.例: LSS DI,string ;把段地址:偏移地址存到SSI.4. 标志传送指令.LAHF 标志寄存器传送,把标志装入AH.SAHF 标志寄存器传送,把AH内容装入标志寄存器.PUSHF 标志入栈.POPF 标志出栈.PUSHD 32位标志入栈.POPD 32位标志出栈.二、算术运算指令ADD 加法.ADC 带进位加法.INC 加 1.AAA 加法的ASCII码调整.DAA 加法的十进制调整.SUB 减法.SBB 带借位减法.DEC 减 1.NEC 求反(以 0 减之).CMP 比较.(两操作数作减法,仅修改标志位,不回送结果).AAS 减法的ASCII码调整.DAS 减法的十进制调整.MUL 无符号乘法.IMUL 整数乘法.以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算),AAM 乘法的ASCII码调整.DIV 无符号除法.IDIV 整数除法.以上两条,结果回送:商回送AL,余数回送AH, (字节运算);或 商回送AX,余数回送DX, (字运算).AAD 除法的ASCII码调整.CBW 字节转换为字. (把AL中字节的符号扩展到AH中去)CWD 字转换为双字. (把AX中的字的符号扩展到DX中去)CWDE 字转换为双字. (把AX中的字符号扩展到EAX中去)CDQ 双字扩展. (把EAX中的字的符号扩展到EDX中去)三、逻辑运算指令AND 与运算.OR 或运算.XOR 异或运算.NOT 取反.TEST 测试.(两操作数作与运算,仅修改标志位,不回送结果).SHL 逻辑左移.SAL 算术左移.(=SHL)SHR 逻辑右移.SAR 算术右移.(=SHR)ROL 循环左移.ROR 循环右移.RCL 通过进位的循环左移.RCR 通过进位的循环右移.以上八种移位指令,其移位次数可达255次.移位一次时, 可直接用操作码. 如 SHL AX,1.移位>1次时, 则由寄存器CL给出移位次数.如 MOV CL,04SHL AX,CL四、串指令DS:SI 源串段寄存器 :源串变址.ESI 目标串段寄存器:目标串变址.CX 重复次数计数器.AL/AX 扫描值.D标志 0表示重复操作中SI和DI应自动增量; 1表示应自动减量.Z标志 用来控制扫描或比较操作的结束.MOVS 串传送.( MOVSB 传送字符. MOVSW 传送字. MOVSD 传送双字. )CMPS 串比较.( CMPSB 比较字符. CMPSW 比较字. )SCAS 串扫描.把AL或AX的内容与目标串作比较,比较结果反映在标志位.LODS 装入串.把源串中的元素(字或字节)逐一装入AL或AX中.( LODSB 传送字符. LODSW 传送字. LODSD 传送双字. )STOS 保存串.是LODS的逆过程.REP 当CX/ECX<>0时重复.REPE/REPZ 当ZF=1或比较结果相等,且CX/ECX<>0时重复.REPNE/REPNZ 当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时,OP1JA/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 置方向标志位.CLD 清方向标志位.STI 置中断允许位.CLI 清中断允许位.六、伪指令DW 定义字(2字节).PROC 定义过程.ENDP 过程结束.SEGMENT 定义段.ASSUME 建立段寄存器寻址.ENDS 段结束.END 程序结束.8088 汇编跳转一、状态寄存器PSW(Program Flag)程序状态字寄存器,是一个16位寄存器,由条件码标志(flag)和控制标志构成,如下所示:15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0        OF DF IF TF SF ZF   AF   PF   CF条件码:①OF(Overflow Flag)溢出标志。溢出时为1,否则置0。②SF(Sign Flag)符号标志。结果为负时置1,否则置0.③ZF(Zero Flag)零标志,运算结果为0时ZF位置1,否则置0.④CF(Carry Flag)进位标志,进位时置1,否则置0.⑤AF(Auxiliary carry Flag)辅助进位标志,记录运算时第3位(半个字节)产生的进位置。有进位时1,否则置0.⑥PF(Parity Flag)奇偶标志。结果操作数中1的个数为偶数时置1,否则置0.控制标志位:⑦DF(Direction Flag)方向标志,在串处理指令中控制信息的方向。⑧IF(Interrupt Flag)中断标志。⑨TF(Trap Flag)陷井标志。二、 直接标志转移(8位寻址)指令格式 机器码 测试条件 如...则转移    指令格式 机器码 测试条件 如...则转移JC 72 C=1 有进位 JNS 79 S=0 正号JNC 73 C=0 无进位 JO 70 O=1 有溢出JZ/JE 74 Z=1 零/等于 JNO 71 O=0 无溢出JNZ/JNE 75 Z=0 不为零/不等于 JP/JPE 7A P=1 奇偶位为偶JS 78 S=1 负号 JNP/IPO 7B P=0 奇偶位为奇三、间接标志转移(8位寻址)指令格式 机器码 测试格式 如...则转移JA/JNBE(比较无符号数) 77 C或Z=0 >  高于/不低于或等于JAE/JNB(比较无符号数) 73 C=0 >=  高于或等于/不低于JB/JNAE(比较无符号数) 72 C=1 <  低于/不高于或等于JBE/JNA(比较无符号数) 76 C或Z=1 <=  低于或等于/不高于JG/JNLE(比较带符号数) 7F (S异或O)或Z=0 >  大于/不小于或等于JGE/JNL(比较带符号数) 7D S异或O=0 >=  大于或等于/不小于JL/JNGE(比较带符号数) 7C S异或O=1 <  小于/不大于或等于JLE/JNG(比较带符号数) 7E (S异或O)或Z=1 <= 小于或等于/不大于四、无条件转移指令操作码 伪码指令 含义EB  cb JMP rel8 相对短跳转(8位),使rel8处的代码位下一条指令E9  cw JMP rel16 相对跳转(16位),使rel16处的代码位下一条指令FF  /4 JMP r/m16 绝对跳转(16位),下一指令地址在r/m16中给出FF  /4 JMP r/m32 绝对跳转(32位),下一指令地址在r/m32中给出EA  cb JMP ptr16:16 远距离绝对跳转, 下一指令地址在操作数中EA  cb JMP ptr16:32 远距离绝对跳转, 下一指令地址在操作数中FF  /5 JMP m16:16 远距离绝对跳转,下一指令地址在内存m16:16中FF  /5 JMP m16:32 远距离绝对跳转,下一指令地址在内存m16:32中五、16位/32位寻址方式操作码 伪码指令 跳转含义 跳转类型 跳转的条件(标志位)0F 87  cw/cd JA rel16/32 大于 near (CF=0 and ZF=0)0F 83  cw/cd JAE rel16/32 大于等于 near (CF=0)0F 82  cw/cd JB rel16/32 小于 near (CF=1)0F 86  cw/cd JBE rel16/32 小于等于 near (CF=1 or ZF=1)0F 82  cw/cd JC rel16/32 进位 near (CF=1)0F 84  cw/cd JE rel16/32 等于 near (ZF=1)0F 84  cw/cd JZ rel16/32 为0 near (ZF=1)0F 8F  cw/cd JG rel16/32 大于 near (ZF=0 and SF=OF)0F 8D  cw/cd JGE rel16/32 大于等于 near (SF=OF)0F 8C  cw/cd JL rel16/32 小于 near (SF<>OF)0F 8E  cw/cd JLE rel16/32 小于等于 near (ZF=1 or SF<>OF)0F 86  cw/cd JNA rel16/32 不大于 near (CF=1 or ZF=1)0F 82  cw/cd JNAE rel16/32 不大于等于 near (CF=1)0F 83  cw/cd JNB rel16/32 不小于 near (CF=0)0F 87  cw/cd JNBE rel16/32 不小于等于 near (CF=0 and ZF=0)0F 83  cw/cd JNC rel16/32 不进位 near (CF=0)0F 85  cw/cd JNE rel16/32 不等于 near (ZF=0)0F 8E  cw/cd JNG rel16/32 不大于 near (ZF=1 or SF<>OF)0F 8C  cw/cd JNGE rel16/32 不大于等于 near (SF<>OF)0F 8D  cw/cd JNL rel16/32 不小于 near (SF=OF)0F 8F  cw/cd JNLE rel16/32 不小于等于 near (ZF=0 and SF=OF)0F 81  cw/cd JNO rel16/32 未溢出 near (OF=0)0F 8B  cw/cd JNP rel16/32 不是偶数 near (PF=0)0F 89  cw/cd JNS rel16/32 非负数 near (SF=0)0F 85  cw/cd JNZ rel16/32 非零(不等于) near (ZF=0)0F 80  cw/cd JO rel16/32 溢出 near (OF=1)0F 8A  cw/cd JP rel16/32 偶数 near (PF=1)0F 8A  cw/cd JPE rel16/32 偶数 near (PF=1)0F 8B  cw/cd JPO rel16/32 奇数 near (PF=0)0F 88  cw/cd JS rel16/32 负数 near (SF=1)0F 84  cw/cd JZ rel16/32 为零(等于) near (ZF=1)注:一些指令操作数的含义说明:  rel8 表示 8 位相对地址  rel16 表示 16 位相对地址  rel16/32 表示 16或32 位相对地址  r/m16 表示16位寄存器  r/m32 表示32位寄存器六、浮点指令对下面的指令先做一些说明:st(i):代表浮点寄存器,所说的出栈、入栈操作都是对st(i)的影响src,dst,dest,op等都是指指令的操作数,src表示源操作数,dst/dest表示目的操作数mem8,mem16,mem32,mem64,mem80等表示是内存操作数,后面的数值表示该操作数的内存位数(8位为一字节)x <- y 表示将y的值放入x,例st(0) <- st(0) - st(1)表示将st(0)-st(1)的值放入浮点寄存器st(0)1. 数据传递和对常量的操作指令指令格式指令含义执行的操作FLD src装入实数到st(0)st(0) <- src (mem32/mem64/mem80)FILD src装入整数到st(0)st(0) <- src (mem16/mem32/mem64)FBLD src装入BCD数到st(0)st(0) <- src (mem80)FLDZ将0.0装入st(0)st(0) <- 0.0FLD1将1.0装入st(0)st(0) <- 1.0FLDPI将pi装入st(0)st(0) <- ?(ie, pi)FLDL2T将log2(10)装入st(0)st(0) <- log2(10)FLDL2E将log2(e)装入st(0)st(0) <- log2(e)FLDLG2将log10(2)装入st(0)st(0) <- log10(2)FLDLN2将loge(2)装入st(0)st(0) <- loge(2)FST dest保存实数st(0)到destdest <- st(0) (mem32/mem64)FSTP destdest <- st(0) (mem32/mem64/mem80);然后再执行一次出栈操作FIST dest将st(0)以整数保存到destdest <- st(0) (mem32/mem64)FISTP destdest <- st(0) (mem16/mem32/mem64);然后再执行一次出栈操作FBST dest将st(0)以BCD保存到destdest <- st(0) (mem80)FBSTP destdest<- st(0) (mem80);然后再执行一次出栈操作2.比较指令指令格式指令含义执行的操作FCOM实数比较将标志位设置为 st(0) - st(1) 的结果标志位FCOM op实数比较将标志位设置为 st(0) - op (mem32/mem64)的结果标志位FICOM op和整数比较将Flags值设置为st(0)-op 的结果op (mem16/mem32)FICOMP op和整数比较将st(0)和op比较 op(mem16/mem32)后;再执行一次出栈操作FTST零检测将st(0)和0.0比较FUCOM st(i)比较st(0) 和st(i) [486]FUCOMP st(i)比较st(0) 和st(i),并且执行一次出栈操作FUCOMPP st(i)比较st(0) 和st(i),并且执行两次出栈操作FXAMExamine: Eyeball st(0) (set condition codes)3.运算指令指令格式指令含义执行的操作加法FADD加实数st(0) <-st(0) + st(1)FADD srcst(0) <-st(0) + src (mem32/mem64)FADD st(i),stst(i) <- st(i) + st(0)FADDP st(i),stst(i) <- st(i) + st(0);然后执行一次出栈操作FIADD src加上一个整数st(0) <-st(0) + src (mem16/mem32)减法FSUB减去一个实数st(0) <- st(0) - st(1)FSUB srcst(0) <-st(0) - src (reg/mem)FSUB st(i),stst(i) <-st(i) - st(0)FSUBP st(i),stst(i) <-st(i) - st(0),然后执行一次出栈操作FSUBR st(i),st用一个实数来减st(0) <- st(i) - st(0)FSUBRP st(i),stst(0) <- st(i) - st(0),然后执行一次出栈操作FISUB src减去一个整数st(0) <- st(0) - src (mem16/mem32)FISUBR src用一个整数来减st(0) <- src - st(0) (mem16/mem32)乘法FMUL乘上一个实数st(0) <- st(0) * st(1)FMUL st(i)st(0) <- st(0) * st(i)FMUL st(i),stst(i) <- st(0) * st(i)FMULP st(i),stst(i) <- st(0) * st(i),然后执行一次出栈操作FIMUL src乘上一个整数st(0) <- st(0) * src (mem16/mem32)除法FDIV除以一个实数st(0) <-st(0) /st(1)FDIV st(i)st(0) <- st(0) /t(i)FDIV st(i),stst(i) <-st(0) /st(i)FDIVP st(i),stst(i) <-st(0) /st(i),然后执行一次出栈操作FIDIV src除以一个整数st(0) <- st(0) /src (mem16/mem32)FDIVR st(i),st用实数除st(0) <- st(i) /st(0)FDIVRP st(i),stFDIVRP st(i),stFIDIVR src用整数除st(0) <- src /st(0) (mem16/mem32)FSQRT平方根st(0) <- sqrt st(0)FSCALE2的st(0)次方st(0) <- 2 ^ st(0)FXTRACTExtract exponent:st(0) <-exponent of st(0); and gets pushedst(0) <-significand of st(0)FPREM取余数st(0) <-st(0) MOD st(1)FPREM1取余数(IEEE),同FPREM,但是使用IEEE标准[486]FRNDINT取整(四舍五入)st(0) <- INT( st(0) ); depends on RC flagFABS求绝对值st(0) <- ABS( st(0) ); removes signFCHS改变符号位(求负数)st(0) <-st(0)F2XM1计算(2 ^ x)-1st(0) <- (2 ^ st(0)) - 1FYL2X计算Y * log2(X)st(0)为Y;st(1)为X;将st(0)和st(1)变为st(0) * log2( st(1) )的值FCOS余弦函数Cosst(0) <- COS( st(0) )FPTAN正切函数tanst(0) <- TAN( st(0) )FPATAN反正切函数arctanst(0) <- ATAN( st(0) )FSIN正弦函数sinst(0) <- SIN( st(0) )FSINCOSsincos函数st(0) <-SIN( st(0) ),并且压入st(1)st(0) <- COS( st(0) )FYL2XP1计算Y * log2(X+1)st(0)为Y; st(1)为X; 将st(0)和st(1)变为st(0) * log2( st(1)+1 )的值处理器控制指令FINIT初始化FPUFSTSW AX保存状态字的值到AXAX<- MSWFSTSW dest保存状态字的值到destdest<-MSW (mem16)FLDCW src从src装入FPU的控制字FPU CW <-src (mem16)FSTCW dest将FPU的控制字保存到destdest<- FPU CWFCLEX清除异常FSTENV dest保存环境到内存地址dest处保存状态字、控制字、标志字和异常指针的值FLDENV src从内存地址src处装入保存的环境FSAVE dest保存FPU的状态到dest处 94字节FRSTOR src从src处装入由FSAVE保存的FPU状态FINCSTP增加FPU的栈指针值st(6) <-st(5); st(5) <-st(4),...,st(0) <-?FDECSTP减少FPU的栈指针值st(0) <-st(1); st(1) <-st(2),...,st(7) <-?FFREE st(i)标志寄存器st(i)未被使用FNOP空操作,等同CPU的nopst(0) <-st(0)WAIT/FWAIT同步FPU与CPU:停止CPU的运行,直到FPU完成当前操作码FXCH交换指令,交换st(0)和st(1)的值st(0) <-st(1)st(1) <- st(0)

    最新回复(0)