IA32体系结构4(x86常见指令概述)

2024-02-21 23:32

本文主要是介绍IA32体系结构4(x86常见指令概述),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

IA32(x86)体系结构指令种类比较多,但是常见的一般也还行,一下总结linux0.11内核中使用到的所有指令,概述这些指令的基本用法,因指令的使用跟寻址方式都有关系,篇幅所限,不详细展开所有细节,看内核代码,了解基本情况已经足够。

1.MOV(mov)

数据转移指令,从源操作数转移数据到目标操作数。

2.PUSH(push)

9086~80286中的push总是把两个字节的数据传送到堆栈,80386以上处理器可以传送两个或四个字节的数据,取决于寄存器或者存储单元的长度。

3.PUSHA(pusha)

讲所有通用寄存器内容压入堆栈,顺序为:AX、CX、DX、BX、SP、BP、SI、DI。

4.PUSHF(pushf)

将标志寄存器内容复制到堆栈。

5.POP(pop)

与PUSH想法,从堆栈弹出数据,放入指定的寄存器或者存储单元。

6.POPA(popa)

从堆栈弹出16字节数据按顺序放入以下寄存器:DI、SI、BP、SP、BX、DX、CX、AX。

7.POPF(popf)

从堆栈弹出数据到标志寄存器。

8.LEA(lea)

LEA指令把由操作数字段指定的数据的偏移地址装入16位或32位寄存器。比如:

LEA BX,[DI]

将DI指定的偏移地址(DI的内容)装入BX,不同于MOV BX,[DI],则是将由DI寻址的存储单元内的数据装入BX。

9.LDS,LES,LFS,LGS、LSS

把偏移地址装入任何16位或32位寄存器,并且把段地址装入DS、ES、FS、GS、SS。比如:

LDS EBX,[DI]

将数据段中由DI寻址的存储区的4个字节装入EBX,然后将这4个字节后面的字装入DS寄存器。

10.CLD(cld)

清除方向标志D(D=0),串操作期间寄存器DI和SI自增。

11.STD(std)

设置方向标志D(D=1),串操作期间寄存器DI和SI自减。

串操作指令执行期间,对存储器的访问是通过DI和SI两个寄存器或其中之一实现。DI偏移地址用于访问附加段ES中的数据,SI偏移地址用于访问数据段DS中的数据。

12.LODS(lods)

LODS指令将存储在数据段并用SI寄存器寻址的数据装入AL、AX或者EAX。装入AL、AX或者EAX之后,如果D=0,SI寄存器的内容增量,D=1,SI寄存器的内容减量。字节型增减1,字型增减2,双字型增减4。

LODSB(lodsb)-字节型

LODSW(lodsw)-字型

LODSD(lodsd)-双字型

13.STOS(stos)

STOS指令将AL、AX或EAX存储到附加段内由DI寄存器寻址的存储单元。

STOSB(stosb)-字节型

STOSW(stosw)-字型

STOSD(stosd)-双字型

REP重复前缀可以加到除了LODS之外的任何串数据传送指令上。执行重复的LODS操作没有任何意义。REP前缀使得每次执行串指令后CX减1。CX减1以后,重复执行串指令,直到CX值为0时,指令终止,继续执行指令序列的下一条。

14.MOVS(movs)

MOVS将数据从一个存储单元传送到另一个存储单元。这是8086~P4唯一允许的存储器到存储器的传送指令。MOVS指令从数据段DS内由SI寻址的存储单元把数据传送到附加段ES内由DI寻址的存储单元,然后根据方向标志的指示增量或减量。

MOVSB(movsb)-字节型

MOVSW(movsw)-字型

MOVSD(movsd)-双字型

15.XCHG(xchg)

交换指令将寄存器的内容与任何其他寄存器或存储单元的内容交换。该指令不能实现段寄存器之间的交换,或存储器与存储器之间的数据交换。比如:

XCHG EDX, ESI

EDX与ESI的内容交换。

16.IN(in)、OUT(out)

在I/O设备与微处理器之间只能传送AL、AX或者EAX的内容。IN指令将外部I/O设备的数据传送到AL、AX或EAX,而OUT指令把AL、AX或EAX的数据传送到外部I/O设备。

17.加法指令

(1)ADD(add)

ADD AL,BL

AL=AL+BL

(2)INC(inc)

使寄存器或者存储单元内容加1。

(3)ADC(adc)

带进位加法把进位标志(C)加到操作数中。

18.减法指令

(1)SUB(sub)

SUB CL, BL

CL=CL-BL

(2)DEC(dec)

减一指令。

(3)SBB(sbb)

带借位减法指令还要将存于进位标志(C)中的借位从差中减去。

19.CMP(cmp)

