原文链接:
一、汇编程序的Hello world
x86 AT&T:
.data
msg:
.ascii "Hello world, hello AT&T asm!\n"
len = . - msg
.text
.global _start
_start:
movl $len, %edx # 显示的字符数
movl $msg, %ecx # 缓冲区指针
movl $1, %ebx # 文件描述符
movl $4, %eax # 系统调用号,_write
int $0x80 # 系统调用
movl $0, %ebx # 传给_exit的参数
movl $1, %eax # 系统调用号,_exit
int $0x80 # 系统调用
然后汇编链接再执行:
这段汇编相当于:
#include <unistd.h>
char msg[14] = "Hello,world!\n";
#define len 14
int main(void)
{
write(1, msg, len);
_exit(0);
}
C代码中的write函数是系统调用的包装函数,其内部实现就是把传进来的三个参数分别赋给ebx、ecx、edx寄存器,然后执行movl $4,%eax和int $0x80两指令。这个函数不可能完全用C代码写,因为任何C代码都不会编译生成int指令,所以这个函数有可能完全用汇编写的,也有可能是C用内联汇编写的,甚至是一个宏定义。_exite函数野史如此。