【Cortex-M3权威指南】学习笔记4 - 异常

目录

    • 实现 CM3
      • 流水线
      • CM3 详细框图
      • CM3 总线接口
      • 总线连接模板
    • 异常
      • 异常类型
      • 优先级定义
        • 优先级组
      • 向量表
      • 中断输入于挂起
        • NMI
        • 中断挂起
      • Fault 类异常
        • 总线 faults
        • 存储器管理 faults
        • 用法 faults
      • SVC 与 PendSV

实现 CM3


流水线

在这里插入图片描述

CM3 处理器使用 3 级流水线,分别是:取指,解码和执行

CM3 有时候会一次取出两个 16 位指令(合计 32 位指令),先处理一个然后等一个周期后再处理下一个

处于对 Thumb 兼容性考虑,取 PC 时,会返回当前指令地址+4 值

处理器内核预取单元有一个指令缓冲区,让后续执行的指令在这里排队


CM3 详细框图

在这里插入图片描述

缩写含义
NVIC嵌套向量中断控制器
SYSTICK Timer一个简易的周期定时器,用于提供时基,亦被操作系统所使用
MPU存储器保护单元(可选)
CM3BusMatrix内部的 AHB 互连
AHB to APB把 AHB 转换为 APB 的总线桥
SW-DP/SWJ-DP串行线调试端口/串行线 JTAG 调试端口。通过串行线调试协议或者是传统的 JTAG 协议(专用于 SWJ-DP),都可以用于实现与调试接口的连接
AHB-AP AHB访问端口,它把串行线/SWJ 接口的命令转换成 AHB 数据传送
ETM嵌入式跟踪宏单元(可选组件),调试用。 用于处理指令跟踪
DWT数据观察点及跟踪单元,调试用。这是一个处理数据观察点功能的模块
ITM仪器化跟踪宏单元
TPIU跟踪单元的接口单元。所有跟踪单元发出的调试信息都要先送给它,它再转发给外部跟踪捕获硬件的
FPB Flash地址重载及断点单元
ROM 表一个小的查找表,其中存储了配置信息

CM3 处理器中各个重要模块介绍:

  1. CM3Core:CPU
  2. NVIC:支持中断嵌套,向量中断机制可以在中断发生时,自动取出对应服务例程的入口地址
  3. SysTick 定时器:在 NVIC 内部实现,可以每隔一定时间产生中断,即便系统睡眠也可以工作
  4. 存储器保护单元:把存储器划分为多个区进行保护
  5. BusMatrix:CM3 总线核心,通过他让数据在不同总线间传输
  6. AHB to APB Bridge:总线桥,把多个 APB 设备连接到私有外设总线
  7. SW-DP/SWJ-DP:串行调试
  8. AHB-AP:无
  9. ETM 嵌入式跟踪宏单元:实时指令跟踪,
  10. DWT 数据观察点及跟踪单元:通过其设置数据观察点
  11. ITM 仪器化追踪宏单元:无
  12. FPB:提供 flash 地址重载与断点功能

CM3 总线接口

I-Code 总线 一条 32 位总线,进行取指操作

D-Code 总线 一条 32 位总线,进行数据访问操作,连接到该总线的设备不需要支持非对齐访问

系统总线 负责数据传送,他们都是对齐的

外部私有外设总线 基于 APB 协议的 32 为总线,负责私有外设访问

调试访问端口总线 专用于挂接调试接口


总线连接模板

在这里插入图片描述


异常


异常类型

编号为 1-15 的对应系统异常,大于等于 16 的则全是外部中断

中断不等于异常

15 个可用的系统异常表
在这里插入图片描述


优先级定义

优先级的数值越小,则优先级越高。
CM3 支持中断嵌套,使得高优先级异常会抢占(preempt)低优先级异常

三个特殊的系统异常:复位,NMI 以及硬 fault,它们有固定的优先级,并且它们的优先级号是负数,从而高于所有其它异常


CM3 还把 256 级优先级按位分成高低两段,分别称为抢占优先级和子优先级

