程序运行总是进入Abort_Handler

问题描述

接手了公司一个早期项目,大概10年了。发现该项目在编译时总是卡死。看汇编,发现总是停留在Abort_handler段。只要一开启中断就会产生。
开发环境:IAR7.20 ADUC7024。

结论

相关文件中中断入口函数配置错误,与cstartup.s中的函数名称不一致。造成所有的中断都指向了同一个入口地址,并且默认为Abort_handler段。

解决过程

刚开始猜测问题发生在中断相关,于是注释掉各个初始化函数,只保留了了外部时钟配置相关函数。发现问题依然存在。因为7024选择外部时钟需要先进入NAP模式,再通过定时器(属于IRQ)中断唤醒。进而发现只要涉及到中断的问题,就一定会复现此问题。猜测问题发生在各个中断文件。然而各个文件都属于早期文件,注释了了。在一一排除了IAR官方文件的问题后。依旧无解。然后走投无路之下,逐步看汇编,发现中断处,所有的向量都指向了同一地址,abort_handler。进而从cstartup.s寻找问题,发现里面的中断入口地址与中断配置文件中的中断函数名称不一致,修改后问题解决。询问经理,才知道cstartup.s文件是从外部复制过来的,因为当时运行不起来......寻找文件夹,发现里面果然有同名的cstartup.s79文件...

感悟

嵌入式的调试,一定要立足于汇编和map。这个远古工程,不如重新搭更靠谱。

上一篇:Photoshop 神秘的发光烟雾字


下一篇:reactor 和 proactor 的区别