比较指令是只改变标志位的减法指令。比如:

CMP EBP,ESI

该指令执行EBP-ESI操作,影响标志位,结果不存放在寄存器中。

20.乘法指令

(1)IMUL(imul)

有符号乘法指令。

8位乘法指令被乘数放在AL中,积放在AX中。

16位乘法指令被乘数放在AX中,积存放在DX-AX中。DX包含积的最高有效16位,而AX总是包含最低有效16位。

32位乘法指令被乘数放在EAX中,积放在EDX-EAX中。

(2)MUL(mul)

无符号乘法指令。

8位乘法指令被乘数总是在AL中,乘数可以在任何寄存器或者任何存储单元中。比如:

MUL CL

AL内容乘以CL内容,无符号乘积留在AX中。

21.除法指令

(1)IDIV(有符号除法)

(2)DIV(无符号除法)

8位除法用AX寄存器存放被除数,可除以任何8位寄存器或存储单元的内容。除法完成后,商放在AL中,用AH保存全部的余数。比如:

DIV CL

AX内容除以CL内容,AL中存放得到的无符号的商,而余数在AH中。

16位除法指令DX-AX中的32位数是被除数,商在AX中,余数在DX中。

32位除法指令使EDX-EAX的64位内容除以指令指定的操作数,32位的商留在EAX中,32位的余数放在EDX中。

22.逻辑操作

(1)AND(and)

逻辑与操作。

(2)OR(or)

逻辑或操作。

(3)XOR(xor)

逻辑异或操作。

(4)TEST(test)

test指令执行AND操作,区别是AND指令改变目标操作数,而TEST指令不改变目标操作数。TEST只影响标志寄存器的状态,指示测试的结果。

(5)NOT(not)

逻辑取反操作(1的补或NOT)。比如:

NOT CH

对CH求1的补码。

(6)NEG(neg)

算术符号取反(2的补或NEG)。比如:

NEG CH

对CH求2的补码。

23.移位指令

(1)SHL(shl)

逻辑左移。

(2)SHR(shr)

逻辑右移。

(3)SAL(sal)

算术左移。

(4)SAR(sar)

算术右移。

(5)ROL(rol)

循环左移。

(6)ROR(ror)

循环右移。

(7)RCL(rcl)

通过进位位循环左移。

(8)RCR(rcr)

通过进位位循环右移。

24.位扫描指令

(1)BSF(bsf)

向前位扫描。从最低位向高位扫描数据,搜索首先遇到的值为1的位。

(2)BSR(bsr)

向后位扫描。从最高位向最低位扫描数据,搜索首先遇到的值为1的位。

无论哪条位扫描指令,如果遇到值为1的位,都将0标志位置1,并且把该位的位置放入目标操作数。如果没有遇到值为1的位,则零标志位被清0.比如:

BSF EBX,EAX

从最低位向左扫描数字,把EAX中首先遇到的1的位置放入EBX,并且将零标志置1。

25.串比较指令

(1)SCAS(scas)

串扫描指令可以比较AL、AX和EAX寄存器与存储区的内容,用AL、AX或EAX中的内容减去存储单元中的数,但既不改变寄存器的内容,也不改变存储单元的内容。

SCASB-字节比较

SCASW-字比较

SCASD-双字比较

所有的情况中,都是附加段中由DI寻址的存储单元的内容与AL、AX或EAX相比较。像其它串指令一样,使用方向标志D选择对DI是自动加1还是自动减1.比如:

MOV DI,OFFSET BLOCK
CLD
MOV CX,100
XOR AL,AL
REPNE SCASB

以上代码假设在BLOCK处开始的存储区域长为100字节,要求测试这个区域,查看是否哪个单元包含有00H。其中REPNE是不等于则重复前缀。REPNE前缀使得SCASB指令重复到或者CX寄存器达到0,或者按照SCASB指令比较的结果满足相等条件。

(2)CMPS(cmps)

比较两个存储区域的内容。比较是在数据段内由SI寻址的存储单元的内容和附加段内由DI寻址的存储单元的内容之间进行。CMPS使SI和DI都自动加1或者减1,它常常与REPE或者REPNE前缀配合使用。

以上是一些常见的指令,没有包含程序转移指令,程序转移指令会单独放在一篇里面说明。

这篇关于IA32体系结构4(x86常见指令概述)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/733444

相关文章

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

MySQL常见的存储引擎和区别说明

《MySQL常见的存储引擎和区别说明》MySQL支持多种存储引擎,如InnoDB、MyISAM、MEMORY、Archive、CSV和Blackhole,每种引擎有其特点和适用场景,选择存储引擎时需根... 目录mysql常见的存储引擎和区别说明1. InnoDB2. MyISAM3. MEMORY4. A

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1