ca9d425ea0e403381ed083d331e64d9d.png

相信有不少读者都遇到过 “HardFault” 的问题,而且不止一次,有时候可能因为它连续几日加班,甚至通宵。

那么今天就来分享一个由armink(也就是现在RTT里面的那位朱大神)整理的开源库,借花献佛分享给大家。

该库采用采用 MIT 开源协议,开源地址:

https://github.com/armink/CmBacktrace

一、CmBacktrace 是什么

CmBacktrace (Cortex Microcontroller Backtrace)是一款针对 ARM Cortex-M 系列 MCU 的错误代码自动追踪、定位,错误原因自动分析的开源库。主要特性如下:

1.支持的错误包括

  • 断言(assert)

  • 故障(Hard Fault, Memory Management Fault, Bus Fault, Usage Fault, Debug Fault)

2.故障原因自动诊断

可在故障发生时,自动分析出故障的原因,定位发生故障的代码位置,而无需再手动分析繁杂的故障寄存器;

3.输出错误现场的函数调用栈(需配合 addr2line 工具进行精确定位),还原发生错误时的现场信息,定位问题代码位置、逻辑更加快捷、精准。也可以在正常状态下使用该库,获取当前的函数调用栈;

4.支持 裸机 及以下操作系统平台:

  • RT-Thread

  • UCOS

  • FreeRTOS(需修改源码)

5.根据错误现场状态,输出对应的 线程栈 或 C 主栈;

6.故障诊断信息支持多国语言(目前:简体中文、英文);

7.适配 Cortex-M0/M3/M4/M7 MCU;

8.支持 IAR、KEIL、GCC 编译器;

二、为什么选择 CmBacktrace

入门新人:对于从 C51 、MSP430 等简单单片机转而使用更加复杂的 ARM 新人来说,时不时出现的 "hard falut" 死机会让新人瞬间懵掉。定位错误的方法也往往是连接上仿真器,一步步 F10/F11 单步,定位到具体的错误代码,再去猜测、排除、推敲错误原因,这种过程十分痛苦。

熟练老手:慢慢的大家知道可以通过故障寄存器信息来定位故障原因及故障代码地址,虽然这样能解决一小部分问题,但是重复的、繁琐的分析过程也会耽误很多时间。而且对于一些复杂问题,只依靠代码地址是无法解决的,必须得还原错误现场的函数调用逻辑关系。虽然连接仿真器可以查看到的函数调用栈,但故障状态下是无法显示的,所以还是得一步步 F10/F11 单步去定位错误代码的位置。另外,还有两种场景,

1、很多产品真机调试时必须断开仿真器

2、问题确实存在,但是极难被重现

所以定位这类问题就显得难上加难。

使用本库:上述所有问题都迎刃而解,可以将错误信息输出到控制台上,还可以将错误信息使用 EasyFlash 的 Log 功能保存至 Flash 中,设备死机后重启依然能够读取上次的错误信息。CmBacktrace 输出的信息包括函数调用栈、故障诊断结果、堆栈、故障寄存器及产品固件信息,极大的提升了错误定位的效率及准确性。

俗话说,工欲善其事,必先利其器。所以有时候做事效率低的原因也许是,你会用的工具种类太少。

三、CmBacktrace 如何使用

本文就简单演示一下,演示分如下几个步骤:

1、制造除零异常(IAR 工程,点击查看源码)

2、查看错误诊断信息

3、查看函数调用栈基本信息

4、通过命令行工具进入项目工程存放可执行文件的路径

5、使用 addr2line 命令,查看函数调用栈详细信息,并定位错误代码

fab649ace20fefb3314feec34e3a0d5e.png

d62f34ca35563721b4a6d7fb4bd46626.png

1236d1834f73a880533d7dc6597a95ba.png

def0117cd412d265d2e9b4b53345dffb.png

086cfd8a8534024df06344adc3258309.png

具体的使用方法,请见原始说明文档,里面描述了很多细节内容。

开源地址:

https://github.com/armink/CmBacktrace

722c79f0c42af5f789e5131d4c0b7d68.png

1.谨记:知者不惑,仁者不忧,勇者不惧

2.中芯国际透露:14nm或不能为某客户代工

3.数学之美:嵌入式编程凹凸性之妙用(附C代码)

4.MCU是如何从上电复位运行到main函数的?

5.不想在编译程序时浪费时间,这里有妙招!

6.STM32L5中如何关闭TrustZone?

13f9cd1e4234a5d05e1cbc09d2978f58.gif

免责声明:本文系网络转载,版权归原作者所有。如涉及作品版权问题,请与我们联系,我们将根据您提供的版权证明材料确认版权并支付稿酬或者删除内容。

Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