ARM的Abort异常
最新推荐文章于 2024-02-29 19:59:12 发布
转载
最新推荐文章于 2024-02-29 19:59:12 发布
·
6k 阅读
·
1
·
11
Linux 系列
同时被 3 个专栏收录
271 篇文章
订阅专栏
Android 系列
100 篇文章
订阅专栏
手机系列
41 篇文章
订阅专栏
本文详细介绍了ARM异常中的dataabortexception和prefetchabortexception,包括它们产生的原因、如何通过指令计算非法内存地址以及解决方法。重点在于理解C/C++语言中的指针使用错误可能导致的异常,并提供了检查memmap的有效途径。
摘要生成于
C知道
,由 DeepSeek-R1 满血版支持,
前往体验 >
data abort exception:
data abort是arm异常的一种。当程序试图读或者写一个不合法的内存地址时发生(没有权限访问或者不存在的地址), 可以通过以下方式计算不合法的内存地址:
R14(LR)-8得到导致data abort异常的指令,从指令的寄存器中得到需要操作的地址。
一般而言,导致这种异常的指令为STR,LDR(涉及到内存读写的指令)。反应在C或者C++语言里,一般是某个指针指向的地址有问题或者存储指针的地址有问题。
prefetch abort exception:
A Prefetch Abort occurs when you've attempted to execute code at an invalid memory address.
预取指令异常。ARM CPU根据一个地址预取指令,发现地址取不出数据或者无法访问,就会触发预取指异常。
一般是B(执行跳转分支指令)触发。发生此种问题时,需要检查程序的mem map是否有问题。