我的编程空间,编程开发者的网络收藏夹
学习永远不晚

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

小编给大家分享一下STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

 引言

我们在平常使用STM32单片机的时候,往往会碰到程序跑飞的情况,出现hard_fulat等错误,而我们在定位错误的时候,采用的方法往往是连上仿真器,一步一步单步调试,定位到具体的错误代码,再去猜测、排除、推敲错误原因,这样一个过程很是痛苦,而且在实际情况中,很多产品真机调试时必须断开仿真器或者说,问题确实存在,但是极难出现,所以在基于这样一个问题背景下,RTT  的大佬armink开发了一个基于 ARM Cortex-M系列的 MCU错误追踪库,用于帮助开发者解决上述问题。

CmBacktrace 的作用及适用平台首先,CmBacktrace 是一款针对于 ARM Cortex-M 系列 MCU  的错误代码自动追踪、定位、错误原因自动分析的开源库,它所支持的错误包括:

  • 断言(assert)

  • 故障

  • Hard Fault, Memory Management Fault, Bus Fault, Usage Fault, Debug Fault

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

  • RT-Thread

  • UCOS

  • FreeRTOS

适配 Cortex-M0/M3/M7  MCU,支持IAR、KEIL、GCC编译器,能够达到的效果是:故障原因自动诊断,自动分析故障原因,定位发生故障代码位置,输出错误现场的函数调用栈。

移植

当前笔者所使用的平台是 keil 5,所使用的控制器是 STM32F103,我们准备一个具备串口功能的工程,工程结构如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306101326283

紧接着,我们来看下 cm_backtrace的源代码:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306101659128

上述中,cm_backtrace文件夹中存放的是源代码,我们需要将其全部复制到我们的工程目录,demos是使用的例子,里面分为有操作系统和无操作系统两种类型,然后tools存放的是工具,用命令行的形式来分析代码错误的工具,将相关文件复制到工程目录之后工程目录下的文件如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306102410525

然后,我们将相关文件添加至工程中,下面是添加之后的工程文件:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306102815766

同时应该添加相关头文件路径,添加的头文件路径如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306102919999

至此,cm_backtrace的源代码就添加完了,我们来编译一下。编译结果如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪


image-20210306103031890

可以发现有很多错误,这是因为我们的相关宏还没有打开,我们以照源码中的说明文档中的一个表,在 cmb_def.h中依次打开对应的宏,表如下所示:

配置名称功能备注
cmb_println(…)错误及诊断信息输出必须配置
CMB_USING_BARE_METAL_PLATFORM是否使用在裸机平台使用则定义该宏
CMB_USING_OS_PLATFORM是否使用在操作系统平台操作系统与裸机必须二选一
CMB_OS_PLATFORM_TYPE操作系统平台RTT/UCOSII/UCOSIII/FREERTOS
CMB_CPU_PLATFORM_TYPECPU平台M0/M3/M4/M7
CMB_USING_DUMP_STACK_INFO是否使用 Dump 堆栈的功能使用则定义该宏
CMB_PRINT_LANGUAGE输出信息时的语言CHINESE/ENGLISH

更改之后的代码如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306103649154

更改了宏之后,我们再来编译代码,编译结果如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306103729814

提示要开启c99编译模式,我们在keil中设置,设置方式如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306103831859

继续编译,看到还有一个错误信息,编译结果如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306104005145

这是因为cmb_fault.S中使用汇编定义了 HardFault_Handler函数,而在原本工程中,stm32f10x_it.c中已经定义了  HardFault_Handler,我们将stm32f10x_it.c中的HardFault_Handler注释掉,代码如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306104326301

现在编译就可以通过了。

测试

移植完之后,我们现在来测试一下,在单片机中除0造成的错误如何检查出来,我们在主函数中添加如下所示的代码:

#include "stm32f10x.h" #include "bsp_usart.h" #include <cm_backtrace.h>  #define HARDWARE_VERSION               "V1.0.0" #define SOFTWARE_VERSION               "V0.1.0"  extern void fault_test_by_div0(void);   int main(void) {          USART_Config();       cm_backtrace_init("CmBacktrace", HARDWARE_VERSION, SOFTWARE_VERSION);    fault_test_by_div0();    while(1)   {       }     }

将程序烧录单片机,通过串口调试助手观查输出的信息:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306105316179

我们可以看到输出信息显示了当前用法错误是:企图除 0  操作,并给出了相关寄存器信息,但是我们还不知道出现错误的代码在哪一行,这个时候,就需要使用到前文所说的tools文件夹下的工具,addr2line工具。在使用这个工具的时候,需要知道当前工具输出的可执行文件的名字,我们打开keil,信息如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306105719377

然后,我们找到 cm_backtrace文件夹下的tools工具,将其复制到USART.axf所在的目录,复制之后的文件夹目录如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306110017993

在当前文件夹下打开 cmd窗口,然后运行addr2line -e USART.axf -a -f 08001844 0800189a,在这里提一下打开  cmd的方法,按住Shift键,然后右键,打开Powershell

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306110527928

打开的 Powershell如下所示,并在Powershell中输入start cmd打开cmd窗口,然后在cmd窗口输入addr2line -e  USART.axf -a -f 08001844 0800189a,结果如下所示:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306110839097

可以看到错误信息是fault_test.c的38行,我们打开源代码查看:

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

image-20210306111229605

可以看到确实是38行,问题分析正确。

以上是“STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

STM32在Keil环境下怎么使用Cm_Backtrace进行错误追踪

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录