天天看点

swift中寄存器相关内容

(%rdi)地址所在的存储空间

movq -0x18(%rbp), %rax

leaq -0x18(%rbp), %rax

movq是将rbp-0x18根据这个内存地址找到对应的内存空间,将内存空间的数据取出来赋给rax,所以rax里面放的是内存空间对应的内存数据

leaq是 直接将rbp-0x18地址值赋值给rax,这个rax中放的是内存地址,((因为不支持movq %rbp-0x18, %rax这种操作))

movq $0x10(%rbp) %rip 做的是值传递

leaq专门做地址值传递的 将0x111a+rip的地址值传给rdi

leaq 0x111a(%rip), %rdi

callq 0x100000f20 (函数地址,跳到这个地址执行完后通过retq又跳回去)

jump 0x100000f20 (跳到这个地址后不回头)

寄存器

有16个常用的寄存器

rax; rbx; rcx; rdx;

rsi; rdi; rbp; rsp;

r8; r9; r10; r11; r12; r13; r14; r15

段寄存器(Segment Register)

CS(Code Segment):代码段寄存器;

DS(Data Segment):数据段寄存器;

SS(Stack Segment):堆栈段寄存器;

ES(Extra Segment):附加段寄存器

应该掌握的16个寄存器

rax,rbx,rcx,rdx,rbp,rsp,rsi,rdi

r8,r9,r10,r11,r12,r13,r14,r15

通用寄存器共有8个: AX,BX,CX,DX, BP,SP, SI,DI;

数据寄存器 ax,bx,cx,dx

ax累加器(Accumulator)

bx基地址寄存器(base register)

cx计数寄存器(count register)

dx数据寄存器(data register)

指针寄存器(Pointer Register):bp,sp

bp 基址指针寄存器(base register)

sp 堆栈指针寄存器(stack register)

变址寄存器(index register):si,di

si 源变址寄存器(source index)

di 目的变址寄存器(destination index)

寄存器具体用途

rax,rdx 常作为函数返回值使用

rdi,rsi,rdx,rcx,r8,r9常用于存放函数参数

rbx,rbp,r12,r13,r14,r15用于数据存储

rsp,rbp,用于栈操作,rsp(栈指针寄存器,指向栈顶)(rsp为基底,rbp为栈顶,中间部分一般为栈空间)

内存地址格式为: 0x4bdc(%rip),一般是全局变量,全局区(数据段)

内存地址格式为: -0x78(%rbp),一般是局部变量,栈空间

内存地址格式为: 0x10(%rax),一般是堆空间

rip(instruction pointer)指令指针:存储着CPU下一条要执行的指令地址,一旦CPU读取一条指令,rip会自动指向下一条指令(存储下一条指令的z地址)

CS:IP 两个寄存器指示了 CPU当前将要读取的指令的地址,其中CS为代码段寄存器,而IP为指令指针寄存器。

什么叫做指示了CPU当前将要读取的指令

你想让CPU执行哪行指令,你就让CS:IP指向保存有指令的那块内存即可。

任何时候,CS:IP指向的地址中的内容都是CPU当前执行的指令。

r开头:64bit,8字节

e开头:32bit,4字节

x/3xw 0x00007fff89adaa10

x/4xg 0x00007fff89adaa10

register read

General Purpose Registers:

rax = 0x00007fff89adaa10 libswiftCore.dylib

type metadata for Any + 8 rbx = 0x0000000000000000 rcx = 0x00007ffeefbff618 rdx = 0x00007ffeefbff528 rdi = 0x0000000000000001 rsi = 0x00007ffeefbff518 rbp = 0x00007ffeefbff4f0 rsp = 0x00007ffeefbff490 r8 = 0x0000000000000000 r9 = 0x0000000000000000 r10 = 0x0000000000000000 r11 = 0x0000000000000000 r12 = 0x0000000000000000 r13 = 0x0000000000000000 r14 = 0x0000000000000000 r15 = 0x0000000000000000 rip = 0x0000000100000e0e 1111

main + 30 at main.swift:10:7

rflags = 0x0000000000000212

cs = 0x000000000000002b

fs = 0x0000000000000000

gs = 0x0000000000000000