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

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

3天内不再提示

谈谈STM32(CM3)的Faults异常

黄工的嵌入式技术圈 来源:黄工的嵌入式技术圈 2020-03-06 15:46 次阅读

看着有儿童节、妇女节这种节日,你们是不是也想有一个程序员的专属节呢?

想过节,做一下梦就好了,还是乖乖加班,把今天的代码敲完,不然又得扣绩效工资啦。

1写在前面

回归现实,本文带领大家学习下STM32中Fault的一些相关知识。

应该有许多朋友在学习,或者开发时遇到过程序进入HardFault_Handler的情况。

那么,你们有多少人认真去分析过Fault这类异常中断呢?下面结合STM32F103,也就是Cortex‐M3内核来给大家讲述一下这些异常中断的内容。

2

Cortex‐M3异常

说起Fault,我们就要说一下Cortex‐M3的异常。

Cortex‐M3 在内核水平上搭载了一个异常响应系统, 支持为数众多的系统异常和外部中断。

CM3部分异常列表:

这些异常中断的优先级,有些却是固定的,有些是可以通过软件来配置,如UART发送中断、DMA中断等。

相信大家看到这个列表不会陌生,因为在STM32的启动代码,中断代码中都会看到这些异常。

比如在stm32f10x_it.c文件中,就能看到HardFault_Handler这类Fault异常。

向量表

当发生了异常并且要响应它时, CM3 需要定位其处理例程的入口地址。这些入口地址存储在“(异常)向量表”中。而我们的中断函数就对应有一个入口地址。

3

Fault错误异常

在Cortex‐M3中的Fault这种错误异常有:BusFault总线错误、MemManageFault存储器管理错误、UsageFault用法错误、HardFault硬错误。

1.BusFault总线错误

当 AHB 接口上正在传送数据时,如果回复了一个错误信号,则会产生总线错误。

产生的场合可以是:

取指,通常被称作“预取流产”(prefetch abort)

数据读/写,通常被称作“数据流产”(data abort)

执行如下动作可以触发总线异常:

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

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

处理器启动中断处理序列(sequence)后的向量读取时。这是一种罕见的特殊情况,被归类为硬错误。

总线错误诱因:

企图访问无效的存储器 region。常见于访问的地址没有相对应的存储器。

设备还没有作好传送数据的准备。比如,在尚未初始化 SDRAM 控制器的时候试图访问 SDRAM。

在企图启动一次数据传送时,传送的尺寸不能为目标设备所支持。例如,某设备只接受字型数据,却试图送给它字节型数据。

因为某些原因,设备不能接受数据传送。例如,某些设备只有在特权级下才允许访问,可当前却是用户级。

2.MemManageFault存储器管理错误

存储器管理错误多与MPU(内存保护单元)有关,其诱因常常是某次访问触犯了MPU设置的保护策略。

常见诱因:

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

往只读 region 写数据

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

在CM3手册中有这样一段话:

在 MemManage fault 发生后,如果其服务例程是使能的,则执行服务例程。如果同时还发生了其它高优先级异常,则优先处理这些高优先级的异常, MemManage 异常被悬起。

如果此时处理器已经在处理同级或高优先级异常,或者 MemManage fault 服务例程被除能,则和总线 fault 一样:上访成硬 fault,最终执行的是硬 fault 的服务例程。

当我们程序内存访问越界,我们会发现,程序会进入HardFault_Handler中断服务程序。可以结合上面那一段话理解一下。

3.UsageFault用法错误

用法错误发生的诱因:

执行了未定义的指令

执行了协处理器指令(Cortex‐M3 不支持协处理器,但是可以通过 fault 异常机制来使用软件模拟协处理器的功能,从而可以方便地在其它 Cortex 处理器间移植)

尝试进入 ARM 状态(因为 CM3 不支持 ARM 状态,所以用法 fault 会在切换时产生。软件可以利用此机制来测试某处理器是否支持 ARM 状态)

无效的中断返回(LR 中包含了无效/错误的值)

使用多重加载/存储指令时,地址没有对齐。另外,通过设置 NVIC 的对应控制位,可以在下列场合下也产生用法 fault:

除数为零

任何未对齐的访问


4.HardFault硬错误

HardFault硬错误是上面说的三种错误“上访”的结果。如果这些fault错误的服务例程无法执行,它们就会成为“硬伤”——上访(escalation)成HardFault硬错误。

在NVIC 中有一个HardFault硬错误状态寄存器(HFSR),它指出产生HardFault硬错误的原因。

状态寄存器(HFSR):

4

如何应对Fault错误异常

在软件开发过程中,我们可以根据各种 fault错误 状态寄存器的值来判定程序错误,并且改正它们。下面给出了各种 faults 的常见诱因,以及应对攻略。

MemManage fault 状态寄存器提供的讯息:

总线 fault 状态寄存器提供的讯息:

用法 fault 状态寄存器提供的讯息:

硬 fault 状态寄存器提供的讯息:

常用应付Fault错误的方法:

1.恢复:在一些场合下,还是有希望解决产生 fault 的问题的。例如,如果程序尝试访问了协处理器,可以通过一个协处理器的软件模拟器来解决此问题——当然是以牺牲性能为代价的,要不然还要硬件加速干啥。

2.中止相关任务:如果系统运行了一个 RTOS,则相关的任务可以被终结或者重新开始。

3.复位:这也是最后一招。通过设置 NVIC“应用程序中断及复位控制寄存器”中的VECTRESET 位,将只复位处理器内核而不复位其它片上设施。取决于芯片的复位设计,有些CM3 芯片可以使用该寄存器的 SYSRESETREQ 位来复位。这种只限于内核中的复位不会复位其它系统部件。

