1. Arm的37个寄存器
看下面这张图:
可以看到User和System模式下的R0~R15和CPSR都是相同的寄存器,而在其它特权模式下用灰色三角形标注的那些寄存器,是该特权模式下特有的寄存器,比如在User模式下存入R8值0x50,切换到FIQ模式下存入R8值0x100,再切换回User模式下后,R8寄存器的值还是0x50。
这样算一下R0~R15在加上CPSR,然后在加上图中所有灰色三角标注的寄存器的个数正好是37个。
2. 异常处理
Arm在执行指令的过程中如果遇到异常,会跳转到异常向量表中对应的位置去处理,这里只是介绍异常向量表的作用,以及遇到异常后的执行流程。
异常向量表是约定好了的,但是异常向量表的内容是可以改变的,其定义如下:
上图对应了各种异常的情况下,程序跳转的地址。例如如果出现未定义的指令时,系统会切换到UND为定义模式,并跳转到0x00000004位置去执行,然而那个位置只有四字节可以执行,实际上那个位置只是一条跳转指令,会跳转到真

本文详细介绍了Arm架构中37个寄存器的用途和功能,包括通用寄存器、链接寄存器、程序状态寄存器等。同时,探讨了Arm的异常处理机制,涵盖中断和异常的基本概念、处理流程以及寄存器在异常处理中的角色。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



