x86汇编程序基础

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指令称为软中断指令,可以用这条指令故意产生一个异常

  

你可能感兴趣的:(Reading,notes)