单片机Fault故障常见应对办法

关注+星标公众,不错过精彩内容

1f098dc9773553bc2a30525ad4cef598.gif

作者 | strongerHuang

微信公众号 | 嵌入式专栏

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

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

嵌入式专栏

1

Fault故障种类

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

  • HardFault:硬故障

  • MemManage:存储器管理故障

  • BusFault:总线故障

  • UsageFault:用法故障

73e36fc46a8e010e087490f4ad022fa4.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:硬故障

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

a4f5d133a9bae67c901b4a2e3019c013.png

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

硬故障状态寄存器描述:

cc4a5def61439be46947e72ac7d0839d.png

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

2.MemManage:存储器管理故障

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

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

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

  • 往只读 region 写数据

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

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

da7e1e5eb9a31b109eda75876fdbfdc0.png

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

3.BusFault:总线故障

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

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

产生总线故障的场合:

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

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

触发总线故障的动作:

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

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

c1183ed8eb6d21eca3b5b5f1ec8776a0.png

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

4ebe7067a47bdc4dc12111592dee95a6.png

4.UsageFault:用法故障

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

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

用法故障状态寄存器:

a615db4383b10c4b268d7067e1eb88d9.png

嵌入式专栏

3

应对故障

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

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

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

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

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

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

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

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

前不久才分享过一篇文章:推荐几个代码静态分析工具

3.其他诊断方法

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

先写到这里,还有更多更好的方法,欢迎大家留言补充。

------------ END ------------

后台回复『Cortex-M3』『单片机』阅读更多相关文章。

欢迎关注我的公众号回复“加群”按规则加入技术交流群,回复“1024”查看更多内容。

欢迎关注我的视频号:

76181361fa18a995ff88574afcb6a81b.png

点击“阅读原文”查看更多分享,欢迎点分享、收藏、点赞、在看。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值