实战汇编程序
1. X86 平台
X86汇编常见的寄存器 4(数据) 2(变址) 2(指针) 6(段) 1(指令指针) 1(标志)
x86-64 64位 x86 机器上调试的程序
1) %rax 作为函数返回值使用
2) %rsp 栈指针寄存器,指向栈顶
3) %rdi,%rsi,%rdx,%rcx,%r8,%r9 用作函数参数,依次对应第1参数,第2参数。。。
4) %rbx,%rbp,%r12,%r13,%14,%15 用作数据存储,遵循被调用者使用规则,简单说就是随便用,调用子函数之前要备份它,以防他被修改
5) %r10,%r11 用作数据存储,遵循调用者使用规则,简单说就是使用之前要先保存原值
汇编子程序的调用过程
0000000000400537 <DRT_GetFls11>: # 子函数入口
400537: 55 push %rbp # 保存旧的帧指针,相当于创建新的栈帧
400538: 48 89 e5 mov %rsp,%rbp # 让 %rbp 指向新栈帧的起始位置
40053b: 48 83 ec 20 sub $0x20,%rsp # 在新栈帧中预留一些空位,供子程序使用,用 (%rsp+K) 或 (%rbp-K) 的形式引用空位
40053f: 48 89 7d e8 mov %rdi,-0x18(%rbp)
400543: 89 75 e4 mov %esi,-0x1c(%rbp)[^1]
400546: c7 45 fc 00 00 00 00 movl $0x0,-0x4(%rbp) #
40054d: 83 45 fc 0b addl $0xb,-0x4(%rbp)
400551: 48 8b 45 e8 mov -0x18(%rbp),%rax
400555: 48 89 c7 mov %rax,%rdi
400558: e8 e3 fe ff ff call 400440 puts@plt
40055d: b8 00 00 00 00 mov $0x0,%eax
400562: c9 leave
400563: c3 ret