AT&T汇编——MOV指令
- MOV类指令
- MOVZ类指令
- MOVS类指令
MOV类指令
MOV类指令是最简单的数据传送指令,这类指令把数据从源位置复制到目的位置,不做任何变化。
MOV类指令由四条指令组成:movb、movw、movl和movq。
这些指令都执行同样的操作:主要区别在于它们操作的数据大小不同:分别是1、2、4和8字节。
指令 | 效果 | 描述 |
传送 | ||
传送字节 | ||
传送字 | ||
传送双字 | ||
传送四字 | ||
传送绝对四字 |
源操作数指定的值是一个立即数,存储在寄存器中或者内存中。
目的操作数指定一个位置,要么是一个寄存器或者,要么是一个内存地址。
x86-64加了一条限制,传送指令的两个操作数不能都指向内存位置。
将一个值从一个内存位置复制到另一个内存位置需要两条指令——第一条指令将源值加载到寄存器中,第二条将该寄存器值写入目的位置。
这些指令的寄存器操作数可以是x86-64CPU的16寄存器中有标号部分中的任意一个,寄存器部分的大小必须与指令最后一个字符(b、w、l或q)指定的大小匹配。
大多数情况下,MOV中指令只会更新目的操作数指定的那些寄存器字节或内存位置。唯一的例外是movl指令以寄存器作为目的时,它会把该寄存器的高4位字节设置为0。
造成这个例外的原因是x86-64采用的惯例,即任何为寄存器生成32为值的指令都会把该寄存器的高位部分置成0。
常规的movq指令只能以表示为32位补码数字的立即数作为源操作数,然后把这个值符号扩展得到64位的值,放到目的位置。movabsq指令能够以任意64位立即数值作为源操作数,并且只能以寄存器作为目的。
MOVZ类指令
MOVZ类数据移动指令,在将较小的源复制到较大的目的时使用。
这些指令把数据从源(在寄存器或内存中)复制到目的寄存器。
MOVZ类中的指令把目的中剩余的字节填充为0。
指令 | 效果 | 描述 |
以零字节扩展进行传送 | ||
将做了零扩展的字节传送到字 | ||
将做了零扩展的字节传送到双字 | ||
将做了零扩展的字传送到双字 | ||
将做了零扩展的字节传送到四字 | ||
将做了零扩展的字传送到四字 |
注意到,并没有一条明确的指令把4字节源值零扩展到8字节目的。
这样的指令逻辑上应该被命名为,但是并没有这样的指令。
不过,这样的数据传送指令可以用以寄存器为目的的来实现。
这一技术利用的属性是,生成4字节值并以寄存器作为目的的指令会把高4字节置为0.
MOVS类指令
MOVS类数据移动指令,在将较小的源复制到较大的目的时使用。
这些指令把源数据从源(在寄存器或内存中)复制到目的寄存器。
MOVS类中的指令通过符号扩展来填充,把源操作数的最高位进行复制。
指令 | 效果 | 描述 |
传送符号扩展的字节 | ||
将做了符号扩展的字节传送到字 | ||
将做了符号扩展的字节传送到双字 | ||
将做了符号扩展的字传送到双字 | ||
将做了符号扩展的字节传送到四字 | ||
将做了符号扩展的字传送到四字 | ||
将做了符号扩展的双字传送到四字 | ||
把%eax符号扩展到%rax |
cltq指令没有操作数:它总是以寄存器%eax作为源,%rax作为符号扩展结果的目的。它的效果与指令movslq %eax, %rax完全一致,不过编码更紧凑。