ARM的Abort异常

ARM的Abort异常

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是否有问题。

相关推荐