解决未进入中断服务程序的一般思路

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Longyu_wlz/article/details/83155042

解决未进入中断服务程序的一般思路

  1. GPIO是否连接

  2. GPIO引脚是否配置,支持引脚复用功能的则需要判断是否选定使用的功能

  3. 检查中断向量表

  4. 对于支持重映射中断向量表的硬件,检查存储中断向量表起始地址的寄存器的值是否正确

  5. 当你在程序中对向量表重新进行了映射时,检查起始地址的合法性与复制区域大小,可以读取复制完成后的新中断向量表的首尾中,检查获取到的中断服务程序地址与旧中断向量表中的内容是否对应

  6. 中断向量表确认不存在问题后,开始检查中断配置状态

  7. 总中断是否打开

  8. 子中断是否打开

  9. 中断号与 ISR 连接是否正确?(不支持动态修改中断向量表的硬件可以跳过)

  10. 中断是否触发

  11. 当前设定的中断优先级是否会造成影响

  12. debug正常release异常的情况,可能是release优化后程序乱序执行造成的问题。考虑是否需要在代码中添加必要的编译屏障(阻止编译器优化造成的乱序执行问题)或运行时的内存屏障。着重分析读写关键变量的情况。

能够使用编译屏障来解决问题,尽可能的使用编译屏障。能够使用不太严格的内存屏障来解决问题,就尽可能使用。在保证正常执行的情况下,考虑最优的性能。越严格的屏障带来更安全的保障的同时也增强了性能开销。

猜你喜欢

转载自blog.csdn.net/Longyu_wlz/article/details/83155042