在X86程序集中访问和移动字节

时间:2015-12-17 11:08:23

标签: string assembly x86 att endianness

我在X86汇编中有几个关于内存和寄存器的问题:

  1. 我有一个字符串"abcdefgh",寄存器%eax包含一个指向字符串的指针。现在我使用movl (%eax), %edx将字符串的前四个字节抓取到%edx。它们如何存储在寄存器中?是d注册中的字符%dl,还是字符a

  2. 例如,使用movb %eax, %dl时,%eax个字节中的哪个字节确实会移动? %al中的那个或相反的那个?甚至可以这样做吗?或者我应该使用这样的指针 - movb (%eax), %dh - 来获取指针指向的第一个字节?

1 个答案:

答案 0 :(得分:5)

假设您正在使用不寻常的GAS'语法(source是第一个操作数,destination是第二个操作数)而不是Intel' s:

  

它们如何存储在寄存器中?是%dl中的字符d   注册,还是字符a?

由于您正在访问字符串,就好像它是32位数字一样,因此适用字节顺序。 x86是little-endian所以你得到最低地址的最低有效字节,所以DL将保持' a' (0x61),整个EDX将为0x64636261。

  

当使用movb%eax,例如%dl时,%eax' s字节中的哪个字节就可以了   实际上移动? %al或者相反的那个?它甚至可能吗?   这样做?

这会产生语法错误,因为操作数大小不同。你不能将32位移动到8位。

  

或者我应该使用这样的指针 - movb(%eax),%dh - 来获取   指针指向的第一个字节?

如果你想访问EAX指向的数据而不是EAX本身,那么是的,这应该有效。