求助!为什么X86以上的CPU指令集不提供给用户呢?比如X86-64,sSSE3等等。 cpu指令集的问题?

cpu\u6307\u4ee4\u96c6\u7684\u4f5c\u7528\u662f\u4ec0\u4e48\uff1f

CPU\u662f\u4e00\u5757\u8d85\u5927\u89c4\u6a21\u7684\u96c6\u6210\u7535\u8def\uff0c\u662f\u4e00\u53f0\u8ba1\u7b97\u673a\u7684\u8fd0\u7b97\u6838\u5fc3\uff08Core\uff09\u548c\u63a7\u5236\u6838\u5fc3\uff08 Control Unit\uff09\u3002

\u4f60\u8bf4\u7684x86\u548cx64\u6216\u8005ia64\u662fCPU\u67b6\u6784\uff0c\u4e5f\u5c31\u662f\u7f16\u8bd1\u7a0b\u5e8f\u7684\u6807\u51c6\uff0c\u800cMMX\u3001SSE\u8fd9\u4e9b\u662f\u6307\u4ee4\u96c6\u3002\u6307\u4ee4\u96c6\u5e76\u975e\u4f1a\u9650\u5236\u67d0\u4e9b\u7a0b\u5e8f\u7684\u8fd0\u884c\uff0c\u800c\u4f1a\u5f71\u54cd\u7a0b\u5e8f\u8fd0\u884c\u7684\u901f\u5ea6\u3002

\u901a\u4fd7\u7684\u8bf4\uff0c\u6307\u4ee4\u96c6\u662f\u4f18\u5316\u67d0\u4e9b\u7a0b\u5e8f\u4e2d\u7684\u53ef\u6267\u884c\u4ee3\u7801\u7684\u6267\u884c\u6548\u7387\uff0c\u5c31\u662f\u8bf4\uff0c\u67d0\u4e9b\u7a0b\u5e8f\u5728\u8fd0\u884c\u5728\u652f\u6301\u67d0\u4e2a\u6307\u4ee4\u96c6\u7684CPU\u4e0a\u4f1a\u6709\u5f88\u9ad8\u7684\u6027\u80fd\u3002\u6bd4\u5982\u8bf4\uff0cSSE\u6307\u4ee4\u96c6\u5c31\u662f\u4e3a\u4e86\u591a\u5a92\u4f53\u7a0b\u5e8f\u7684\u6027\u80fd\u800c\u8bbe\u8ba1\u7684\uff0c\u4f7f\u7528\u4e86SSE\u6307\u4ee4\u96c6\u7f16\u5199\u7684\u7a0b\u5e8f\uff0c\u5f53\u4ed6\u8fd0\u884c\u5728\u652f\u6301\u8fd9\u4e2a\u6307\u4ee4\u96c6\u7684CPU\u4e0a\u65f6\uff0c\u6027\u80fd\u4f1a\u6709\u6781\u5927\u63d0\u5347\uff0c\u800c\u8fd0\u884c\u5728\u4e0d\u652f\u6301SSE\u6307\u4ee4\u96c6\u7684CPU\u4e0a\uff0c\u867d\u7136CPU\u7684\u901f\u5ea6\u548c\u6307\u6807\u53ef\u80fd\u4e00\u81f4\uff0c\u4f46\u662f\u4f1a\u6709\u6781\u5927\u5730\u4e0b\u964d\u3002

\u6307\u4ee4\u96c6\u662f\u4e00\u79cd\u77e5\u8bc6\u4ea7\u6743\uff0c\u6240\u4ee5amd\u548cintel\u7684\u4e0d\u4e00\u6837\uff0c\u5982\u679cAMD\u60f3\u652f\u6301intel\u7684\u6307\u4ee4\u96c6\uff0c\u662f\u9700\u8981\u4e3aintel\u4ed8\u8d39\u7684\uff0c\u6240\u4ee5amd\u4f1a\u53e6\u5916\u5f00\u53d1\u4e00\u5957\u6307\u4ee4\u96c6\uff0c\u4ee5\u767d\u76ae\u4e66\u7684\u5f62\u5f0f\u53d1\u653e\u7ed9\u7a0b\u5e8f\u5458\uff0c\u8ba9\u7a0b\u5e8f\u5458\u7f16\u5236\u51fa\u9002\u5408amd cpu\u4f7f\u7528\u7684\u7a0b\u5e8f\u3002

\u5f80\u5f80\u4e00\u4e2a\u7a0b\u5e8f\u4e0d\u53ea\u53ef\u4ee5\u517c\u5bb9\u4e00\u5957\u6307\u4ee4\u96c6\uff0c\u5047\u5982\u7f16\u8bd1\u65f6\u9009\u62e9\u517c\u5bb9\u591a\u79cd\u6307\u4ee4\u96c6\uff0c\u7a0b\u5e8f\u7684\u4f53\u79ef\u4f1a\u5927\u4e00\u4e9b\uff0c\u4f46\u662f\u8fd9\u5e76\u4e0d\u4f1a\u9020\u6210\u592a\u5927\u7684\u95ee\u9898\u3002

\u800cX86\u662fCPU\u7684\u67b6\u6784\uff0c\u4e5f\u5c31\u662f\u5728\u53ea\u652f\u6301X86\u67b6\u6784\u7684\u8ba1\u7b97\u673a\u4e0a\uff0c\u4e3aX64\u7f16\u5199\u7684\u4efb\u4f55\u7a0b\u5e8f\u662f\u4e0d\u80fd\u8fd0\u884c\u7684\uff0c\u8fd9\u4e2a\u4e0d\u662f\u6307\u4ee4\u96c6\u3002