NVIC 中有一个寄存器保存优先级组,他把优先级分为两段:
MSB 所在的位段对应抢占优先级; LSB 所在的位段对应子优先级


优先级组

CM3 支持 8 个不同的中断优先级,通常被分成 4 个优先级组

CM3 中断优先级组分配的四种主流方式:

Preemptive Priority Grouping (0 位抢占优先级组)
这种模式下,优先级分组被禁用,所有中断的优先级都是唯一的。优先级值高的中断总是可以打断正在执行的优先级值低的中断。这是最简单的中断优先级模式,但在复杂的应用中可能不够灵活。

No Preemptive Priority Grouping (4 位抢占优先级组)
这种模式下,中断被分为 4 个优先级组,每组内有 2 个优先级。每个组的中断不会互相打断,但是一个组内的高优先级中断可以打断低优先级中断。这提供了一定程度的分层和优先级控制。

Priority Grouping (3 位抢占优先级组)
这种模式下,中断被分为 8 个优先级组,每组内有 1 个优先级。这意味着每个中断都有唯一的优先级,没有中断会被其他中断完全屏蔽。这提供了更精细的优先级控制,但在复杂应用中可能需要更多的配置。

Priority Grouping (2 位抢占优先级组)
这种模式下,中断被分为 16 个优先级组,每组内有 1 个优先级。与上述模式相比,这种模式提供了更大的灵活性,但配置会更加复杂。


向量表

Cortex-M3 处理器使用中断向量表来管理不同中断的入口地址。
中断向量表是一个存储了中断处理程序地址的数组,每个元素对应一个特定的中断号。
当中断发生时,处理器会根据中断号从向量表中读取对应的地址,然后跳转到相应的中断处理程序。

中断向量表通常位于内存的起始地址处。向量表中的每个元素都是一个 4 字节(32 位)的地址,指向对应中断的处理程序

可以在 SRAM 中开出一块空间用于存储向量表


中断输入于挂起

NMI

NMI(Non-Maskable Interrupt,非屏蔽中断)是一种特殊类型的中断,在嵌入式系统中常用于处理一些紧急和重要的事件。与普通的可屏蔽中断不同,NMI 是无法被屏蔽或阻止的中断,即使处理器处于屏蔽中断状态(例如,全局中断被禁用),NMI 仍然可以触发。

当 NMI 发生时,处理器会跳转到 NMI 处理程序的入口地址执行相应的操作


中断挂起

在这里插入图片描述

中断输入脚置位有效后,他就被挂起,此时无法撤销中断请求
若在中断得到响应前消除挂起状态,则中断被取消

中断服务例程开始执行时,其挂起状态会被硬件自动清除

中断源一直维持中断请求信号,则该中断再完成一轮服务历程后又会被立刻赋予挂起状态进行下一轮
中断源以脉冲的形式发送 N 多个中断请求信号,最终只会接受一个


Fault 类异常

总线 faults

该 fault 可能产生的情况:

  1. 当 AHB 接口上正在传送数据时,回复了一个错误信号
  2. 在处理器启动中断服务序列(sequence)后读取向量时
  3. 中断处理起始阶段的堆栈 PUSH 动作
  4. 中断处理收尾阶段的堆栈 POP 动作

总线 fault 一旦检测到更高优先级异常,就会先执行后者,自己就挂起

总线 fault 是被某同级或更高优先级异常的服务例程引发的,则会变成硬 fault,使得最后执行的是硬 fault 的服务例程

欲使能总线 fault 服务例程前,总线 fault 服务例程的入口地址必须已经在向量表中配置好


总线 fault 状态寄存器(BFSR) 位于 NVIC 内部,可以找出产生 fault 的原因


存储器管理 faults

触发该 faults 的原因有如下四点:

  • 访问了所有 MPU regions 覆盖范围之外的地址
  • 访问了没有存储器与之对应的空地址
  • 往只读 region 写数据
  • 用户级下访问了只允许在特权级下访问的地址

MemManage fault 被除能,则会上访成硬 faults
若该硬 faults 执行时又导致了 MemManage fault,则内核被锁定

MemManage fault 必须被使能才能正常响应


