x86-64 指令¶
x86-64 汇编指令类型主要包含三类:
在内存和寄存器之间转移数据:
从内存到寄存器称为加载(load),例如
%reg = Mem[address]
从寄存器到内存称为存储(store),例如
Mem[address] = %reg
对寄存器或内存上的数据进行算术或逻辑运算
控制:选择下一条需要执行的指令
无条件跳转
条件跳转
认识硬件:寄存器文件¶
内存模型是学习 C 语言的核心,寄存器则是理解汇编语言的核心。相比内存,寄存器能够提供更快的数据访问。
寄存器文件是 CPU 内部的硬件,数量和类型由指令集定义。x86-64 架构包含 16 个通用寄存器,可以存储 64 位的值。每个寄存器都有固定的名称和不同的用途,并以 %
开头。CPU 工作过程中包含大量的数据移动和计算,在此过程中,寄存器用作临时存放区域,通常用于存储函数的参数、返回值等。
下表列出了 16 个 64 位寄存器的名称和用途。由于历史原因,每个寄存器还有一些其他的别名,从左到右依次是 32 位、16 位、8 位等。
寄存器 |
常规用法 |
低 32 位 |
低 16 位 |
低 8 位 |
---|---|---|---|---|
%rax |
Return value, callee-owned |
%eax |
%ax |
%al |
%rdi |
1st argument, callee-owned |
%edi |
%di |
%dil |
%rsi |
2nd argument, callee-owned |
%esi |
%si |
%sil |
%rdx |
3rd argument, callee-owned |
%edx |
%dx |
%dl |
%rcx |
4th argument, callee-owned |
%ecx |
%cx |
%cl |
%r8 |
5th argument, callee-owned |
%r8d |
%r8w |
%r8b |
%r9 |
6th argument, callee-owned |
%r9d |
%r9w |
%r9b |
%r10 |
Scratch/temporary, callee-owned |
%r10d |
%r10w |
%r10b |
%r11 |
Scratch/temporary, callee-owned |
%r11d |
%r11w |
%r11b |
%rsp |
Stack pointer, caller-owned |
%esp |
%sp |
%spl |
%rbx |
Local variable, caller-owned |
%ebx |
%bx |
%bl |
%rbp |
Local variable, caller-owned |
%ebp |
%bp |
%bpl |
%r12 |
Local variable, caller-owned |
%r12d |
%r12w |
%r12b |
%r13 |
Local variable, caller-owned |
%r13d |
%r13w |
%r13b |
%r14 |
Local variable, caller-owned |
%r14d |
%r14w |
%r14b |
%r15 |
Local variable, caller-owned |
%r15d |
%r15w |
%r15b |