我一直是高级编码员,架构对我来说很新,所以我决定在这里阅读关于组装的教程:
http://en.wikibooks.org/wiki/X86_Assembly/Print_Version
在教程的最后,关于如何转换 Hello World 的说明!程序
#include <stdio.h>
int main(void) {
printf("Hello, world!\n");
return 0;
}
给出了等效的汇编代码,并生成了以下内容:
.text
LC0:
.ascii "Hello, world!\12\0"
.globl _main
_main:
pushl %ebp
movl %esp, %ebp
subl $8, %esp
andl $-16, %esp
movl $0, %eax
movl %eax, -4(%ebp)
movl -4(%ebp), %eax
call __alloca
call ___main
movl $LC0, (%esp)
call _printf
movl $0, %eax
leave
ret
对于其中一条线,
andl $-16, %esp
解释是:
此代码“和”s ESP 与 0xFFFFFFF0,将堆栈与下一个最低 16 字节边界对齐。对 Mingw 源代码的检查表明,这可能是针对出现在“_main”例程中的 SIMD 指令,它只对对齐的地址进行操作。由于我们的例程不包含 SIMD 指令,因此这一行是不必要的。
我不明白这一点。有人可以解释一下将堆栈与下一个 16 字节边界对齐的含义以及为什么需要它吗?以及如何andl
实现这一目标?