当然,说了这么多,我们还是要从根源出发,平时保持良好的编程习惯,以及遵循必要的编程规范。

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

    关注

    2239

    文章

    10671

    浏览量

    348735
  • Cortex
    +关注

    关注

    2

    文章

    194

    浏览量

    45743
  • Fault
    +关注

    关注

    0

    文章

    4

    浏览量

    7243
收藏 人收藏

    评论

    相关推荐

    STM32、ESP8266与MQTT连接阿里云物联网的串口通信异常解析

    阿里云物联网平台的过程中,串口通信异常成为了一个常见的挑战。本文将探讨这些异常现象及其可能的原因,并给出相应的解决方案。 首先,我们来谈谈STM32与ESP8266之间的串口通信问题。
    的头像 发表于 04-19 17:19 163次阅读

    如何处理STM32的HAL库函数返回异常问题?

    STM32运行死机了,是很可能可以在这种 库函数运行返回值不是 HAL_OK 中进行故障定位的。 (3)问题是 一旦出现了这种返回值异常的错误,记录在哪里比较好?芯片自带FLASH区域?EEPROM?在
    发表于 04-17 06:39

    STM32F407ZG MCU控制器偶尔会出现异常复位,为什么?

    我这边用了STM32F407ZG MCU, 发现控制器偶尔会出现异常复位。 程序使用了独立看门狗,没有使用窗口看门狗。通过监控RCC->CSR, 发现异常复位时以下位置1: .位29
    发表于 04-01 07:13

    电导率单位ms/cm和us/cm怎么换算

    电导率是描述电解质溶液中离子传导能力的物理量。常用的电导率单位有毫西/厘米(ms/cm)和微西/厘米(us/cm)。要将毫西/厘米(ms/cm)转换为微西/厘米(us/cm),需要乘以
    的头像 发表于 01-25 15:52 8860次阅读

    谈谈数字验证场景的“边界”和“异常

    在IC验证者进行测试点评审的时候,或者在和DE(数字设计工程师)、SE(系统工程师)进行验证场景讨论的时候,常常会听到“边界”“异常”这俩词。他俩就像是一对形影不离的好朋友,同时出现在验证者的耳畔和DE、SE的嘴边。
    的头像 发表于 01-23 13:43 219次阅读

    ADSP-CM402F/ADSP-CM403F/ADSPCM407F/ADSP-CM408F SINC滤波器的主要特性

    电子发烧友网站提供《ADSP-CM402F/ADSP-CM403F/ADSPCM407F/ADSP-CM408F SINC滤波器的主要特性.pdf》资料免费下载
    发表于 11-29 09:28 0次下载
    ADSP-<b class='flag-5'>CM</b>402F/ADSP-<b class='flag-5'>CM</b>403F/ADSPCM407F/ADSP-<b class='flag-5'>CM</b>408F SINC滤波器的主要特性

    深入 Cortex‐M3 的 Faults异常

    深入 Cortex‐M3 的 Faults异常
    的头像 发表于 10-26 16:57 317次阅读
    深入 Cortex‐M3 的 <b class='flag-5'>Faults</b><b class='flag-5'>异常</b>

    Cortex-M3权威指南

    了!由于采用了最新的设计技术,它的门数更低,性能却更强。许多曾经只能求助于高级32位处理器或DSP的软件设计,都能在CM3上跑得很快很欢。嵌入式处理器市场正在32位化,相信用不了多久,CM3就一定
    发表于 09-28 06:32

    STM32 Bootloader异常复位案例

    电子发烧友网站提供《STM32 Bootloader异常复位案例.pdf》资料免费下载
    发表于 09-25 09:17 3次下载
    <b class='flag-5'>STM32</b> Bootloader<b class='flag-5'>异常</b>复位案例

    STM32H7双核CM4作为Master初始化系统

    电子发烧友网站提供《STM32H7双核CM4作为Master初始化系统.pdf》资料免费下载
    发表于 09-20 09:13 0次下载
    <b class='flag-5'>STM32</b>H7双核<b class='flag-5'>CM</b>4作为Master初始化系统

    CM3权威指南CnR2

    发表于 08-30 16:10 0次下载
    <b class='flag-5'>CM3</b>权威指南CnR2

    谈谈SiC MOSFET的短路能力

    谈谈SiC MOSFET的短路能力
    的头像 发表于 08-25 08:16 1174次阅读
    <b class='flag-5'>谈谈</b>SiC MOSFET的短路能力

    STM32单片机的应用笔记 奇怪的NRST 管脚异常复位问题

    做EMS 浪涌测试的时候发生的, 平台上使用了一个 STM32G474 RCT6 MCU 。 在某个等级的EMS 测试中, 客户发现MCU有时候会异常复 位而影响平台的稳定 工作。 2.1. MCU
    的头像 发表于 07-13 18:55 7551次阅读
    <b class='flag-5'>STM32</b>单片机的应用笔记 奇怪的NRST 管脚<b class='flag-5'>异常</b>复位问题

    织物负离子发生量测试仪、纺织品负离子测试仪主要特点

    负离子发生量的检测和评价》 技术参数:  1、电容式吸入法收集空气离子,收集离子迁移率大于0.15 (cm2/v·s)的离子  2、测量范围:量程1: 0~20,000 个/cm3;量程
    的头像 发表于 06-28 11:37 302次阅读
    织物负离子发生量测试仪、纺织品负离子测试仪主要特点

    RT1170 EVK CM7核心卡在0x223104怎么解决?

    中的其他主题来看,这看起来像启用了调试的设计? 2) 之后启动CM4核心 3CM7出现异常 我试图从论坛上获得答案,看起来我是迄今为止 EVK 板上唯一遇到此类问题的人。 我也尝
    发表于 05-18 07:22