用法 faults

用法 faults 一个重要的功能是:
执行了协处理器指令。Cortex-M3 本身并不支持协处理器,但是通过 fault 异常机制,可以建立一套“软件模拟”的机制,来执行一段程序模拟协处理器的功能

其余功能以及使能除能啥的情况和存储器 faults 基本一致,在这里不做过多介绍

导致用法 faults 最常见的原因是:视图切入 ARM 状态


SVC 与 PendSV

OS 不允许用户直接操作硬件,故出现了对应的桥梁 SVC(系统服务调用)

SVC 可以这样定义:
操作系统提供系统服务函数,用户通过 SVC 对这些函数发出请求,并以此来间接控制硬件


SVC 异常可以通过执行 SVC 指令来产生;
SVC 指令需要一个立即数,充当系统调用代号


PendSV 和 SVC 作用一致,只不过他可以被挂起

PendSV 异常处理程序通常会保存当前任务的上下文,并加载下一个任务的上下文,从而实现任务切换

PendSV 的任务优先级较低,故可以被许多高优先级例程打断


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/99783.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ERROR(IMPSP-365) innovus加endcap失败问题解析

我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧? 拾陆楼知识星球入口 ERROR(IMPSP-365):Design has inst with SITE (xx_site),but the floorplan has no rows defined for this site.Any location for such instance will …

jsch网页版ssh

使用依赖 implementation com.jcraft:jsch:0.1.55Server端代码 import com.jcraft.jsch.Channel; import com.jcraft.jsch.JSch; import com.jcraft.jsch.Session; import java.io.InputStream; import java.io.OutputStream; import java.util.concurrent.TimeUnit; import o…

【状态估计】基于UKF法、AUKF法、EUKF法电力系统三相状态估计研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

在k8s中用label控制Pod部署到指定的node上

案例-标注k8s-node1是配置了SSD的节点 kubectl label node k8s-node1 disktypessd 查看标记 测试 将pod部署到disktypessd的节点上(这里设置了k8s-node1为ssd) 部署后查看结果-副本全都运行在了k8s-node1上—符合预期 删除标记 kubectl label node k8…

Linux 进程基础概念-进程状态、进程构成、进程控制

Linux 进程 参考: 「linux操作系统」进程的切换与控制到底有啥关系? - 知乎 (zhihu.com),Linux进程解析_deep_explore的博客-CSDN博客,腾讯面试:进程的那些数据结构 - 知乎 (zhihu.com),如何在Linux下的进…

算法通过村第四关-栈黄金笔记|表达式问题

文章目录 前言1. 计算器问题2. 逆波兰表达式问题 总结 前言 提示:快乐的人没有过去,不快乐的人除了过去一无所有。 --理查德弗兰纳根《深入北方的小路》 栈的进阶来了,还记得栈的使用场景吗?表达式和符号,这不就来了 1…

【LeetCode-中等题】437. 路径总和 III

文章目录 题目方法一:迭代层序 每层节点dfs 维护一个count变量 题目 方法一:迭代层序 每层节点dfs 维护一个count变量 思路: 层序遍历每一个节点遍历一个节点就对这个节点进行dfsdfs的同时,维护一个count变量,并且…

ARDUINO STM32 SSD1306

STM32F103XX系列SPI接口位置 在ARUDINO 下,(不需要设置引脚功能,不需要开启时钟设置,ARDUINO已经帮我们处理了) stm32f103c6t6 flash不足,不足以运行U8G2,产生错误 改用U8X8,后将字体改为u8x8_…

Ubuntu 22.04安装 —— Win11 22H2

