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

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

3天内不再提示

深入 Cortex‐M3 的 Faults异常

jf_pJlTbmA9 来源:strongerHuang 作者:strongerHuang 2023-10-26 16:57 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

有许多朋友在学习,或者开发STM32时都遇到过HardFault_Handler的情况。

那么,又有多少人认真去分析过Fault这类异常中断呢?

下面结合STM32F1(Cortex‐M3内核)来给大家讲述一下这些异常中断的内容。

1、Cortex‐M3异常

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

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

CM3部分异常列表:

wKgaomUD62KAKMaUAAXH-xwCYp4794.jpg

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

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

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

wKgaomUD62SAAkDSAAGPyYwDWFQ381.jpg

向量表

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

2、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):

wKgZomUD62eABg0OAAOEOsCU1k8873.jpg

3、如何应对Fault错误异常

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

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

wKgZomUD62mAPSDwAAM8DVZWJ2w085.jpg

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

wKgaomUD62qAPNXxAAKnmahLJlE842.jpg

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

wKgaomUD62yAS4L3AADa1H0PGZI059.jpg

wKgZomUD62-Aa-qmAAUFc2roSjU927.jpg

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

wKgaomUD63CAJHiSAAKS3d148AQ557.jpg

常见应对Fault错误的方法:

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

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

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

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

来源:strongerHuang
免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理

审核编辑 黄宇

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

    关注

    68

    文章

    20148

    浏览量

    246935
  • STM32
    +关注

    关注

    2305

    文章

    11120

    浏览量

    371049
  • Cortex
    +关注

    关注

    2

    文章

    220

    浏览量

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    Cortex-M产品的特色

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

    为什么cortex-M0+功耗低?

    1. 流水线层级简化 Cortex-M0:采用 3级流水线(取指、解码、执行)。 更多流水线层级导致每个时钟周期需激活更多硬件单元,动态功耗较高。 流水线冲突(如分支预测错误)需刷新流水线,浪费
    发表于 11-19 08:15

    Cortex-M级别的转换

    一、 简述 Cortex-M 里面有特权级别的概念,不同级别可以设定不同的权限,如何转换特权级别基本是本章的内容。 二、操作模式 ARM M 核操作模式有两个: 线程(Thread)模式:在复位时或
    发表于 11-19 07:32

    Cortex-M0+处理器的HardFault错误介绍

    在ARM处理器中,如果一个程序产生了错误并且被处理器检测到,就会产生错误异常Cortex-M0+处理器只有一种异常用以处理错误:HardFault。
    的头像 发表于 10-14 10:50 2941次阅读
    <b class='flag-5'>Cortex-M</b>0+处理器的HardFault错误介绍

    高性能M3 系列 MCU,灵活对应多元应用,高效赋能未来

    高性能M3 系列 MCU,灵活对应多元应用,高效赋能未来 高性能M3系列 随着消费电子等产业升级,产品功能越发先进,对MCU的性能要求在不断提升,比如新能源应用中的充电桩产品,会需要MCU带有
    发表于 07-21 19:10

    ADuCM362集成双通道Σ-Δ型ADC和ARM Cortex-M3的低功耗精密模拟微控制器技术手册

    ADuCM362/[ADuCM363]是完全集成的3.9 kSPS、24位数据采集系统,在单芯片上集成双核高性能多通道Σ-Δ型模数转换器(ADC)、32位ARM Cortex™-M3处理器
    的头像 发表于 05-08 18:20 863次阅读
    ADuCM362集成双通道Σ-Δ型ADC和ARM <b class='flag-5'>Cortex-M3</b>的低功耗精密模拟微控制器技术手册

    ADuCM3027/ADuCM3029集成电源管理和128Kb嵌入式闪存的超低功耗ARM Cortex-M3 MCU技术手册

    ADuCM3027/ADuCM3029 微控制器单元(MCU)均为集成电源管理的超低功耗微控制器系统,可用于处理、控制和连接。MCU系统基于ARM^®^ Cortex ^®^ -M3处理器,由数字
    的头像 发表于 05-08 17:15 705次阅读
    ADuCM3027/ADuCM3029集成电源管理和128Kb嵌入式闪存的超低功耗ARM <b class='flag-5'>Cortex-M3</b> MCU技术手册

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

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

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

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

    瑞芯微RK3506(3核ARM+Cortex-A7 + ARM Cortex-M0)工业核心板选型资料

    创龙科技SOM-TL3506是一款基于瑞芯微RK3506J/RK3506B处理器设计的3核ARM Cortex-A7 + ARM Cortex-M0全国产工业核心板,主频高达1.5GHz。核心板CPU、ROM、RAM、电源、晶振
    的头像 发表于 04-09 09:04 2899次阅读
    瑞芯微RK3506(<b class='flag-5'>3</b>核ARM+<b class='flag-5'>Cortex</b>-A7 + ARM <b class='flag-5'>Cortex-M</b>0)工业核心板选型资料

    M3 Ultra 苹果最强芯片 80 核 GPU,32 核 NPU

    苹果最新发布的 M3 Ultra 芯片的核心信息与技术亮点总结,结合其性能表现、技术革新及市场定位进行综合分析:一、性能突破与架构升级性能提升幅度CPU性能 :M3 Ultra 采用 32 核
    的头像 发表于 03-10 10:42 4276次阅读
    <b class='flag-5'>M3</b> Ultra 苹果最强芯片 80 核 GPU,32 核 NPU

    LM5175的四开关管升降压开关电源,导出的原理图中有六个开关管,为什么M3M4各自需要并联一个一样的开关管呢?

    就是我利用TI上导出关于LM5175芯片的四开关管升降压开关电源,导出的原理图中有六个开关管,我想知道为什么M3M4各自需要并联一个一样的开关管呢?
    发表于 02-26 08:24

    M3 - RK3588 主板,性能界的超级巨星!

    处理器),给 M3 - RK3588 主板装上了超级大脑?。在智能识别方面,人脸识别门禁系统里,它能快速又精准地识别人员身份,智能安防监控中,异常行为也逃不过它的 “法眼”,运算速度超快,结果马上就出来
    发表于 02-18 11:54

    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指令集技术用户手册