- dfsr: data fault status register
- 发生异常时,该寄存器能够表示引起异常的原因,如非对齐访问、mmu translation fault 等等
- 读取 dfsr 到 r[x] 寄存器 :mrc p15,0,r[x],c5,c0,0
- dfar: data fault address register
- 保存了引起 data abort 异常的地址(VA 虚拟地址)
- 读取 dfar 到 r[x] 寄存器:mrc p15,0,r[x],c6,c0,0
- cpsr: Current Program Status Register
- 用于保存 保存处理器状态和控制信息
- 在特权模式下 (除了 user 模式),可以通过使用 cps 指令修改 cpsr 寄存器的 M[4:0],让处理器处于不同的模式
- 读取 cpsr到 r[x] 寄存器中:mrs r[x], cpsr
- spsr: Saved Program Status Registers
- 发生异常时,cpsr 会被复制到 spsr,然后 cpsr 寄存器的中相关字段更新为异常模式
- 可通过该寄存器得知异常前的工作模式
- 读取 spsr 到 r[x] 寄存器中:mrs r[x], spsr
- pc
- 对于 cortex-a,同步异常与异步异常均不会自动保存任何寄存器到 异常前上下文的栈中
- 此时 lr 会被设置为 pc + 8
- 异常的那条 pc = lr - 8 (此时的 lr 为异常模式的 lr)
- 根据 pc 可以定位到具体执行了那条指令产生了异常
- lr
- 异常时,处理器会自动切换状态
- 此时 lr 的值也会随着切换到异常模式下的 lr
- 如果想要恢复异常前的 lr,则需要根据 spsr 得知异常前的工作模式,然后强行切换到那个模式,把 lr 恢复回来
- 切换模式使用 cps 指令操作 cpsr 寄存器
- sp
- 与 lr 同理,切模式将异常上下文的 sp 恢复回来
- 得知 sp 的值,可以进行栈回溯,获取调用栈
armv7-a 异常排查
EINT2024-10-12 10:57
相关推荐
黑猫学长呀2 小时前
【嵌入式系统科普】第2篇:什么是uboot/kernel/根文件系统/BootLoader/操作系统/bios/设备树HunterMichaelG3 天前
【MySQL】KylinV10 ARM 服务器上编译MySQL 5.7 XtraBackup千桐科技6 天前
qData 数据中台开源版 v1.1.0 发布:清洗与稽查规则能力增强,支持 ARM 与 x86 双架构Coding Peasant6 天前
GD32E230 I2C从机功能深度解析与实现指南大聪明-PLUS6 天前
优雅的操作系统开发:用现代 C++ 编写操作系统内核(不使用宏)。第一部分——HAL 为王。才鲸嵌入式7 天前
香山CPU(国产开源)的 SoC SDK底层程序编写,以及其它开源SoC芯片介绍大聪明-PLUS8 天前
硬件断点:它们在 Linux 中的用途和工作原理大聪明-PLUS9 天前
如何修补 Linux 内核:完整指南大聪明-PLUS9 天前
Docker 内部机制:深入剖析大聪明-PLUS9 天前
常见的 Docker 问题及解决方法