天天看点

ARM小知识点总结

ARM有几种工作模式?

用户、系统、快速中断、外部中断、超级用户、异常、未定义共七种模式

CPSR、SPSR寄存器分别是什么?

CPSR:程序状态寄存器(current program status register) (​

​当前程序状态寄存器​

​),在任何处理器模式下被访问。它包含了条件标志位、中断禁止位、当前处理器模式标志以及其他的一些控制和状态位。

CPSR在用户级编程时用于存储条件码。

SPSR:​

​程序状态保存寄存器​

​(saved program status register),每一种处理器模式下都有一个状态寄存器SPSR,​

​SPSR用于保存CPSR的状态​

​,以便异常返回后恢复异常发生时的工作状态。当特定的异常中断发生时,这个寄存器用于存放当前程序状态寄存器的内容。在异常中断退出时,可以用SPSR来恢复CPSR。由于用户模式和系统模式不是异常中断模式,所以他没有SPSR。当用户在用户模式或系统模式访问SPSR,将产生不可预知的后果

ARM中的R0~R15寄存器分别是什么?

R0-R3 用作传入函数参数,传出函数返回值。在子程序调用之间,可以将 r0-r3 用于任何用途。被调用函数在返回之前不必恢复 r0-r3。如果调用函数需要再次使用 r0-r3 的内容,则它必须保留这些内容。

.

R4-R11 被用来存放函数的局部变量。如果被调用函数使用了这些寄存器,它在返回之前必须恢复这些寄存器的值。

R12是内部调用暂时寄存器 ip。它在过程链接胶合代码中用于此角色。可以将它用于任何用途。被调用函数在返回之前不必恢复 r12。

在过程调用之间,可以将它用于任何用途。被调用函数在返回之前不必恢复 r12。

R13 是栈指针SP。它不能用于任何其它用途。sp 中存放的值在退出被调用函数时必须与进入时的值相同。

R14是链接寄存器 LR。如果您保存了返回地址,则可以在调用之间将 r14 用于其它用途,程序返回时要恢复

R15是程序计数器 PC。它不能用于任何其它用途。

指令执行被分为几个阶段?分别是什么?

三个阶段

1.取指(从存储器装载一条指令);

2.译码(识别将要被执行的指令);

3.执行(处理指令并将结果写回寄存器)

ARM7种工作模式下寄存器列表?

 ​

ARM小知识点总结

继续阅读