目录 Ubuntu使用下载UbuntuVmware 安装图示安装步骤图示 Ubuntu使用 系统环境: Windows 11 22H2Vmware 17 ProUbutun 22.04.3 Server Ubuntu Server documentation | Ubuntu 下载 Ubuntu 官网下载 建议安装长期支持版本 ——> 可以选择桌面版或服务器版(仅包…

基于侏儒猫鼬算法优化的BP神经网络(预测应用) - 附代码

基于侏儒猫鼬算法优化的BP神经网络(预测应用) - 附代码 文章目录 基于侏儒猫鼬算法优化的BP神经网络(预测应用) - 附代码1.数据介绍2.侏儒猫鼬优化BP神经网络2.1 BP神经网络参数设置2.2 侏儒猫鼬算法应用 4.测试结果:5…

基于JAVAEE技术的ssm校园车辆管理系统源码和论文

基于JAVAEE技术的ssm校园车辆管理系统源码和论文105 开发工具:idea 数据库mysql5.7 数据库链接工具:navcat,小海豚等 技术:ssm 1.选题背景和意义 背景: 随着第二次工业革命后,内燃机的发明与完善,解…

原生js实现轮播图及无缝滚动

我这里主要说轮播图和无缝滚动的实现思路,就采用最简单的轮播图了,当然实现的思路有很多种,我这也只是其中一种。 简单轮播图的大概结构是这样的,中间是图片,二边是箭头可以用来切换图片,下面的小圆点也可以…

three.js(九):内置的路径合成几何体

路径合成几何体 TubeGeometry 管道LatheGeometry 车削ExtrudeGeometry 挤压 TubeGeometry 管道 TubeGeometry(path : Curve, tubularSegments : Integer, radius : Float, radialSegments : Integer, closed : Boolean) path — Curve - 一个由基类Curve继承而来的3D路径。 De…

可控生成:ControlNet原理

🤗关注公众号funNLPer体验更佳阅读🤗 论文:Adding Conditional Control to Text-to-Image Diffusion Models 代码:lllyasviel/ControlNet 简单来说ControlNet希望通过输入额外条件来控制大型图像生成模型,使得图像生成模型根据可控。 文章目录 1. 动机2. ControlNet原理…

Hadoop依赖环境配置与安装部署

目录 什么是Hadoop?一、Hadoop依赖环境配置1.1 设置静态IP地址1.2 重启网络1.3 再克隆两台服务器1.4 修改主机名1.5 安装JDK1.6 配置环境变量1.7 关闭防火墙1.8 服务器之间互传资料1.9 做一个host印射1.10 免密传输 二、Hadoop安装部署2.1 解压hadoop的tar包2.2 切换…

让企业主们头疼的mkp勒索病毒,究竟有何来历,勒索病毒解密

mkp勒索病毒是一种比较常见的电脑病毒,它会对感染的电脑进行加密,并要求用户支付一定的赎金才能解锁。这种病毒已经引起了全球范围内的关注,因为它已经造成了严重的经济损失和电脑系统崩溃。 mkp勒索病毒是一种相对较新的病毒,但是…

集丰照明|汽车美容店设计,装修色彩灯光搭配方法

正确处理好店面的空间设计。 店铺各个功能区设计要合理,衔接合理,这样既能提高员工的工作效率也能提高顾客的满意度。合理安排店铺的空间分配, 要给顾客一种舒适度,既不能让顾客感觉到过于拥挤,又不能浪费店铺的有限空…

学习高级数据结构:探索平衡树与图的高级算法

文章目录 1. 平衡树:维护数据的平衡与高效性1.1 AVL 树:严格的平衡1.2 红黑树:近似平衡 2. 图的高级算法:建模复杂关系与优化2.1 最小生成树:寻找最优连接方式2.2 拓扑排序:解决依赖关系 拓展思考 &#x1…

【Unity】URP屏幕后处理UI模糊效果实现

这里Canvas(1)设置为Overlay能渲染出指定UI高清,其他UI模糊,然而这做法非常不好,如果此时再打开UI 以及 关闭模糊效果 要将这些置顶UI 恢复到原本Canvas里,也就是要管理2套Canvas using System; using System.Collections; using…

【仿写spring之ioc篇】二、bean生命周期中的创建以及属性赋值

扫描类 这个类就不多说了,基本所有框架都要有这一步,这里主要关注我们目前要实现的方法,其他的具体方法可以查看源码 isComponent方法 /*** 扫描所有带有Component注解的java类,放入到BeanRegistry** return boolean*/public bo…