0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

针对Cortex-M3谈谈单片机Fault故障

strongerHuang 来源:strongerHuang 作者:strongerHuang 2021-10-29 10:00 次阅读

我们平时的项目,可能会遇到死机的情况,通过在线调试,或者打印消息,可能会发现,怎么进入了 HardFault_Handler 中断呢?

这种“硬故障”是我们常见的一种故障,导致硬故障的原因也有很多。本文针对 Cortex-M3 说说 Fault 故障相关的内容。

1

Fault故障种类

Fault故障的种类有很多,拿本文Cortex-M3来说,主要有:

HardFault:硬故障

MemManage:存储器管理故障

BusFault:总线故障

UsageFault:用法故障

4a8fa124-383f-11ec-82a8-dac502259ad0.png

比如,在stm32f10x_it.c源代码中,有这样的中断入口:

void HardFault_Handler(void){ /* Go to infinite loop when Hard Fault exception occurs */ while (1) { }}

void MemManage_Handler(void){ /* Go to infinite loop when Memory Manage exception occurs */ while (1) { }}

void BusFault_Handler(void){ /* Go to infinite loop when Bus Fault exception occurs */ while (1) { }}

void UsageFault_Handler(void){ /* Go to infinite loop when Usage Fault exception occurs */ while (1) { }}

2

Fault故障描述

每一种Fault故障的产生,都肯定是有一定原因的,如果你代码产生了Fault故障中断,说明代码某些地方引起了Fault故障。

1.HardFault:硬故障

通过截图的描述,你会发现硬故障是一种“不可编程”的故障,因为存储器管理故障、总线故障、用法故障如果不能得到执行,就为上访为硬故障。

4a8fa124-383f-11ec-82a8-dac502259ad0.png

比如:比如在取向量时产生的总线故障也按会硬故障进行处理。所以,你会发现出现故障,很多时候都是硬故障。

硬故障状态寄存器描述:

4b3a6546-383f-11ec-82a8-dac502259ad0.png

通过状态寄存器,你会发现产生硬故障的原因有以上几种。

2.MemManage:存储器管理故障存储器管理故障通常与MPU(内存保护单元)有关,之前给大家分享过MPU相关的文章《什么是Cortex-M内核的MPU?》。

通常就是我们说的“内存越界”就会导致存储器管理故障,细说引起该故障的诱因有:

访问了 MPU 设置区域覆盖范围之外的地址

往只读 region 写数据

用户级下访问了只允许在特权级下访问的地址

存储器管理故障状态寄存器:

4b803576-383f-11ec-82a8-dac502259ad0.png

通过状态寄存器,你会发现引起该故障的一些原因。

3.BusFault:总线故障总线故障,顾名思义就是对“总线”操作出现问题,导致的故障。

比如:当 AHB 接口上正在传送数据时,如果回复了一个错误信号(error response),则会产生总线故障。

产生总线故障的场合:

取指,通常被称作“预取流产”

数据读/写,通常被称作“数据流产”

触发总线故障的动作:

中断处理起始阶段的堆栈 PUSH 动作。称为“入栈错误”

中断处理收尾阶段的堆栈 POP 动作。称为“出栈错误”

4bbd91dc-383f-11ec-82a8-dac502259ad0.png

同样,通过总线故障状态寄存器了解产生的原因:

4c069850-383f-11ec-82a8-dac502259ad0.png

4.UsageFault:用法故障用法故障相对不常见,出现该故障通常是进行了“未对齐访问操作”,其他导致该故障问题很少见。

比如:执行了未定义的指令、除数为0(编译器都会避免)、无效的中断返回等这些情况比较少见。

用法故障状态寄存器:

4c5be620-383f-11ec-82a8-dac502259ad0.png

3

应对故障

不知道大家平时有没有对这些进行有效避免?

这里简单说几点应对故障的措施:

1.通过故障状态寄存器的值来判定程序错误

在故障中断函数中,读取故障的状态(上面描述了状态寄存器),比如硬故障:

void HardFault_Handler(void){ //读取状态寄存器,打印状态寄存器,判断什么原因引起故障 printf(“状态x信息”); while (1) { }}

如果不想系统处于死机状态,可以在中断里面做软复位。

2.提前对代码进行分析、预判

比如:通过代码静态分析工具,对代码进行分析、查找bug。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6037

    文章

    44558

    浏览量

    635258
  • Fault
    +关注

    关注

    0

    文章

    5

    浏览量

    7300

原文标题:单片机Fault故障常见应对办法

文章出处:【微信号:strongerHuang,微信公众号:strongerHuang】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Cortex-M3/M4F指令集技术用户手册

    电子发烧友网站提供《Cortex-M3/M4F指令集技术用户手册.pdf》资料免费下载
    发表于 12-23 16:31 3次下载
    <b class='flag-5'>Cortex-M3</b>/<b class='flag-5'>M</b>4F指令集技术用户手册

    单片机出现故障怎么维修

    单片机出现故障时,维修过程需要系统地检查和诊断,以确定故障的根本原因,并采取相应的修复措施。以下是一个详细的单片机维修指南,旨在帮助技术人员或爱好者有效地解决
    的头像 发表于 10-17 17:57 1057次阅读

    STM32单片机的特点介绍

    和易用的工具,再配合强大的功能,在行业中享有盛誉。 STM32单片机的特点主要体现在以下几个方面: STM32拥有强大的内核。它采用了ARM32位Cortex-M3 CPU,最高工作频率可达72MHz,这意味着它能够以极快的速度处理复杂的任务。同时,它还具备1.25DMI
    的头像 发表于 09-25 17:19 1490次阅读

    基于ARM Cortex-M3单片机研发的国产指纹芯片 - P1032BF1

    指纹芯片 - P1032BF1是一款基于ARM Cortex-M3单片机,专为Wi-Fi /蓝牙通信控制而设计;可应用于智能锁;支持大型程序代码和拥有大型嵌入式SRAM,也可用于一般的MCU应用。
    的头像 发表于 07-10 09:22 611次阅读
    基于ARM <b class='flag-5'>Cortex-M3</b><b class='flag-5'>单片机</b>研发的国产指纹芯片 - P1032BF1

    求助,关于cortex-M3的压栈问题求解

    我们都知道cortex-m3中断时是硬件自动压栈的,这样可以减少中断响应和恢复时间。中断硬件压栈的寄存器为xPSR, PC, LR, R12, R0-R3,为什么其他寄存器不需要压栈呢?
    发表于 04-28 08:18

    请问cortex-M7核单片机主要应用在哪些领域?

    看到st和nxp的M7核单片机,动不动几百兆的主频,有的还要外置DDR,还有的成本低于1刀。想知道这些单片机的目标应用场合是哪些? 单片机发展,从51过渡到
    发表于 04-17 07:49

    Holtek新推出Arm® Cortex®-M0+直流无刷电机控制专用全整合单片机

    Holtek推出新一代Arm® Cortex®-M0+直流无刷电机控制专用全整合单片机HT32F65C32F与HT32F65C40F,针对低电压、低功率电机专门设计,具有极高的集成度,
    的头像 发表于 04-02 17:19 890次阅读

    市面上很火的32位单片机—PY32F030单片机的产品特性介绍

    PY32F030 系列单片机是采用了高性能的 32 位 ARM® Cortex®-M0+ 内核,宽电压工作范围的 MCU。
    的头像 发表于 03-22 15:29 1296次阅读

    Cortex-M3芯片有哪些

    Cortex-M3芯片是一款基于ARM架构的低功耗、高性能的嵌入式处理器。目前市面上有众多厂商生产了基于Cortex-M3内核的芯片,如意法半导体的STM32F系列、恩智浦半导体的LPC1800系列等。这些芯片广泛应用于工业控制、智能家居、物联网等领域。
    的头像 发表于 03-11 17:07 1593次阅读

    Cortex-M3芯片怎么样

    Cortex-M3芯片是一款高性能、低功耗的32位RISC处理器,特别适用于嵌入式系统和实时控制领域。其架构采用哈佛结构,实现指令和数据存储器的独立访问,提高了系统效率。Cortex-M3支持内部和外部总线接口,提供了广泛的外设连接和扩展性支持。
    的头像 发表于 03-08 16:00 1329次阅读

    Cortex-M85内核单片机如何快速上手

    2022年4月,Arm推出了全新的MCU级内核Cortex-M85。截止目前(2024年2月),Cortex-M85是最新、最强的Cortex-M内核。
    发表于 02-29 09:35 745次阅读
    <b class='flag-5'>Cortex-M</b>85内核<b class='flag-5'>单片机</b>如何快速上手

    强大的Arm® Cortex®-M3内核(下)

    经过前一期的芝识课堂,我们了解了东芝MCU产品所基于Arm Cortex-M3内核的基本结构和寄存器分配的细节。
    的头像 发表于 01-25 09:25 1251次阅读
    强大的Arm® <b class='flag-5'>Cortex</b>®-<b class='flag-5'>M3</b>内核(下)

    PY32C613单片机简单介绍

    PY32C613单片机是普冉新推出的高性能的 32 位 ARM Cortex-M0+ 内核,宽电压工作范围的 MCU。
    的头像 发表于 01-16 18:06 1094次阅读
    PY32C613<b class='flag-5'>单片机</b>简单介绍

    如何实现Cortex-M3与ADuC7061之间用IIC通讯?

    我想实现Cortex-M3与ADuC7061之间用IIC通讯,Cortex-M3用做主机,ADuC7061用做从 。我要实现收发数据,ADuC7061应该怎样配置呢,思路是什么?
    发表于 01-15 06:13

    STM32单片机的特点和功能是什么

    STM32单片机是一款基于ARM Cortex-M内核的32位闪存微控制器,由STMicroelectronics公司(意法半导体)生产。STM32单片机具有高性能、低功耗、丰富的外设和易于开发
    的头像 发表于 01-03 15:33 1.2w次阅读