\u7efc\u4e0a\uff0c\u6307\u4ee4\u96c6\u5e76\u4e0d\u80fd\u9650\u5236\u7a0b\u5e8f\u662f\u5426\u80fd\u591f\u5728\u8be5\u8ba1\u7b97\u673a\u4e0a\u8fd0\u884c\uff0c\u800c\u662f\u5236\u7ea6\u4e86\u7a0b\u5e8f\u8fd0\u884c\u7684\u901f\u5ea6\u3002

学习汇编语言,最关键的就在于汇编指令集的掌握以及计算机工作方式的理解,以下是80X86汇编过程中经常用到的一些汇编指令。

由于百度字数限制不能发全

一、 数据传送指令:MOV、XCHG、LEA、LDS、LES、PUSH、POP、PUSHF、POPF、CBW、CWD、CWDE。

二、 算术指令:ADD、ADC、INC、SUB、SBB、DEC、CMP、MUL、DIV、DAA、DAS、AAA、AAS。

三、 逻辑指令:AND、OR、XOR、NOT、TEST、SHL、SAL、SHR、SAR、RCL、RCR、ROL、ROR。

四、 控制转移指令:JMP、Jcc、JCXZ、LOOP、LOOPZ、LOOPNZ、LOOPNE、CALL、RET、INT。

五、 串操作指令:MOVS、LODS、STOS、CMPS、SCAS。

六、 标志处理指令:CLC、STC、CLD、STD。

七、 32位CPU新增指令(后续补充并完善)

除上述的一些指令外,还有许多32位80X86CPU新增指令,这些指令有时会简化程序设计,不过由于我也是刚刚学习汇编,这些都是从书上看到的,所以很多还不是十分了解,我写这些的目的仅仅是想让自己能更好的去记住这些指令的作用和用法,同事也希望和我一样刚入门的朋友能够多了解一些,并没有其他目的,所有的示例也并没有经过实际的代码测试,所以希望各位朋友,不管你喜欢不喜欢,反对不反对,请文明发言,谢谢!

------------------------------------------------数据传送指令开始-------------------------------------------------------

1、 MOV(传送)

指令写法:MOV target,source

功能描述:将源操作数source的值复制到target中去,source值不变

注意事项:1)target不能是CS(代码段寄存器),我的理解是代码段不可写,只可读,所以相应这地方也不能对CS执行复制操作。2)target和source不能同时为内存数、段寄存器(CS\DS\ES\SS\FS\GS)3)不能将立即数传送给段寄存器4)target和source必须类型匹配,比如,要么都是字节,要么都是字或者都是双字等。4)由于立即数没有明确的类型,所以将立即数传送到target时,系统会自动将立即数零扩展到与target数的位数相同,再进行传送。有时,需要用BYTE PTR 、WORD PTR、 DWORD PTR明确指出立即数的位数

写法示例:MOV dl,01H;MOV eax,[bp]; eax =ss:[bp] 双字传送。

2、 XCHG(交换)

指令写法:XCHG object1,object2

功能描述:交换object1与object2的值

注意事项:1)不能直接交换两个内存数的值 2)类型必须匹配3)两个操作数任何一个都不能是段寄存器【看来段寄存器的写入的限制非常的严格,MOV指令也不能对段寄存器进行写入】,4)必须是通用寄存器(ax、bx、cx、dx、si、di)或内存数

写法示例:XCHG ax,[bx][si]; XCHG ax,bx;

3、 LEA(装入有效地址)

指令写法:LEZ reg16,mem

功能描述:将有效地址MEM的值装入到16位的通用寄存器中。

写法示例:假定bx=5678H,EAX=1,EDX=2

Lea si,2[bx] ;si=567AH

Lea di,2[eax][edx] ;di=5

注意,这里装入的是有效地址,并不是实际的内存中的数值,如果要想取内存中该地址对应的数值,还需要加上段地址才行,而段地址有可能保存在DS中,也有可能保存在SS或者CS中哦:>不知道我的理解可正确。。。。

4、 LDS\LES\LGS\LSS(注意,与LEA不同的是,这里是装入的值,而不是有效地址)

这几个指令,名称不同,作用差不多。

写法:LDS reg16,mem32

功能描述:reg16等于mem32的低字,而DS对应于mem32的高字(当为LES时,这里就是ES对应于mem32的高字)

用来给一个段寄存器和一个16位通用寄存器同时复制。

注意事项:第一个操作数必须是16位通用寄存器

在接着往下说之前,先熟悉下堆栈的概念。堆栈,位于内存的堆栈段中,是内存的一部分,具有“先进后出”的特点,堆栈只有一个入口,即当前栈顶,当堆栈为空时,栈顶和栈底指向同一内存地址,在WINDOWS中,可以把堆栈理解成一个倒着的啤酒瓶,上面的地址大,下面的地址小,当从瓶口往啤酒瓶塞啤酒时(进栈),栈顶就会往瓶口下移动,也就是往低地址方向移动,同理,出栈时,正好相反,把啤酒给倒出来,栈顶向高地址方向移动。这就是所谓的堆栈 ,哼哼,很Easy吧。

在汇编语言中,堆栈操作的最小单位是字,也就是说,只能以字或双字为单位,同时,SS:SP指向栈顶(SS为堆栈段寄存器,SP为堆栈指针,二者一相加,就构成了堆栈栈顶的内存地址)。

5、 PUSH(进栈)

写法:PUSH reg16(32)/seg/mem16(32)/imm

功能描述:将通用寄存器/段寄存器/内存数/立即数的值压入栈中,即:

SP=SP-2 SS:[SP]=16位数值(当将32位数值压入栈中时,SP=SP-4,SS:[SP]=32为数值)

6、 POP(出栈)

写法:POP reg16(32)/seg/mem16(32)【不能出栈到CS中】

