|
- 一、数据传输指令
- 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 ;把段地址:偏移地址存到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 标志寄存器传送,把标志装入AH.
- SAHF 标志寄存器传送,把AH内容装入标志寄存器.
- PUSHF 标志入栈.
- POPF 标志出栈.
- PUSHD 32位标志入栈.
- POPD 32位标志出栈.
- 二、算术运算指令
- ───────────────────────────────────────
- ADD 加法.
- ADC 带进位加法.
- INC 加 1.
- AAA 加法的ASCII码调整.
- DAA 加法的十进制调整.
- SUB 减法.
- SBB 带借位减法.
- DEC 减 1.
- NEG 求反(以 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,04
- SHL AX,CL
- 四、串指令
- DS:SI 源串段寄存器 :源串变址.
- ES:DI 目标串段寄存器:目标串变址.
- 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时,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 置方向标志位.
- CLD 清方向标志位.
- STI 置中断允许位.
- CLI 清中断允许位.
- 六、伪指令
- DW 定义字(2字节).
- PROC 定义过程. 例子:name proc var1,var2,var3
- ENDP 过程结束.例子:name endp
- SEGMENT 定义段.例子 name segment
- ASSUME 建立段寄存器寻址. 例子:assume cs:codes,ds:datas,ss:stacks
- ENDS 段结束.name ends
- END 程序结束(同时指出指令入口,即程序执行的第一条指令).end start
- 七、处理机控制指令:
- 标志处理指令
- CLC(进位位置0指令)
- CMC(进位位求反指令)
- STC(进位位置为1指令)
- CLD(方向标志置1指令)
- STD(方向标志位置1指令)
- CLI(中断标志置0指令)
- STI(中断标志置1指令)
- NOP(无操作)
- HLT(停机)
- WAIT(等待)
- ESC(换码)
- LOCK(封锁)
- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 浮点协处理器
- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 浮点指令
- 对下面的指令先做一些说明:
- 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.0
- FLD1
- 将1.0装入st(0)
- st(0) <- 1.0
- FLDPI
- 将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)到dest
- dest <- st(0) (mem32/mem64)
- FSTP dest
- dest <- st(0) (mem32/mem64/mem80);然后再执行一次出栈操作
- FIST dest
- 将st(0)以整数保存到dest
- dest <- st(0) (mem32/mem64)
- FISTP dest
- dest <- st(0) (mem16/mem32/mem64);然后再执行一次出栈操作
- FBST dest
- 将st(0)以BCD保存到dest
- dest <- st(0) (mem80)
- FBSTP dest
- dest<- 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),并且执行两次出栈操作
- FXAM
- Examine: Eyeball st(0) (set condition codes)
- 3.运算指令
- 指令格式
- 指令含义
- 执行的操作
- 加法
- FADD
- 加实数
- st(0) <-st(0) + st(1)
- FADD src
- st(0) <-st(0) + src (mem32/mem64)
- FADD st(i),st
- st(i) <- st(i) + st(0)
- FADDP st(i),st
- st(i) <- st(i) + st(0);然后执行一次出栈操作
- FIADD src
- 加上一个整数
- st(0) <-st(0) + src (mem16/mem32)
- 减法
- FSUB
- 减去一个实数
- st(0) <- st(0) - st(1)
- FSUB src
- st(0) <-st(0) - src (reg/mem)
- FSUB st(i),st
- st(i) <-st(i) - st(0)
- FSUBP st(i),st
- st(i) <-st(i) - st(0),然后执行一次出栈操作
- FSUBR st(i),st
- 用一个实数来减
- st(0) <- st(i) - st(0)
- FSUBRP st(i),st
- st(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),st
- st(i) <- st(0) * st(i)
- FMULP st(i),st
- st(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),st
- st(i) <-st(0) /st(i)
- FDIVP st(i),st
- st(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),st
- FDIVRP st(i),st
- FIDIVR src
- 用整数除
- st(0) <- src /st(0) (mem16/mem32)
- FSQRT
- 平方根
- st(0) <- sqrt st(0)
- FSCALE
- 2的st(0)次方
- st(0) <- 2 ^ st(0)
- FXTRACT
- Extract exponent:
- st(0) <-exponent of st(0); and gets pushed
- st(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 flag
- FABS
- 求绝对值
- st(0) <- ABS( st(0) ); removes sign
- FCHS
- 改变符号位(求负数)
- st(0) <-st(0)
- F2XM1
- 计算(2 ^ x)-1
- st(0) <- (2 ^ st(0)) - 1
- FYL2X
- 计算Y * log2(X)
- st(0)为Y;st(1)为X;将st(0)和st(1)变为st(0) * log2( st(1) )的值
- FCOS
- 余弦函数Cos
- st(0) <- COS( st(0) )
- FPTAN
- 正切函数tan
- st(0) <- TAN( st(0) )
- FPATAN
- 反正切函数arctan
- st(0) <- ATAN( st(0) )
- FSIN
- 正弦函数sin
- st(0) <- SIN( st(0) )
- FSINCOS
- sincos函数
- 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
- 初始化FPU
- FSTSW AX
- 保存状态字的值到AX
- AX<- MSW
- FSTSW dest
- 保存状态字的值到dest
- dest<-MSW (mem16)
- FLDCW src
- 从src装入FPU的控制字
- FPU CW <-src (mem16
- FSTCW dest
- 将FPU的控制字保存到dest
- dest<- FPU CW
- FCLEX
- 清除异常
- 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的nop
- st(0) <-st(0)
- WAIT/FWAIT
- 同步FPU与CPU:停止CPU的运行,直到FPU完成当前操作码
- FXCH
- 交换指令,交换st(0)和st(1)的值
- st(0) <-st(1)
- st(1) <- st(0)
复制代码 |
|