ARM Cortex-M 系列 MCU 错误追踪库 心得

一. 感谢CmBacktrace开源项目,git项目网站:https://github.com/armink/CmBacktrace

二. 移植CmBacktrace

2.1 准备好CmBacktrace源码

2.2. 准备自己的项目源码

1. 如果没有自己的项目,可以使用CmBacktrace的demos项目作为自己的项目

2. 我的项目代码是用cuteMX生成的project for NUCLEO-G431RB

2.3. 需要移植的文件

2.3.1. cmb_fault.S

1. 此文件很重要,当发生HardFault_Handler中断时,程序会跳转到cmb_fault.S文件的中断函数(当然要先删掉c语言的HardFault_Handler中断)

2.3.2. cm_backtrace.c,fault_test.c

1. cm_backtrace.c文件用于当发生HardFault_Handler中断时打印出寄存器值及必要的错误信息

2. fault_test.c是一个测试应用

2.3.3. addr2line工具

2.3.4. 相关头文件

1. cmb_cfg.h此文件很重要,应用配置自己项目的一些参数,比如打印函数,内核类型

2.4. 项目开发

2.4.1. 添加源文件到项目

2.4.2. 添加头文件路径

2.4.3. main中添加init 函数,NUCLEO-G431RB就是项目名字

cm_backtrace_init("jsNUCLEO-G431RB", HARDWARE_VERSION, SOFTWARE_VERSION);

2.4.4. 添加测试程序

fault_test_by_div0();

三. 测试

3.1. 运行程序。串口打印错误信息

3.2. 使用串口打印的命令找出错误点,需要将NUCLEO-G431RB.axf和addr2line工具放在同一目录下

原文地址:https://www.cnblogs.com/linux-37ge/p/11749978.html

时间: 2024-10-05 23:25:19

ARM Cortex-M 系列 MCU 错误追踪库 心得的相关文章

ARM cortex a 之时钟系统1

ARM cortex a系列的时钟系统是一个非常复杂而且麻烦的东西,下面我们首先明确一些概念和东西. 本部分主要介绍一下时钟系统的初始化工作,以及里面的一些原理. S5PV210的时钟系统是一个非常麻烦的东西,首先需要时钟信号的产生,时钟发生器只有和晶振一起工作才能产生时钟信号,这两个单独使用的话是没有任何作用的. 时钟系统分为三个大域:即主系统(MSYS),显示系统(DSYS),和外围系统(PSYS). (1)MSYS域包括cortexA8处理器,DRAM内存控制器(DMC0和DMC1),3D

ARM linux电源管理——Cortex A系列CPU(32位)睡眠和唤醒的底层汇编实现

ARM linux电源管理——Cortex A系列CPU(32位)睡眠和唤醒的底层汇编实现 承接 http://www.wowotech.net/pm_subsystem/suspend_and_resume.html Linux电源管理(6)_Generic PM之Suspend功能一文中的下图. 本文主要分析平台相关的CPU睡眠和唤醒,即下电和上电流程,以及ARM底层汇编代码实现. 内核版本:3.1.0               CPU:ARM Cortex-A7 1 平台相关函数执行流程

ARM7与ARM Cortex比较

ARM7与ARM Cortex比较  1.ARM实现方法 ARM Cortex是一种基于ARM7v架构的最新ARM嵌入式内核,它采用哈佛结构,使用分离的指令和数据总线(冯诺伊曼结构下,数据和指令共用一条总 线).从本质上来说,哈佛结构在物理上更为复杂,但是处理速度明显加快.根据摩尔定理,复杂性并不是一件非常重要的事,而吞吐量的增加却极具价值. ARM公司对Cortex的定位是:向专业嵌入式市场提供低成本.低功耗的芯片.在成本和功耗方面,Cortex具有相当好的性能,ARM公司认为它特别适用于汽车

《Cortex?-A系列编程者指南(V3.0)》第12章<异常处理>笔记

在本章,我们看看ARM处理器如何响应异常.异常是任何需要挂起正常执行转而运行与每个异常类型相关联软件(称为异常处理程序)的条件. 12.1 异常的类型 如我们在第四章看到,A系列和R系列架构支持七种处理器模式,六种特权模式(称为快速中断模式.外部中断模式.管理模式.中止模式.未定义模式和系统模式),一种非特权模式(用户模式).如果虚拟化扩展和安全扩展被实现,Hyp和Monitor模式可以被添加到列表.当前模式在软件控制下或处理一个异常时修改. 然而,非特权的用户模式只能通过产生一个异常来切换到另

ARM Cortex M0权威指南_PDF电子书下载 带书签目录 高清完整版 http://pan.baidu.com/s/1jGKQSwY MariaDB入门很简单_PDF电子书下载 带

ARM  Cortex  M0权威指南_PDF电子书下载 带书签目录 高清完整版   http://pan.baidu.com/s/1jGKQSwY MariaDB入门很简单_PDF电子书下载 带书签目录 高清完整版  http://pan.baidu.com/s/1hqpgV20 管理就是走流程__没有规范流程,管理一切为零_PDF电子书下载 带书签目录 高清完整版  http://pan.baidu.com/s/1bntuLyf 搜索引擎优化  SEO  方法与技巧  第5版_PDF电子书下

意法STM32F1系列MCU单片机解密芯片破解复制

意法STM32F1系列MCU单片机解密芯片破解复制 STM32F1系列MCU芯片解密: STM32F100解密 | STM32F101解密 | STM32F102解密 | STM32F103解密 | STM32F105解密 | STM32F107解密 STM32F1系列基础型MCU满足了工业.医疗和消费类市场的各种应用需求.凭借该产品系列,意法半导体在全球ARM Cortex-M 微控制器领域处于领先地位,同时树立了嵌入式应用的里程碑.该系列利用一流的外设和低功耗.低压操作实现了高性能,同时还以

《Cortex?-A系列编程者指南(V3.0)》第13章<中断处理>笔记

在本章,我们会看看ARM处理器处理中断的一系列方法,简单地看看通用中断控制器(Generic Interrupt Controller,GIC)架构. 旧版本的ARM架构允许实现者在他们的外部中断控制器设计中相当大的自由,没有关于中断类型或数量,或者是被用于中断控制模块接口的软件模型的协议.GIC架构提供一个更为严格的控制规范,使得来自不同制造商之间的中断控制器之间有更高程度的一致性.这使得中断处理代码变得更加可移植. 13.1 外部中断请求 如我们在第12章的异常类型中讨论的,所有的ARM处理

Win10 UWP开发系列——开源控件库:UWPCommunityToolkit

原文:Win10 UWP开发系列--开源控件库:UWPCommunityToolkit 在开发应用的过程中,不可避免的会使用第三方类库.之前用过一个WinRTXamlToolkit.UWP,现在微软官方发布了一个新的开源控件库—— UWPCommunityToolkit 项目代码托管在Github上:https://github.com/Microsoft/UWPCommunityToolkit 包括以下几个类库: 都可以很方便的从Nuget上安装. NuGet Package Name des

S12(X)系列MCU的存储器分页访问机制

本文由"汽车电子expert成长之路"公众号中"S12(X)系列MCU的片上存储器资源与分页访问机制详解"文章整理得来 最近接触S12MCU中关于FLASH的擦写相关知识,需要捋清楚几个概念.  (16位单片机)   具体内存分配看 MC9S12G系列芯片手册中 40 页 本地地址(Local Address):也称为局部地址,指内核CPU能够线性访问的地址,对于16位MCU来说就是0x0000~0xFFFF的64KB地址空间; 逻辑地址(Logic Address