功能描述:将堆栈口的16(32)位数据推出到通用寄存器/段寄存器/内存中,即:

寄存器/段寄存器/内存= SS:[SP] SP=SP+2(当将32位数值出栈时,SP=SP+4)(注意,不能出栈给立即数哦,常量不可变嘛)

7、 PUSHA、PUSHAD、POPA、POPAD

作用:将所有16/32位通用寄存器进栈/出栈

如:PUSHA ;将AX、CX、DX、BX、原SP、BP、SI、DI依次进栈。POPA出栈顺序正好相反,但要注意的是,弹出到SP的值被丢弃,SP通过增加16位来恢复(当然嘛,不然栈顶地址就被修改了,就会出息不对齐的情况,就有可能乱套了)

POPAD PUSHAD一样,只不过是32位的罢了。

8、 PUSHF、PUSHFD、POPF、POPFD

功能描述:标志寄存器FLAGS(EFLAGS)进栈或出栈

如:PUSHF ;FLAGS进栈 POPF; 栈顶字出栈到FLAGS

总结下,POP 和PUSH通常可以用来交换两个寄存器的值,也可以用来保护寄存器的值,如下:

交换ax与cx的值:push ax;push cx;pop ax; pop cx;

保护寄存器:push ax;push cx;….中间有很多执行的代码…pop cx;pop ax;

9、LAHF\SAHF(标志寄存器传送指令)

写法:lahf;

作用:AH=FLAGS的低8位

写法:sahf;

作用:FLAGS的低8位=AH

10、符号扩展和零扩展指令

CBW;AL符号扩展为AX

CWD;AX符号扩展为32位数DX:AX

CWDE;AX符号扩展为EAX;

CDQ:EAX符号扩展为64位数EDX:EAX

MOVSX(符号扩展指令的一般形式)

写法:MOVSX reg16\32,reg8\reg16\mem8\mem16

作用:用来将8位符号扩展到16位,或者16位符号扩展到32位

MOVZX(零扩展指令)

写法:MOVZX reg16\32,reg8\reg16\mem8\mem16

零扩展,就是高位补0进行扩展。通常用在将数据复制到一个不同的寄存器中,如AL零扩展为EBX。相同寄存器的零扩展,可以使用MOV 高位, 0来实现。

11、BSWAP(字节交换)

写法:bswap reg32

作用:将reg32的第0与第3个字节,第1与第2个字节进行交换。

示例:设EAX=12345678h

执行bswap eax;后,eax=78563412H

12、XLAT(换码)

写法:XLAT;

作用:AL=DS:[bx+AL]

将DS:BX所指内存中的由AL指定位移处的一个字节赋值给AL。(貌似这是一个方便偷懒的指令哦。。),原来它的主要用途是查表。注意可以给它提供操作数,用来指定使用哪个段地址,如:

XLAT ES:table;使用ES来作为段地址,table不起作用。

XLAT table ;使用table所在段对应的段寄存器作为段地址。
------------------------------------------------数据传送指令结束-------------------------------------------------------

----------------------------------算术指令开始-----------------------------------------------

13、ADD(加法)

写法:ADD reg/mem reg/mem/imm

作用:将后面的操作数加到前面的操作数中

注意:两个操作数必须类型匹配,并且不能同时是内存操作数

ADC (带进位加法)

写法:ADC reg/mem, reg/mem/imm ;

作用:dest=dest+src+cf

当CF=0时 ADD与ADC的作用是相同的。

示例:实现64位数EDX:EAX与ECX:EBX的加法:

Add EAX,EBX;

ADC EDX,ECX;

14、INC(自加一)

写法:INC reg/mem;

作用:dest=dest+1;

15、XADD(交换加)

写法:XADD reg/mem, reg

作用:先将两个数交换,然将二者之和送给第一个数

16、SUB(减法)

写法:SUB reg/mem, reg/mem/imm;

作用:dest=dest-src;

SBB(带借位减法)

写法:SBB reg/mem, reg/mem/imm

作用:dest=dest-src-cf;

注意:两个操作数必须类型匹配,且不能同时是内存数

17、DEC(自减1)

写法:DEC reg/mem;

作用:dest=dest-1;

18、CMP(比较)

写法:CMP reg/mem, reg/mem/imm

作用:dest-src

注意:这里并不将结果存入dest中,而仅仅是执行相减的运算,达到依据运算结果去影响EFLAG标志位的效果

19、NEG(求补)

写法:NEG reg/mem

作用:求补就是求相反数,即:dest=0-dest;

20、CMPXCHG(比较交换)

写法:CMPXCHG reg/mem, reg;

作用:AL/AX/EAX-oprd1,如果等于0,则oprd1=oprd2,否则,AL/AX/EAX=oprd1;

即:比较AL/AX/EAX与第一个操作数,如果相等,则置ZF=1,并复制第二个操作数给第一个操作数;否则,置ZF=0,并复制第一个操作数给AL/AX/EAX。

说明:CMPXCHG主要为实现原子操作提供支持

CMPXCHG8B(8字节比较交换指令)

写法:CMPXCHG8B MEM64;

功能:将EDX:EAX中的64位数与内存的64位数进行比较,如果相等,则置ZF=1,并存储ECX:EBX到mem64指定的内存地址;否则,置ZF=0,并设置EDX:EAX为mem64的8字节内容

21、MUL(无符号乘法)

写法:MUL reg/mem;

作用:当操作数为8位时,AX=AL*src;

当操作数为16位时,DX:AX=AX*src;

当操作数为32位时,EDX:EAX=EAX*src;

22、IMUL(带符号位乘法)

写法:IMUL reg/mem;(作用同上)

IMUL reg16,reg16/mem16,imm16;

