ARM有几种工作模式?
用户、系统、快速中断、外部中断、超级用户、异常、未定义共七种模式
CPSR、SPSR寄存器分别是什么?
CPSR:程序状态寄存器(current program status register) (
当前程序状态寄存器
),在任何处理器模式下被访问。它包含了条件标志位、中断禁止位、当前处理器模式标志以及其他的一些控制和状态位。
CPSR在用户级编程时用于存储条件码。
SPSR:
(saved program status register),每一种处理器模式下都有一个状态寄存器SPSR,
程序状态保存寄存器
,以便异常返回后恢复异常发生时的工作状态。当特定的异常中断发生时,这个寄存器用于存放当前程序状态寄存器的内容。在异常中断退出时,可以用SPSR来恢复CPSR。由于用户模式和系统模式不是异常中断模式,所以他没有SPSR。当用户在用户模式或系统模式访问SPSR,将产生不可预知的后果
SPSR用于保存CPSR的状态
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种工作模式下寄存器列表?