ARM的Abort异常
2015-11-16 19:53
162 查看
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是否有问题。
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是否有问题。
相关文章推荐
- IO(一):传统IO(基于字符,字节,Socket) 与BIO,NIO,AIO 介绍
- lightoj1034 Hit the Light Switches
- 硬件语言编写规范与技巧
- hibernate连接Oracle rac
- java笔记_集合
- leetcode 50:Pow(x, n)
- Thread的run()与start()的区别
- xml文件不能被正确解析/The processing instruction target matching "[xX][mM][lL]" is not al
- 图像分割
- HTML笔记(2)
- 在xml中添加array
- 第八周 数据结构实践项目——串【项目4-字符串加密】
- 笔记五(垂直运动)
- Java RMI之HelloWorld篇
- iOS开发拓展篇—CoreLocation简单介绍
- java搭建finagle(2)
- AngularJs $compile编译服务与指令
- [POJ 1625] Censored! (AC自动机+DP+大整数)
- .pch文件的创建
- Unity与Android接口互相调用