IMUL reg32,reg32/mem32,imm32;

IMUL reg16,imm16/reg16/imm16;

IMUL reg32,reg32/mem32/imm32;

注意:没有两个操作数均为8位的多操作数乘法。

对于同一个二进制数,采用MUL和IMUL执行的结果可能不同,设AL=0FF,BL=1,分别执行下面的指令,会得到不同的结果:

Mul bl; AX=0FFH(255);

Imul bl; AX=0FFFFH(-1)(高一半为低一半的扩展)

23、DIV(无符号除法 )/IDIV(带符号数除法)

写法:DIV reg/mem;/IDIC reg/mem

作用:如果操作数是8位,AX%SRC,结果商在AL、余数在AH中;

如果操作数是16位,DX:AX%SRC,结果商在AX,余数在DX中;

如果操作数是32位,EDX:EAX%SRC,结果商在EAX,余数在EDX中;

注意:不能直接实现8位数除8位数、16位数除16位数、32除32,若需要这样,则必须先把除数符号扩展或零扩展到16、32、64位,然后用除法指令。

对于IDIV,余数和被除数符号相同,如:-5 IDIV 2 = 商 -2,余数:-1;

在下列情况下,会使CPU产生中断:一:除数为0 ;二:由于商太大,导致EAX\AX或AL不能容纳,从而产生了溢出。

-----------------BCD码调整指令(十进制调整指令)待补充------------------------------------------------

24、关于BCD码:BCD码就是一种十进制数的二进制编码表示,分为压缩BCD码和非压缩BCD码,压缩BCD码用4个二进制位表示一个十进制位,即用0000B~1001B表示十进制0~9,如0110 0100 0010 1001B表示6429

用8位二进制来表示一个十进制叫非压缩BCD码,其中,低四位与压缩BCD码相同,高四位无意义。

压缩BCD码调整指令包括DAA(加法的压缩BCD码调整)和DAS(减法的压缩BCD码调整)

写法:

DAA;

作用:调整AL中的和为压缩BCD码。

功能:使用DAA指令时,通常先执行ADD/ADC指令,将两个压缩BCD码相加,结果存放在AL中,然后使用该指令将AL调整为压缩BCD码格式。

DAA的调整算法:

IF(AL低4位>9 或 AF=1)

THEN

AL=AL+6;

AF=1;

ENDIF

IF( AL高4位>9或CF=1)

THEN

AL=AL+60H;

CF=1;

ENDIF

说明:CF反映压缩BCD码相加的进位。

DAS;

作用:调整AL中的差为压缩BCD码。

功能:使用DAS指令时,通常先执行SUB/SBB指令,将两个压缩BCD码相减,结果存放在AL中,然后使用该指令将AL调整为压缩BCD码格式。

DAS的调整算法:

IF(AL低4位>9 或 AF=1)

THEN

AL=AL-6;

AF=1;

ENDIF

IF( AL高4位>9或CF=1)

THEN

AL=AL-60H;

CF=1;

ENDIF

说明:CF反映压缩BCD码相减的借位。

特别注意,如果使用DAA或DAS指令,则参加加法或减法运算的操作数应该是压缩BCD码,如果将任意两个二进制数相加或相减,然后调整,则得不到正确的结果。

关键是调整的规则,其中AF标志位就是专门为BCD码调整设计的,当低四位有向高四位进位或借位时,值为1。而CF就是最高位有进位或者借位时,为1.

非压缩BCD码调整指令,包括AAA,AAS,AAM,AAD。

写法:AAA ;

作用:调整AL中的和为非压缩BCD码;调整后,AL高4位等于0,AH=AH+产生的CF

功能:使用AAA指令时,通常先执行ADD/ADC指令,以AL为目的操作数,将两个非压缩BCD码(与高位无关)相加,然后使用AAA将AL调整为非压缩BCD码格式,且高4位等于0,同时,将调整产生的进位加到AH中。

AAA调整算法:

IF(AL低4位>9 或者 AF=1)

THEN

AL=AL+6;

AH=AH+1;

AF=1;

CF=1;

ELSE

AF=0;CF=0;

ENDIF

AL=AL AND OFH;;AL高4位清0

写法:AAS ;

作用:调整AL中的差为非压缩BCD码;调整后,AL高4位等于0,AH=AH-产生的CF

功能:使用AAS指令时,通常先执行SUB/SBB指令,以AL为目的操作数,将两个非压缩BCD码(与高位无关)相减,然后使用AAS将AL调整为非压缩BCD码格式,且高4位等于0,同时,将调整产生的借位从AH中减去。

AAA调整算法:

IF(AL低4位>9 或者 AF=1)

THEN

AL=AL-6;

AH=AH-1;

AF=1;

CF=1;

ELSE

AF=0;CF=0;

ENDIF

AL=AL AND OFH;;AL高4位清0

写法:AAM;

作用:AH=AX DIV 10, AL=AX MOD 10;

功能:使用AAM时,通常先执行MUL/IMUL指令,将两个一字节非压缩BCD码(高四位必须为0)相乘,结果存入AX.然后使用AAM指令将AX(AH=0)调整为两字节压缩BUC码格式。

写法:AAD;

作用:AL=AH*10+AL,AH=0;

功能:使用AAD时,通常先执行该指令,将AX中的两字节非压缩BCD码(AH与AL的高4位必须为0)调整为相应的二进制表示,然后使用DIV/IDIV指令,除以一个一字节的非压缩BCD码(高四位必须为0),可得到非压缩BCD码的除法结果。

特别注意,参加非压缩BCD码乘法或除法的操作数高4位必须为0。

-----------------------------算术指令结束-----------------------------------------------------------------------------

