linux 汇编学习

第一个程序:

exit.s:

.section .data
.section .text
.global _start

_start:
    movl $1, %eax  //eax保存系统调用号
    movl $0, %ebx   //ebx保存返回状态,改变此数字,则返回echo $?的值
    int $0x80

 

汇编:

as exit.s -o exit.o

链接:

ld exit.o -o exit

解释:

as为汇编器,即汇编命令,将汇编程序汇编为机器码

ld为连接器

 

注释:

#

汇编语言以‘#’开始一行注释

.(.section .text中的小点):任何以点号开始的指令都不会直接翻译成机器语言,这些是针对汇编程序本身,最终由汇编器处理,因此被称为伪指令

 

X86上有如下几个通用寄存器:

%eax

%ebx

%ecx

%edx

%edi

%esi

x86上的专用寄存器:

%ebp

%esp

%eip

%eflags

 

eax ebx ecx edx以及他们与8086的AX BX CX DX的联系与区别

4个数据寄存器(EAX、EBX、ECX和EDX)
2个变址和指针寄存器(ESI和EDI)
2个指针寄存器(ESP和EBP)

4个数据寄存器(EAX、EBX、ECX和EDX):
32位CPU有4个32位的通用寄存器EAX、EBX、ECX和EDX。对低16位数据的存取,不会影响高16位的数据。这些低16位寄存器分别命名为:AX、BX、CX和DX,它和先前的CPU中的寄存器相一致。
4个16位寄存器又可分割成8个独立的8位寄存器(AX:AH-AL、BX:BH-BL、CX:CH-CL、DX:DH-DL),每个寄存器都有自己的名称,可独立存取。程序员可利用数据寄存器的这种“可分可合”的特性,灵活地处理字/字节的信息。

那么如何理解eax,ax,al(ah)之间的关系呢?
专业点可以这样解释:Eax是32位寄存器,ax是16位寄存器,al(ah)是八位寄存器。
那么eax存储的数据就是ax的两倍,ax是al(ah)的两倍。
Eax可以存储的数字是DWORD(双字)ax存储的是WORD(字)AL(AH)存储的是BYTE(字节),那么为什么又有AH和AL呢,我们可以这样理解,AX=AH+AL,AH存储的是AX的高8位数据,AL存储的是AX的低八位数据。H这里就是HIGH,L就是LOW.
假设eax是红色区域,那么eax现在就是64636261;
那么ax就是eax的低十六位,也就是6261;
Al是61;AH是62。

其他ebx,ecx,edx也有类似的bx,bl,bh等对应的寄存器,原理和上面相同

 

 

 

你可能感兴趣的:(汇编)