超实用!单片机Fault故障常见应对办法

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

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

Fault故障种类

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

  • HardFault:硬故障

  • MemManage:存储器管理故障

  • BusFault:总线故障

  • UsageFault:用法故障

比如,在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) { }}

    Fault故障描述

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

    1、HardFault:硬故障

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

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

    硬故障状态寄存器描述:
    通过状态寄存器,你会发现产生硬故障的原因有以上几种。
    2、MemManage:存储器管理故障
    存储器管理故障通常与MPU(内存保护单元)有关,之前给大家分享过MPU相关的文章《什么是Cortex-M内核的MPU?》。
    通常就是我们说的“内存越界”就会导致存储器管理故障,细说引起该故障的诱因有:
    • 访问了 MPU 设置区域覆盖范围之外的地址

    • 往只读 region 写数据

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

    存储器管理故障状态寄存器:
    通过状态寄存器,你会发现引起该故障的一些原因。
    3、BusFault:总线故障
    总线故障,顾名思义就是对“总线”操作出现问题,导致的故障。
    比如:当 AHB 接口上正在传送数据时,如果回复了一个错误信号(error response),则会产生总线故障。
    产生总线故障的场合:
    • 取指,通常被称作“预取流产”

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

    触发总线故障的动作:
    • 中断处理起始阶段的堆栈 PUSH 动作。称为“入栈错误”

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

    同样,通过总线故障状态寄存器了解产生的原因:
    4、UsageFault:用法故障
    用法故障相对不常见,出现该故障通常是进行了“未对齐访问操作”,其他导致该故障问题很少见。
    比如:执行了未定义的指令、除数为0(编译器都会避免)、无效的中断返回等这些情况比较少见。
    用法故障状态寄存器:

    如何应对故障

    不知道大家平时有没有对这些进行有效避免?这里简单说几点应对故障的措施:

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

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

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

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

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

      比如:通过代码静态分析工具,对代码进行分析、查找bug。前不久才分享过一篇文章:推荐几个代码静态分析工具

      3、其他诊断方法

      之前给大家分享过一篇文章《针对Cortex-M调试诊断 HardFault 的错误追踪库》可以有效诊断本文说的这种“硬故障”。
      (0)

      相关推荐

      • ARM Cortex-M 系列 MCU错误代码自动追踪库的使用经验分享

        大家在用STM32的时候有没有遇到过HardFault的问题呢: 之前有一段时间被这个问题困扰了很久,下面针对这个问题做个小总结. 现象还原:在debug模式下进行仿真调试,全速运行再停止运行,程序会 ...

      • CmBacktrace

        Foreword CmBacktrace (Cortex Microcontroller Backtrace)是一款针对 ARM Cortex-M 系列 MCU 的错误代码自动追踪.定位,错误原因自动 ...

      • CNC加工中心常见的松刀故障及解决办法

        西尔普数控,CNC加工中心常见的松刀故障及加工中心常见手轮故障的解决办法. 目前我们所见的松刀故障有哪些,西尔普数控整理的CNC加工中心松刀故障如下: CNC加工中心常见的松刀故障 一.原因: 1.松 ...

      • 电动执行器常见故障及维修办法(收藏备用!)

        来源:阀门之声 如有侵权,请联系删除 一.指示灯故障 1.故障现象: 给电动执行机通电后发现电源指示灯不亮,伺放板无反馈,给信号不动作. 故障判断和检修过程: 因电源指示灯不亮,首先检查保险管是否开路 ...

      • 邢台数控编程培训学校-主轴编码器常见的故障及处理办法

        GUBOA机床编码器作为机床使用的一款编码器,主要是用于测速及定位,通过信号反馈输出从而测量机械的速度及位置.GUBOA编码器就是一款机床编码器,随着编码器的不断升级换代,精密等级也不断提升,使用范围 ...

      • 门禁系统常见故障及解决办法

        故障现象1 在独立门禁系统中,经常出现的就是无法卡门,刷卡或密码后,锁打不开. 判断及解决方法:首先确定卡或密码的有效性,在正常情况下卡或密码不会丢失.如果出现打不开锁,且情况紧急,直接把门禁电源断掉 ...

      • 动画揭示电磁阀工作原理,附电磁阀常见故障及解决办法

        法律顾问:赵建英律师 电磁阀相信大家都不陌生: 它是用来控制流体的自动化基础元件,属于执行器,并不限于液压.气动.不同的电磁阀在控制系统的不同位置发挥作用,最常用的是单向阀.安全阀.方向控制阀.速度调 ...

      • 收藏备用!电动执行器常见故障及维修办法

        一.指示灯故障 1.故障现象: 给电动执行机通电后发现电源指示灯不亮,伺放板无反馈,给信号不动作. 故障判断和检修过程: 因电源指示灯不亮,首先检查保险管是否开路,经检查保险管完好,综合故障现象,可以 ...

      • 叉车的基本操作常识:驱动系统常见的故障及处理办法

        叉车的装载行驶时,货物离地高度不应该大于500毫米. 内燃叉车工作时的正常水温应该在内燃叉车启动时间应在几秒内完成,如果不能启动,应该间隔2至3分钟再重新启动.以免造成电瓶放电过快及启动机过热而损坏部 ...

      • 详解电风扇常见故障和处理办法

        到了夏天,带给大家清凉的电风扇总是被长期的使用着,这样就增加了电风扇的损坏率.当电风扇坏掉的时候,有些人觉得拿去专业的维修店维修所需的时间太长了,所以选择亲自动手维修.今天,小编为大家总结出一些电风扇 ...

      • 最常见的电脑故障及其解决办法,不求人自己就能修复

        在使用电脑的过程中,我们难免会遇到各种各样的电脑故障.对于电脑小白来说,在面对这样的状况时,脑海中萌发的第一个想法就是拿去电脑店修理.事实上,有些电脑故障只需自己简单处理一下就可以正常使用了,何必要浪 ...