-----------------------------------------位操作指令开始-----------------------------------------------------

25、AND\OR\XOR\NOT\TEST

写法:

AND reg/mem,reg/mem/imm;

OR reg/mem,reg/mem/imm;

XOR reg/mem,reg/mem/imm;

NOT reg/mem;

TEST reg/mem,reg/mem/imm;

作用:AND\TEST\OR\XOR,两个操作数必须类型匹配,而且不能同时是内存操作数。

XOR通常用来将寄存器清0,如 XOR AX,AX;

TEST与AND的关系类似于CMP与SUB。TEST的典型用法是检查某位是否为1,如:

TEST DX,109H;

若 DX的第0,3,8位至少有一位为1,则 ZF=0,否则ZF=1;

26、移位指令

SHL(逻辑左移)

写法:SHL REG\mem,1\CL ;

作用:将dest的各个二进制位向左移动1(CL)位,并将DEST的最高位移出到CF,最低位移入0。

SAL(算术左移)

写法:SAL REG\mem,1\CL ;

作用:将dest的各个二进制位向左移动1(CL)位,并将DEST的最高位移出到CF,最低位移入0(同SHL)。

SHR(逻辑右移)

写法:SHR REG\mem,1\CL ;

作用:将dest的各个二进制位向左移动1(CL)位,并将DEST的最低位移出到CF,最高位移入0。

SAR(算术右移)

写法:SAR REG\mem,1\CL ;

作用:将dest的各个二进制位向左移动1(CL)位,并将DEST的最低位移出到CF,最高位不变。

SHLD(双精度左移)

写法:SHLD REG16/REG32/MEM16/MEM32, REG16/REG32, IMM8/CL;(类型须匹配)

作用:将OPRD1的各二进制左移,并将oprd1的最高位移到CF,oprd2的最高位移到oprd1的最低位,但是,oprd2的值不变。

SHRD(双精度右移)

写法与作用与双精度左移类似。注意移动方向为右移。

以上位移指令对标志位的影响:

若移位后符号位发生了变化,则OF=1,否则OF=0;CF为最后移入位;按一般规则影响ZF与SF。然而,若移位次数为0,则不影响标志位;若移位次数大于1,则OF无定义。

27、循环移位指令

ROL(循环左移)

写法:ROL REG\MEM, 1\CL;或 ROL REG/MEM,IMM8;(类型可不匹配)

作用:将DEST的各二进制位向左移动,并将最高位移出到CF,并同时移入最低位。

ROR(循环右移)

写法:ROR REG\MEM, 1\CL;或 ROR REG/MEM,IMM8;(类型可不匹配)

作用:将DEST的各二进制位向右移动,并将最低位移出到CF,并同时移入最高位。

RCL(带进位循环左移)

写法:RCL REG\MEM, 1\CL;或 RCL REG/MEM,IMM8;(类型可不匹配)

作用:将DEST的各二进制位向左移动,并将最高位移出到CF,原CF移入最低位。

RCR(带进位循环右移)

写法:RCR REG\MEM, 1\CL;或 RCR REG/MEM,IMM8;(类型可不匹配)

作用:将DEST的各二进制位向右移动,并将最低位移出到CF,原CF移入最高位。

28、位测试指令

BT(位测试)

写法:BT REG16/MEM16,REG16/IMM8;或BT REG32/MEM32,REG32/IMM8;

作用:CF=DEST的第index位,dest不变。

BTS(位测试并置位)

写法:BTS REG16/MEM16,REG16/IMM8;或BTS REG32/MEM32,REG32/IMM8;

作用:CF=DEST的第index位,dest的第index位=1;

BTR(位测试并复位)

写法:BTR REG16/MEM16,REG16/IMM8;或BTR REG32/MEM32,REG32/IMM8;

作用:CF=DEST的第index位,dest的第index位=0;

BTC(位测试并复位)

写法:BTC REG16/MEM16,REG16/IMM8;或BTC REG32/MEM32,REG32/IMM8;

作用:CF=DEST的第index位,dest的第index位取反;

说明:若dest为寄存器,则以index除以16(dest为reg16)或32(dest为reg32)的余数作为测试位。当然,index最好不要超出操作数的位数。

若dest为内存操作数,则无论其类型为字或双字,测试位为相对于起始地址的位移,例如,设BX=50,X为字类型的变量,则执行指令BT X,BX;后,CF=X+6单元的第2位,因为50%8=6余2.

BTS、BTC、BTR指令可用于并发程序设计。

29、位扫描指令

BSF(前向位扫描)

写法:BSF reg16/reg32, reg16/reg32/mem16/mem32;(类型须匹配)

作用:dest=src中值为1的最低位编号(从低位向高位搜索)

BSR(后向位扫描)

写法:BSR reg16/reg32, reg16/reg32/mem16/mem32;(类型须匹配)

作用:dest=src中值为1的最高位编号(从高位向低位搜索)

说明:BSF和BSR搜索SRC操作数中首次出现1的位置,BSF从低位向高位搜索,BSR反之。若找到一个1,则置ZF=0,并存储位编号到DEST操作数中。若SRC=0,即没有1出现,则置ZF=1,且dest的值不确定。

比如,有如下二进制数0111 1111 1010 0100

执行bsf后,位编号为2,执行bsr后,位编号为14.

30、条件置位指令

通用写法:SETcc reg8/mem8

作用:若条件cc成立,则dest=1,否则,dest=0;

SETcc有很多种命令形式,这里的cc只是一个描述符,具体的参见下面的三个表,其中,E(Equal)表示相等,G(Greatet)表示带符号大于,L(Less)表示带符号小于,A(Above)表示无符号大于,B(Below)表示无符号小于。

表一:测试单个标志位的SETcc指令:
SETcc指令
描述
置1条件

