Bad mode in prefetch abort handler detected

来源:互联网 发布:个人软件开发合同范本 编辑:程序博客网 时间:2024/06/12 19:17
简单记录一下,今天在调试休眠代码时,遇到一个很奇怪的问题,在唤醒过程中,出现了一个没见过Oops。看样子是执行了非法操作,CPU进入了异常状态。
 
Bad mode in prefetch abort handler detected
Internal error: Oops - bad mode: 0 [#1]
Modules linked in:
CPU: 0
PC is at serial_pxa_resume+0x38/0x58
LR is at uart_resume_port+0x1d8/0x1e4
pc : [<c01186ec>]    lr : [<c0116aec>]    Not tainted
sp : c78c1df0  ip : c78c1de0  fp : c78c1e4c
r10: c79fb7a0  r9 : c78c1f78  r8 : 00000008
r7 : c01ea010  r6 : c0218580  r5 : c0218658  r4 : c023f0a8
r3 : 00000000  r2 : 00000001  r1 : 00000000  r0 : 00000000
Flags: nZCv  IRQs off  FIQs on  Mode UK8_32  Segment user
 
    看代码都是很正常,没有做什么很罕见的操作,不应该有这么奇怪的错误,最后发现,是因为某一路分支路径上,local_irq_save 和 local_irq_restore没有配对,使得传给local_irq_restore的参数不正确。导致CPSR中的处理器模式位的值不正确,于是出现这个错误。

原创粉丝点击