1. 最简单的汇编程序
.section .data
.section .text
.globl _start
_start:
movl $1, %eax
movl $4, %ebx
int $0x80
汇编器: as hello.s -o hello.o
链接器: ld hello.o -o hello
为什么用汇编器翻译成机器指令了还不行,还要有一个链接的步骤呢?链接主要有两个作用,一是修改目标文件中的信息,对地址做重定位,二是把多个目标文件合并成一个可执行文件。
分析:
(1) .section .data
.section指示把代码划分成若干个段(Section),程序被操作系统加载执行时,每个段被加载到不同的地址,操作系统对不同的页面设置不同的读、写、执行权限。.data段保存程序的数
据,是可读可写的,相当于C程序的全局变量。
(2) .section .text
.text段保存代码,是只读和可执行的,后面那些指令都属于.text段。
(3) .globl _start
.globl指示告诉汇编器,_start这个符号要被链接器用到,所以要在目标文件的符号表中标记它是一个全局符号。_start就像C程序的main函数一样特殊,是整个程序的入口,链接器在链接时会查找目标文件中的_start符号代表的地址,把它设置为整个程序的入口地址,所以每个汇编程序都要提供一个_start符号并且用.globl声明。如果一个符号没有用.globl声明,就表示这个符号不会被链接器用到。
(4) movl $1, %eax
指令要求CPU内部产生一个数字1并保存到eax寄存器中 ,在汇编程序中,立即数前面要加$,寄存器名前面要加% 。
(5) int $0x80
int指令称为软中断指令,可以用这条指令故意产生一个异常