SETC,SETB,SETNAE
有进位时置1
CF=1

SETNC,SETNB,SETAE
无进位时置1
CF=0

SETZ,SETE
为0(相等)时置1
ZF=1

SETNA,SETNE
非0(不等)时置1
ZF=0

SETS
为负时置1
SF=1

SETNS
为正时置1
SF=0

SET0
溢出时置1
OF=1

SETNO
不溢出时置1
OF=0

SETP,SETPE
‘1’的个数为偶数时置1
PF=1

SETNP,SETPO
‘1’的个数为奇数时置1
PF=0

表二:用于带符号数比较的SETcc指令,这些指令常用在CMP指令之后,以判断带符号数的大小:
SETcc指令
描述
置1条件

SETG,SETNLE
大于(不小于等于)时置1
SF=OF且ZF=0

SETGE,SETNL
大于等于(不小于)时置1
SF=OF

SETL,SETNGE
小于(不大于等于)时置1
SF≠OF

SETLE,SETNG
小于等于(不大于)时置1
SF≠OF或ZF=1

表三:用于无符号数比较的SETcc指令,常用在CMP指令之后,用来判断无符号数的大小:
SETcc指令
描述
置1条件

SETA,SETNBE
大于(不小于等于)时置1
CF=0且ZF=0

SETAE,SETNB,SETNC
大于等于(不小于)时置1
CF=0

SETB,SETNAE,SETC
小于(不大于等于)时置1
CF=1

SETBE,SETNA
小于等于(不大于)时置1
CF=1或ZF=1

-----------------------------------------位操作指令结束----------------------------------------------------

----------------------------------------------------

---------------------------控制转移指令开始--------------------------------------------------

31、JMP(无条件转移指令)

执行代码的跳转,分为两种,一:段内转移,即要跳过去的代码地址和当前地址在同一段,这时只要修改IP(专用寄存器--指令指针)即可;二:段间转移:即要跳过去的代码地址和当前代码地址不在同一段内,需要同时修改CS和IP的值。

写法:

1、JMP label;若label与该指令位于同一代码段内,IP=label的偏移地址,否则CS:IP=label的分段地址,简单的说,就是跳到label的地址去。

2、JMP reg16/mem16;段内转移,偏移地址=reg16/[mem16]

3、JMP mem32;段间间接转移,段地址CS=mem32高字,偏移地址IP=mem32低字。

说明:当操作数是内存操作数时,若内存操作数是双字类型,则产生段间转移,若内存操作数是字类型,则产生段内间接转移。当不能确定类型时,编译器将报错。

32、Jcc(条件转移指令)

写法:Jcc label;

作用:若条件成立,则IP=label的偏移地址,否则,CPU将忽略该条件转移,继续执行下一条指令。

条件转移有以下几种形式:

表一:测试单个标志位的Jcc指令:
Jcc指令
描述
转移条件

JC,JB,JNAE
有进位时转移
CF=1

JNC,JNB,JAE
无进位时转移
CF=0

JZ,JE
为零(相等)时转移
ZF=1

JNZ,JNE
非零(不等)时转移
ZF=0

JS
为负时转移
SF=1

JNS
为正时转移
SF=0

JO
溢出时转移
OF=1

JON
不溢出时转移
OF=0

JP,JPE
‘1’的个数为偶数时转移
PF=1

JNP,JPO
‘1’的个数为奇数时转移
PF=0

表二:用于带符号数比较的Jcc指令(常用在CMP指令之后,以判断带符号数的大小)
Jcc指令
描述
转移条件

JG,JNLE
大于(不小于等于)时转移
SF=OF且ZF=0

JGE,JNL
大于等于(不小于)时转移
SF=OF

JL,LNGE
小于(不大于等于)时转移
SF<>OF

JLE,LNG
小于等于(不大于)时转移
SF<>OF或ZF=1

表三:用于无符号数比较的Jcc指令(常用在CNO指令之后,以判断无符号数的大小)
Jcc指令
描述
转移条件

JA,JNBE
大于(不小于等于)时转移
CF=0且ZF=0

JAE,JNB,JNC
大于等于(不小于)时转移
CF=0

JB,LNAE,JC
小于(不大于等于)时转移
CF=1

JBE,LNA
小于等于(不大于)时转移
ZF=1或CF=1

33、JCXZ/JECXZ(Jump if CX/ECX is zero)

写法:JCXZ label;(若CX=0,则转移到label)

JECXZ label;(若ECX=0,则转移到label)

说明:label相对位移量必须在-126~127之间

34、循环指令

LOOP label;

作用:CX=CX-1;若CX<>0,则转移到label;

LOOPZ/LOOPE label;

作用:CX=CX-1;若CX<>0且 ZF=1,则转移到label;

LOOPNZ/LOOPNE label;

作用:CX=CX-1;若CX<>0且ZF=0,则转移到label;

说明:label相对位移量必须在-128~127之间

35、过程调用和返回指令

CALL(过程调用)

写法:CALL label;

