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

    文章

    5343

    浏览量

    120350
  • 数据
    +关注

    关注

    8

    文章

    7026

    浏览量

    89031
  • 代码
    +关注

    关注

    30

    文章

    4788

    浏览量

    68606
  • 编译器
    +关注

    关注

    1

    文章

    1634

    浏览量

    49130

原文标题:Cortex-M3发生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-23 15:52 167次阅读

    TAS6421-Q1产生负载短路故障,功放fault脚不置位是怎么回事?

    产生负载短路故障,检测到AMP fault脚拉低,读取0x0C, 0x0D寄存器确认故障类型后,操作0x21寄存器清除
    发表于 10-09 06:04

    基于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>单片机研发的国产指纹芯片 - P1032BF1

    变频器故障类型产生原因详解

    、输出电路和驱动电路等构成,主要完成对逆变器的开关控制、对整流器的电压控制及完成各种保护功能,也是经常出故障的环节。   一、故障类型   当变频器不能正常工作时就可能发生
    的头像 发表于 06-14 09:45 538次阅读

    变频器故障类型产生原因详解

    变频器作为现代工业自动化控制中的核心设备,其稳定运行对于生产效率和设备安全至关重要。然而,由于工作环境、操作方式、设备质量等多种因素的影响,变频器在运行过程中可能会出现各种故障。本文将对变频器的故障类型
    的头像 发表于 06-11 11:52 962次阅读

    函数信号发生器的常见故障原因分析

    的应用价值。然而,随着使用时间的增长,函数信号发生器可能会出现各种故障,影响其正常工作。本文将对函数信号发生器进行详细介绍,并分析其常见故障原因
    的头像 发表于 05-10 16:13 1459次阅读

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

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

    SDK5.2产生的F103+IHM07M1可以跑了,但是FOC Duration Fault,为什么?

    经过对比测试,发现SDK产生的F103代码,不仅ADC_FLAG_JEOC定义有错。 EN1/2/3的信号一直为低,电机完全不转。 修改EN1、2、3的GPIO配置,输出高。电机可以转了,但是转了几秒钟,就停了。 请问, 是可
    发表于 04-22 07:38

    STM32F103VE添加DSP库报错ld.exe: cannot find -l-mcpu=cortex-m3是什么原因呢?

    使用STM32F103VE芯片,在STM32cubeide里添加DSP库后,编译报错ld.exe: cannot find -l-mcpu=cortex-m3,请问是什么原因呢?文件目录以及配置如下
    发表于 03-15 08:14

    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次阅读

    光缆故障的主要产生原因及解决方案

    光缆故障的主要产生原因及解决方案 光缆是现代通信领域中重要的传输介质,其稳定可靠的运行对于现代社会的信息传输和通信起着至关重要的作用。然而,光缆在使用过程中,也存在着各种故障问题,这些
    的头像 发表于 02-04 10:11 4481次阅读

    强大的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>内核(下)

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

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