1.操作状态(operation state):
debug state:处理器在调试器发起halt或匹配到断点时,会进入debug state并停止执行指令.
thumb state:处理器正在运行程序代码(thumb 指令)时会处于thumb state。 和传统的ARM处理器不同,cortex m3
不支持ARM 指令集,所以没有ARM state.
2.操作模式(operation mode):
handler mode:指执行异常处理例程(如ISR)时的模式。在handler mode中,处理器一直处于特权访问层次(privileged level).
thread mode:指执行普通应用程序代码时的状态,处理器可以处于特权访问层次(privileged level)或非特权访问层次(unprivileged level)
3访问层次(access level):
在thread mode中,软件可以实现unprivileged到privileged的切换,但反向的切换必须通过中断(SVC)实现,这是因为access level由CONTROL寄存器控制,而只有在privileged level下才能访问这个寄存器。
由于cortex m3的指令均为16bit或32bit,对指令存储器寻址用的地址LSB应该都为0,但是对LR和PC,一些分支/调用/读存储器指令需要把它们的LSB设为1以表明是thumb state,否则会被认为尝试访问ARM指令而导致fault,vector table中的内容LSB均为1.但对C编程来讲,LR/PC的LSB都会由编译器自动决定,不会出现问题。