armv7-a 异常排查

  • 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 的值,可以进行栈回溯,获取调用栈
相关推荐
才鲸嵌入式14 天前
C++相比于C语言增加了哪些概念?
c语言·c++·单片机·嵌入式·arm·面向对象·软件
ID244251272015 天前
Linux设备框架:kset与kobject基本介绍
linux·c语言·arm开发·驱动开发·嵌入式硬件·linux内核·arm
hyh-hz17 天前
4 Studying《ARM System Developer’s Guide》9-15
arm
hyh-hz20 天前
1 Studying《Arm A715 Software Optimization Guide》
arm
飞凌嵌入式21 天前
基于RK3588,飞凌教育品牌推出嵌入式人工智能实验箱EDU-AIoT ELF 2
linux·人工智能·嵌入式硬件·arm·nxp
toradexsh25 天前
HDMI 显示器热插拔对应显示应用启停测试
arm·nxp·hdmi·imx8qm·hotplug
才鲸嵌入式1 个月前
01 Ubuntu20.04下编译QEMU8.2.4,交叉编译32位ARM程序,运行ARM程序的方法
linux·c语言·单片机·嵌入式·arm·qemu·虚拟机
謓泽1 个月前
【STM32】按键控制LED & 光敏传感器控制蜂鸣器
stm32·单片机·arm
MaoXian_n1 个月前
[IMX] 08.RTC 时钟
linux·驱动开发·嵌入式硬件·arm
极术社区1 个月前
“星睿O6”AI PC 开发套件评测: NPU 算力测评(1)
arm