不同的CPU,寄存器的结构和个数是不同的。
ARM64有31个64位的寄存器,x0~x30,通常用来存放一般性的数据,被称为通用寄存器。
w0~w28是32位的寄存器,因为64位是兼容32位的,所以可以使用64位寄存器的低32位,w0就是x0的低32位。
通常CPU会将内存中的数据存储在寄存器中,然后对通用寄存器中的数据进行计算。
mov只是读取内存的值,但是不会对内存中的值进行修改。
汇编里面没有开辟空间、销毁空间,拿到内存地址,直接开干。
PC寄存器
- Xcode查看寄存器的方法
- Xcode查看汇编代码的方法
- 汇编代码的含义?、
- 查看汇编指令的地址
那我们现在知道了,程序的执行完全是由PC寄存器的指令来决定的,那么假如我们修改PC寄存器将要执行的命令,会怎么样呢?
真机因为是ARM64架构,叫PC寄存器,模拟器是x8686,叫rip
接下来我们来修改它
- 为指令指针寄存器,它指示了CPU当前要读取指令的地址
- 在内存或者磁盘上,指令和数据没有任何区别,都是二进制信息
- CPU在工作的时候把有的信息看做指令,有的信息看做数据,为同样的信息赋予了不同的意义
- 比如 1110 0000 0000 0011 0000 1000 1010 1010
- 可以当做数据 0xE003008AA
- 也可以当做指令 mov x0, x8
- CPU根据什么将内存中的信息看做指令?
- CPU将pc指向的内存单元的内容看做指令
- 如果内存中的某段内容曾被CPU执行过,那么它所在的内存单元必然被pc指向过
bl指令
bl指令 – 练习
现在有两段代码!假设程序先执行A,请写出指令执行顺序.最终寄存器x0的值是多少?
_A:
mov x0,#0xa0
mov x1,#0x00
add x1, x0, #0x14
mov x0,x1
bl _B
mov x0,#0x0
ret
_B:
add x0, x0, #0x10
ret