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

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

3天内不再提示

剖析Cortex-M3发生Fault故障类型及产生原因

strongerHuang 来源:strongerHuang 作者:strongerHuang 2021-05-08 15:59 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

我们平时的项目,可能会遇到死机的情况,通过在线调试,或者打印消息,可能会发现,怎么进入了 HardFault_Handler 中断呢? 这种“硬故障”是我们常见的一种故障,导致硬故障的原因也有很多。本文针对 Cortex-M3 说说Fault故障相关的内容。

1

Fault故障种类

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

HardFault:硬故障

MemManage:存储器管理故障

BusFault:总线故障

UsageFault:用法故障

3af924d0-ac42-11eb-9728-12bb97331649.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:硬故障

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

3af924d0-ac42-11eb-9728-12bb97331649.png

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

硬故障状态寄存器描述:

3b7d6de4-ac42-11eb-9728-12bb97331649.png

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

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

往只读 region 写数据

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

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

3b8febae-ac42-11eb-9728-12bb97331649.png

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

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

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

触发总线故障的动作:

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

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

3ba59ad0-ac42-11eb-9728-12bb97331649.png

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

3bb8ed56-ac42-11eb-9728-12bb97331649.png

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

3bc89de6-ac42-11eb-9728-12bb97331649.png

3

应对故障

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

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

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

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

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

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

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

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

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

编辑:jq

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

    关注

    31

    文章

    5588

    浏览量

    129053
  • 数据
    +关注

    关注

    8

    文章

    7314

    浏览量

    93968
  • 代码
    +关注

    关注

    30

    文章

    4941

    浏览量

    73137
  • 编译器
    +关注

    关注

    1

    文章

    1669

    浏览量

    51079

原文标题:Cortex-M3发生Fault故障类型及产生原因

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    onsemi碳化硅MOSFET NVHL070N120M3S:性能剖析与应用展望

    在功率半导体领域,碳化硅(SiC)技术正逐渐崭露头角。今天,我们就来详细剖析onsemi推出的一款碳化硅MOSFET——NVHL070N120M3S,看看它在实际应用中究竟有哪些独特之处。
    的头像 发表于 12-02 10:06 187次阅读
    onsemi碳化硅MOSFET NVHL070N120<b class='flag-5'>M3</b>S:性能<b class='flag-5'>剖析</b>与应用展望

    Cortex-M产品的特色

    低功耗设计:Cortex-M系列处理器核心被设计为低功耗架构,适用于移动电源和电池供电的嵌入式系统。 高性能处理:Cortex-M处理器具有高性能的特点,能够处理复杂的实时任务,并拥有较高
    发表于 11-26 07:22

    STM32G474进入Fault3中断没办法设置成周期性触发吗?

    手动操作硬件触发了Fault3故障,进入了Fault3中断,此时若故障一直存在程序就在中断里无法出来,FreeRTOS停止运行,把故障解除后
    发表于 08-01 07:23

    电机疑难故障原因分析及解决措施

    ,电机无法拖动负载,最终导致了故障现象的产生。通过对转子发生轴向位移的轴承位置的调整,解除了故障,恢复了正常生产。 **纯分享帖,需要者可点击附件免费获取完整资料~~~*附件:电机疑难
    发表于 05-14 16:31

    BNC座接地故障深度剖析与应对策略

    尽管BNC座接地故障较为常见,但只要我们明确故障原因,并采取恰当的措施,就能有效预防或减少故障发生。在使用BNC座时,要注重定期检查、清洁
    的头像 发表于 05-12 09:31 449次阅读
    BNC座接地<b class='flag-5'>故障</b>深度<b class='flag-5'>剖析</b>与应对策略

    MAX32510基于DeepCover安全Arm Cortex-M3的闪存微控制器技术手册

    的解决方案,用于构建新一代安全防护设备。MAX32510包括Arm^®^ Cortex ^®^ -M3核心、512KB嵌入式闪存、96KB系统RAM、1KB电池备份AES自加密非易失内存(NVSRAM
    的头像 发表于 05-08 16:33 562次阅读
    MAX32510基于DeepCover安全Arm <b class='flag-5'>Cortex-M3</b>的闪存微控制器技术手册

    MAX32558 DeepCover安全ARM Cortex-M3闪存微控制器技术手册

    DeepCover 嵌入式安全方案采用多重先进的物理安全机制保护敏感数据,提供最高等级的密钥存储保护。 MAX32558基于Arm Cortex ^®^ -M3处理器,具有512KB嵌入式闪存
    的头像 发表于 05-08 14:49 667次阅读
    MAX32558 DeepCover安全ARM <b class='flag-5'>Cortex-M3</b>闪存微控制器技术手册

    MAX32555 Cortex-M3闪存微控制器英文数据手册

    电子发烧友网站提供《MAX32555 Cortex-M3闪存微控制器英文数据手册.pdf》资料免费下载
    发表于 04-25 16:40 1次下载

    变频器相同的故障原因不同的故障代码分类

    变频器相同的故障原因可能对应不同的故障代码,这主要取决于变频器的型号、制造商以及具体的故障检测机制。以下是一些常见的故障
    的头像 发表于 04-25 14:31 1889次阅读
    变频器相同的<b class='flag-5'>故障</b><b class='flag-5'>原因</b>不同的<b class='flag-5'>故障</b>代码分类

    UPS(不间断电源)故障原因竟然是这样

    UPS(不间断电源)故障原因竟然是这样
    的头像 发表于 04-19 13:53 1361次阅读
    UPS(不间断电源)<b class='flag-5'>故障</b>频<b class='flag-5'>发</b>?<b class='flag-5'>原因</b>竟然是这样

    电机故障诊断常见误区的剖析

    纯分享帖,需要者可点击附件获取完整资料~~~*附件:电机故障诊断常见误区的剖析.pdf (免责声明:本文系网络转载,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请第一时间告知,删除内容!)
    发表于 04-07 17:35

    GD3162栅极驱动器WDOG故障原因?怎么解决?

    我对 WDOG 故障有一些担忧,这会导致我们的项目出现一些问题。 我们观察到,它发生在 Power-up 序列中,其中 LV 域在 HV 域之前上电。但是,当 HV 域首先通电时,故障不会发生
    发表于 03-31 06:12

    电网故障模拟发生装置的定义

    一、电网故障模拟发生装置的定义与核心价值 1. 装置本质 电网故障模拟发生装置(Power Grid Fault Simulator)是一种
    的头像 发表于 03-20 18:04 758次阅读

    无功补偿故障原因及解决方法

    无功补偿故障可能由多种原因引起,以下是一些常见的故障原因及其解决方法:
    的头像 发表于 01-29 14:25 2619次阅读

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

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