如果一个cpu是64位的,我们可以使用AArch64指令集 也可以使用 AArch32指令集。
(1)如果想使用 aarch32指令集,也就是我们通常说的armv7的arm指令集,可以通过设置cpsr寄存器来达到目标。
首先解析armv7中的 cpsr寄存器:
从图中可得知,bit4控制我们使用什么指令集:
bit4 = 0b0 :表示 使用aarch64指令集。
bit4 = 0b1 :表示 使用aarch32指令集。
使用aarch32启动代码如下:
上诉代码中,cpsr 低5bit被修改为 0xd3,也就是二进制:0b 1101 0011.
bit4被设置成了1。也就是使用aarch32指令集。
(2)如果想要使用aarch64指令集启动,也就是armv8的 aarch64指令集,则如下操作:
介绍:
在aarch64中,不在使用cpsr寄存器。但它的类似功能被一组寄存器 替代。这个寄存器组 叫做 PSTATE.
PSTATE的部分寄存器如下:
(我们重点关注 current EL)
如果我们想要使用 aarch64指令集,则不用上来设置cpsr寄存器,而是使用上图中“”current EL“”。
汇编驱动代码如下:
鸣谢:http://www.lujun.org.cn/?p=1676