AT&T汇编——MOV指令

  • MOV类指令
  • MOVZ类指令
  • MOVS类指令


MOV类指令

MOV类指令是最简单的数据传送指令,这类指令把数据从源位置复制到目的位置,不做任何变化。
MOV类指令由四条指令组成:movb、movw、movl和movq。
这些指令都执行同样的操作:主要区别在于它们操作的数据大小不同:分别是1、2、4和8字节。

指令

效果

描述

汇编 movf_操作数

汇编 movf_操作数_02

传送

汇编 movf_数据_03

传送字节

汇编 movf_寄存器_04

传送字

汇编 movf_数据_05

传送双字

汇编 movf_数据_06

传送四字

汇编 movf_汇编 movf_07

汇编 movf_寄存器_08

传送绝对四字

源操作数指定的值是一个立即数,存储在寄存器中或者内存中。
目的操作数指定一个位置,要么是一个寄存器或者,要么是一个内存地址。
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字节目的。
这样的指令逻辑上应该被命名为汇编 movf_操作数_16,但是并没有这样的指令。
不过,这样的数据传送指令可以用以寄存器为目的的汇编 movf_AT&T汇编语言_17来实现。
这一技术利用的属性是,生成4字节值并以寄存器作为目的的指令会把高4字节置为0.

MOVS类指令

MOVS类数据移动指令,在将较小的源复制到较大的目的时使用。
这些指令把源数据从源(在寄存器或内存中)复制到目的寄存器。
MOVS类中的指令通过符号扩展来填充,把源操作数的最高位进行复制。

指令

效果

描述

传送符号扩展的字节

将做了符号扩展的字节传送到字

将做了符号扩展的字节传送到双字

将做了符号扩展的字传送到双字

将做了符号扩展的字节传送到四字

将做了符号扩展的字传送到四字

将做了符号扩展的双字传送到四字

把%eax符号扩展到%rax

cltq指令没有操作数:它总是以寄存器%eax作为源,%rax作为符号扩展结果的目的。它的效果与指令movslq %eax, %rax完全一致,不过编码更紧凑。