SSE AVX这些是扩展指令集,传统的x86那些是基本指令集,用那个叫CPUID的软件自己测测看自己机器支持哪些指令集。这些哪里不给你用啦?你都可以用,Intel手册里都有写,只是研究这些的人比较少罢了,一般都是做特殊优化,比如视频解码,游戏这些采用。

  • 鐢佃剳涓轰粈涔鏈x86鍏煎鍜寈64鍏煎?杩欎袱绉嶆湁浠涔堜笉鍚?
    绛旓細x86 x86鏄竴涓猧ntel閫氱敤璁$畻鏈虹郴鍒楃殑鏍囧噯缂栧彿缂╁啓,涔熸爣璇嗕竴濂楅氱敤鐨勮绠楁満鎸囦护闆嗗悎,X涓庡鐞嗗櫒娌℃湁浠讳綍鍏崇郴锛屽畠鏄竴涓鎵鏈*86绯荤粺鐨勭畝鍗曠殑閫氶厤绗﹀畾涔夛紝渚嬪锛歩386, 586,濂旇吘(pentium)銆傜敱浜庢棭鏈焛ntel鐨凜PU缂栧彿閮芥槸濡8086,80286鏉ョ紪鍙,杩欐暣涓郴鍒楃殑CPU閮芥槸鎸囦护鍏煎鐨,鎵浠ラ兘鐢X86鏉ユ爣璇嗘墍浣跨敤鐨勬寚浠ら泦鍚...
  • Intel鐨勫帀瀹充笉鍦ㄤ簬鍏惰嚜韬湁澶氫箞鍘夊,鑰屾槸鍦ㄤ簬x86杞欢鐢熸佺殑鍘夊
    绛旓細涓庡叾鍦x86浣撶郴鎵撹浆杞,涓嶅涓庡浗浜cpu鏋舵瀯鍗忓悓寮鍙,鍏堣繘鍐涙斂搴滈摱琛岀瓑琛屼笟搴旂敤棰嗗煙,鍐嶆嫇灞曚竴甯︿竴璺彂灞曚腑鍥藉琛屼笟搴旂敤,寰呮椂鏈烘垚鐔熴侀氱敤鎬ф彁楂樹箣鍚,鎷撳睍鍥藉唴姘戠敤甯傚満銆佸浗闄呮皯鐢ㄥ競鍦,涓巌ntel x86浣撶郴骞堕┚榻愰┍,鎴栧亣浠ユ椂鏃ヨ秴瓒婁箣銆 鎵鏈浠ヤ笂鐨闀挎湡鍙戝睍,鏍规簮鍦ㄤ簬甯傚満闇姹傚拰甯傚満鍗犳湁鐜,鎴戜滑鑷繁鐨勫競鍦鸿妯″凡缁忓緢澶,濡傛灉Intel...
  • 涓轰粈涔32浣嶇郴缁熺殑鏈哄櫒鍙仛X86鑰屼笉鏄疿32? 鑰64浣嶇殑绯荤粺鍗村彨鍋歑64鑰屼笉...
    绛旓細X86鍙槸涓绉嶆灦鏋勭殑绉板懠锛屾棭鍏坕ntel鍑哄搧鐨凜PU鍦ㄦ皯鐢ㄨ寖鐣撮兘鏄疿86鏋舵瀯鐨勶紝鍥犱负閭f椂鍊欒繕娌℃湁64浣嶇殑CPU锛屾墍浠ユ妸32浣岰PU鍜岀郴缁熺О涓篨86锛屽悗鏉ュ嚭鐜颁簡64鐨凜PU锛屾墠鏈夌殑X86涓64浣嶏紝鍏跺疄X86鎸囩殑鏄灦鏋勫悕绉帮紝64浣嶆槸鎸囨妧鏈寚鏍囷紝姒傚康鏄笉涓鏍风殑锛屾墍浠ユ湁鏃跺欎笉璇32浣嶏紝鑰岃X86锛屼篃鏄範鎯殑鍘熷洜 ...
  • 64浣嶈绠楁満CPU鏋舵瀯,涓轰粈涔鍙玜md64,鑰屼笉鏄痠ntel64?
    绛旓細8. 鍦ㄤ互寰鐨勮惀閿涓紝Intel缁忓父灏咥MD鐨勪骇鍝佽涓鸿嚜瀹舵妧鏈殑浠垮埗鍝併傜劧鑰岋紝AMD鐜囧厛寮鍙戜簡姘戠敤64浣嶆妧鏈苟鍙栧緱浜嗘垚鍔燂紝杩欎娇寰桰ntel涓嶅緱涓嶅惛鏀禔MD鐨勬妧鏈紝浠庤屽湪x86澶勭悊鍣鎶鏈殑鐮斿彂棰嗗鍦颁綅涓婂彈鍒颁簡閲嶆尗銆傚湪EM64T鐨勮祫鏂欎腑锛孖ntel瀵规寚浠ら泦鐨勮捣婧愬彧瀛椾笉鎻愶紝鍚庢潵鐢氳嚦灏嗚繖椤规妧鏈寮忓懡鍚嶄负Intel 64銆9. AMD鍜孖ntel...
  • 涓轰粈涔坸86鍜宎rm鐨勬灦鏋勪笉鍚,浣嗘槸閮借兘瑁卨inux鍛,浠栦滑鐨勭紪璇戞椂濡備綍瀹炵幇鐨...
    绛旓細rm鏋舵瀯鍜x86鏋舵瀯鍖哄埆锛氫竴銆佹ц兘锛歑86缁撴瀯鐨勭數鑴戞棤璁哄浣曢兘姣擜RM缁撴瀯鐨勭郴缁熷湪鎬ц兘鏂归潰瑕佸揩寰楀銆佸己寰楀銆X86鐨凜PU闅忎究灏辨槸1G浠ヤ笂銆佸弻鏍搞佸洓鏍稿ぇ琛屽叾閬擄紝閫氬父浣跨敤45nm锛堢敋鑷虫洿楂樼骇锛夊埗绋嬬殑宸ヨ壓杩涜鐢熶骇锛涜孉RM鏂归潰锛欳PU閫氬父鏄嚑鐧惧厗锛屾渶杩戞墠鍑虹幇1G宸﹀彸鐨凜PU锛屽埗绋嬮氬父浣跨敤涓嶅埌65nm鍒剁▼鐨勫伐鑹猴紝鍙互璇村湪鎬ц兘...
  • 涓轰粈涔32浣嶇郴缁熸槸X86,涓嶆槸32鍛,鑰64浣嶅張鏄64鍛
    绛旓細X86鎸32浣cpu銆x86鎸囩殑鏄竴绉峜pu鐨勬灦鏋勫洜涓篿ntel鐨8086锛286锛386锝586鑰屽緱鍚峚md寮鍙戠殑澶ч儴鍒哻pu涔熸槸鍩轰簬x86鏋舵瀯鐨勩倄86鏋舵瀯鐨勭壒鐐规槸cpu鐨勫瘎瀛樺櫒鏄32浣嶇殑锛屽洜姝や篃鍙32浣峜pu銆X86鐨32浣嶄綋绯荤粨鏋勯氬父绉颁负IA锛32锛屽叏绉颁负鈥滆嫳鐗瑰皵浣撶郴缁撴瀯锛32浣嶁濄傚畠鐨64浣嶄綋绯荤粨鏋勬渶鏃╃敱AMD鎺ㄥ嚭锛岃绉颁负鈥淎MD64鈥濄
  • 涓轰粈涔堝彧瀛X86姹囩紪銆86浠ヤ笂鐨勪负浠涔涓嶅
    绛旓細cpu鏈甯歌鏄痠ntel鐨80X86绯诲垪:1978骞8086;1979骞8088;1982骞80286;浠ュ悗灏辨槸(80)386,(80)486,Pentium(586),PentiunPro(P6),PentiumII...杩欎簺CPU鐨勬牳蹇冮儴鍒嗛兘鏄樊涓嶅鐨,鑰屾眹缂栨槸閽堝CPU鐨,鎵浠ュX86杩欎釜绯诲垪灏辫浜
  • 鍥藉唴鍙堟湁X86澶勭悊鍣澶ф壒閲忎笂甯,鎬ц兘濡備綍杩樼敤Intel鑷冲己?
    绛旓細鍥藉唴X86澶勭悊鍣甯傚満鍐嶆坊鏂版槦锛氭緶璧风鎶娲ラCPU瀹炵幇澶ц妯′緵璐 鍦ㄥ浗闄呭埗瑁佽儗鏅笅锛屼腑鍥戒紒涓氬湪瀵绘眰鎽嗚劚瀵瑰鑺墖渚濊禆鐨勮繃绋嬩腑锛岄珮鎬ц兘澶勭悊鍣紝鐗瑰埆鏄疿86鏋舵瀯锛屾垚涓哄叧閿鍩熴傝繎鏃ワ紝婢滆捣绉戞妧瀹e竷鍏朵笌Intel鍜屾竻鍗庡ぇ瀛﹁仈鍚堢爺鍙戠殑娲ラ甔86 CPU宸插叿澶囨壒閲忕敓浜х殑鑳藉姏锛屾爣蹇楃潃涓浗鍦╔86棰嗗煙鐨勭爺鍙戝彇寰楅噸瑕佺獊鐮淬備笉鍚屼簬浠ュ線鐨...
  • intel cpu, 80x86, 杩欎釜鍚嶅瓧鏄庝箞鍙栫殑,涓轰粈涔鍙80,鍙堜负浠涔堝彨86鍛?
    绛旓細杩欎釜璧锋簮鍙互浠8085璇磋捣锛岃繖涓悕瀛楃殑瀛楅潰鎰忔濇槸锛80骞翠唬鐢熶骇鐨8浣5浼忕數鍘澶勭悊鍣銆傚悗鏉ワ紝瀵硅繖涓繘琛屽崌绾э紝灏辩畝鍗曠殑鍦ㄤ釜浣嶄笂鍔1锛屽彉鎴愪簡8086锛屼篃灏卞嚭鐜颁簡閭d釜闈炲父钁楀悕鐨x86榧荤锛屼簬鏄氨寤剁敤涓嬫潵浜嗐傚叾瀹烇紝鍚庢潵鐨32浣嶅拰64浣嶇郴缁燂紝鍏ㄥ悕鍙仛x86-32 鍜 x86-64銆備絾鏄紝涓轰簡鏂逛究鍖哄垎锛屽氨鍙樻垚浜唜86鍜寈64......
  • ibm鐨x86鏋舵瀯涓轰粈涔鍏锋湁鐢熷懡鍔
    绛旓細鍏煎鎬с佸叿鏈夌敓鎬佺郴缁熴1銆X86鏋舵瀯鐨凜PU涓庡競鍦轰笂澶ч噺鐨勮蒋浠跺拰搴旂敤鍏煎锛岃繖浣垮緱浼佷笟鍜屼釜浜哄彲浠ユ柟渚垮湴浣跨敤杩欎簺杞欢鍜屽簲鐢紝鏃犻渶鎷呭績鍏煎鎬ч棶棰樸2銆乆86鏋舵瀯鎷ユ湁搴炲ぇ鐨勭敓鎬佺郴缁燂紝鍖呮嫭鎿嶄綔绯荤粺銆佸伐鍏枫佸簲鐢ㄧ▼搴忕瓑銆傝繖浣垮緱浼佷笟鍜屼釜浜哄湪浣跨敤X86鏋舵瀯鐨凜PU鏃讹紝鍙互鑾峰緱涓板瘜鐨勮蒋浠跺拰宸ュ叿鏀寔锛屾彁楂樺伐浣滄晥鐜囥
  • 扩展阅读:国产兆芯系列cpu ... 为什么xr自拍是反着的 ... x86国产cpupeople ... 为什么ae只能看15秒 ... www.sony.com.cn ... 真的coach马车的标志 ... 86不存在的战区 ... 国内有哪些像ae86的车 ... ae86车图片 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网