Cortex-M7核心寄存器

参考内容:Cortex-M7编程手册

文章目录

  • 软件执行的处理器模式和权限级别
    • 处理器模式
    • 软件执行的权限级别
  • 栈Stacks
  • 核心寄存器Core registers
    • 通用寄存器General-purpose registers
    • 链接寄存器Link register
    • 程序计数器 Program counter
    • 程序状态寄存器Program status register
    • 应用程序状态寄存器Application program status register(APSR)
    • 中断程序状态寄存器 Interrupt program status register(IPSR)
    • 执行程序状态寄存器Execution program status register(EPSR)
    • 优先级掩码寄存器Priority mask register(PRIMASK )
    • 故障掩码寄存器Fault mask register(FAULTMASK)
    • 基本优先级掩码寄存器Base priority mask register(BASEPRI)
    • 控制寄存器CONTROL register


软件执行的处理器模式和权限级别

Processor mode and privilege levels for software execution

处理器模式

线程模式Thread mode:执行应用程序软件。处理器在 reset 中退出时进入 Thread 模式。

异常模式Handler mode:处理异常。处理器在完成所有异常处理后返回到 Thread 模式。

软件执行的权限级别

非特权Unprivileged
• 使用 MSR 和 MRS 指令对系统寄存器的访问受到限制,并且不能使用 CPS 指令来屏蔽中断。
• 无法访问系统计时器、NVIC 或系统控制块。
• 可能限制了对内存或外围设备的访问。
非特权软件在非特权级别执行。

特权Privileged:该软件可以使用所有指令并可以访问所有资源。特权软件在特权级别执行。

在 Thread 模式下,CONTROL 寄存器决定软件执行是特权还是无特权。
在这里插入图片描述
在这里插入图片描述

在 Handler 模式下,软件执行始终具有特权

只有特权软件才能写入 CONTROL 寄存器,以更改在 Thread 模式下执行软件的权限级别。非特权软件可以使用 SVC 指令进行监督程序调用,以将控制权转移给特权软件


栈Stacks

处理器使用完整的降序栈。
处理器实现了两个栈,主栈和进程栈,每个栈都有一个指针保存在独立的寄存器中,就是有两个栈指针MSP和PSP

堆栈指针 (SP) 是寄存器 R13
在 Thread 模式下,CONTROL 寄存器的 bit[1] 表示要使用的堆栈指针:
• 0 = 主堆栈指针 (MSP)。这是复位值。
• 1 = 进程堆栈指针 (PSP)
复位时,处理器使用地址 0x00000000 的值加载 MSP

在 Thread 模式下,CONTROL 寄存器决定处理器是使用主堆栈还是进程堆栈
在这里插入图片描述
在这里插入图片描述

在 Handler 模式下,处理器始终使用主堆栈。

在这里插入图片描述

总结:

处理器模式用于特权等级使用栈指针
线程模式应用程序特权或非特权MSP或PSP
异常模式异常中断特权MSP

核心寄存器Core registers

在这里插入图片描述

通用寄存器General-purpose registers

R0-R12 是用于数据操作的 32 位通用寄存器
R0到R7称为低组寄存器,R8到R12为高组寄存器

链接寄存器Link register

链接寄存器 (LR) 是寄存器 R14。
它存储子例程、函数调用和异常的返回信息。
重置时,处理器将 LR 值设置为 0xFFFFFFFF

程序计数器 Program counter

程序计数器 (PC) 是寄存器 R15。
它包含当前的程序地址。在 reset 时,处理器加载 PC为 reset 向量的值,该值位于地址 0x00000004
该值的 Bit[0] 在 reset 时加载到 EPSR T 位中,并且必须为 1

程序状态寄存器Program status register

程序状态寄存器 (PSR) 包括:
• 应用程序程序状态寄存器 (APSR)
• 中断程序状态寄存器 (IPSR)
• 执行程序状态寄存器 (EPSR)

这些寄存器是 32 位 PSR 中互斥的位字段,如下
在这里插入图片描述

使用寄存器名称作为 MSR 或 MRS 指令的参数,单独访问这些寄存器或作为任意两个或所有三个寄存器的组合访问这些寄存器。比如:

  • 使用 PSR 和 MRS 指令读取所有 registers
  • 使用 APSR_nzcvq 和 MSR 指令写入 APSR N、Z、C、V 和 Q 位
    在这里插入图片描述

应用程序状态寄存器Application program status register(APSR)

APSR用于存储与当前程序执行状态有关的信息。该寄存器包含多个标志位,用于指示程序的执行状态
在这里插入图片描述

中断程序状态寄存器 Interrupt program status register(IPSR)

IPSR 包含当前中断服务程序 (ISR) 的异常类型编号
在这里插入图片描述

执行程序状态寄存器Execution program status register(EPSR)

EPSR 包含 Thumb 状态位和以下任一指令的执行状态位:
• If-Then (IT) 指令
• 可中断 - 连续指令 (ICI) 字段
在这里插入图片描述
使用 MSR 指令通过应用程序软件直接读取 EPSR 的尝试始终返回零。
在应用程序软件中使用 MSR 指令写入 EPSR 的尝试将被忽略。

可中断 - 可连续指令 Interruptible-continuable instructions
当 LDM、STM、PUSH、POP、VLDM、VSTM、VPUSH 或 VPOP 指令执行过程中发生中断时,处理器:
• 暂时停止加载多个指令或存储多个指令操作。
• 将多运算中的下一个寄存器操作数存储到 EPSR 位 [15:12]。
在处理中断后,处理器:
• 返回到 bits[15:12] 指向的寄存器。
• 恢复执行多重加载或存储指令。
当 EPSR 保持 ICI 执行状态时,位 [26:25,11:10] 为零

If-Then block
If-Then 块最多包含一条 IT 指令之后的四条指令。块中的每个指令都是有条件的。指令的条件要么全部相同,要么有些条件与其他条件相反

Thumb state
Cortex-M7处理器仅支持在 Thumb 状态下执行指令。
以下可以将 T 位清零:
• 指令 BLX、BX 和 POP{PC}
• 在异常返回时从堆叠的 xPSR 值恢复
• 异常entry或复位时向量值的 Bit[0]
尝试在 T 位为 0 时执行指令会导致故障或锁定

优先级掩码寄存器Priority mask register(PRIMASK )

PRIMASK 寄存器可屏蔽具有可配置优先级的所有异常
在这里插入图片描述

故障掩码寄存器Fault mask register(FAULTMASK)

FAULTMASK 寄存器可屏蔽除不可屏蔽中断 (NMI) 之外的所有异常。
就是除了NMI中断,其他中断都可以屏蔽,包括硬件错误HardFault
在这里插入图片描述

处理器在退出除 NMI 处理程序之外的任何异常处理程序时将 FAULTMASK 位清除为 0,就是退出中断时,FAULTMASK会被清0

基本优先级掩码寄存器Base priority mask register(BASEPRI)

BASEPRI 寄存器定义异常处理的最低优先级。当 BASEPRI 设置为非零值时,它会屏蔽与 BASEPRI 值具有相同或更低优先级的所有异常
在这里插入图片描述

控制寄存器CONTROL register

当处理器处于 Thread 模式时,CONTROL 寄存器控制使用的堆栈和软件执行的权限级别,并指示 FPU 状态是否处于活动状态
在这里插入图片描述
在这里插入图片描述

  • FPCA :此位用于确定在处理异常时是否保留浮点状态
  • SPSEL:定义当前有效栈指针
  • nPRIV:定义线程模式特权等级

Handler 模式始终使用 MSP,因此在 Handler 模式下,处理器会忽略对 CONTROL 寄存器的 active stack pointer bit 的显式写入。

异常输入和返回机制根据 EXC_RETURN自动更新 CONTROL 寄存器

在 OS 环境中,Arm 建议在 Thread 模式下运行的线程使用进程堆栈,内核和异常处理程序使用主堆栈

默认情况下,线程模式使用 MSP。要将线程模式中使用的堆栈指针切换到 PSP,请执行以下任一操作:

  • 使用 MSR 指令设置 CONTROL 寄存器的SPSEL位 置为 1
  • 使用适当的EXC_RETURN 值执行异常返回线程模式

更改堆栈指针时,软件必须在 MSR 指令之后立即使用 ISB 指令。这可确保 ISB 指令之后的指令使用新的堆栈指针执行

EXC_RETURN
在这里插入图片描述

EXC_RETURN描述
0xFFFFFFF1返回到 Handler 模式,异常返回使用 MSP 中的非浮点状态,返回后执行使用 MSP
0xFFFFFFF9返回到 Thread 模式,异常返回使用 MSP 中的非浮点状态,返回后执行使用 MSP
0xFFFFFFFD返回到 Thread 模式,异常返回使用 PSP 中的非浮点状态,返回后执行使用 PSP
0xFFFFFFE1返回到 Handler 模式,异常返回使用 MSP 中的浮点状态,返回后执行使用 MSP
0xFFFFFFE9返回到 Thread 模式,异常返回使用 MSP 中的浮点状态,返回后执行使用 MSP
0xFFFFFFED返回到Thread 模式,异常返回使用 PSP 中的浮点状态,返回后执行使用 PSP

在FreeRTOS中,是通过EXC_RETURN 将刚开始时堆栈指针MSP变为PSP的,将0xfffffffd先压入栈,伪造现场,在SVC中断中恢复现场,则将0xfffffffd赋值给了R14寄存器,然后跳转bx r14,就从MSP → PSP

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

18.1 k8s服务组件之4大黄金指标讲解

本节重点介绍 : 监控4大黄金指标 Latency:延时Utilization:使用率Saturation:饱和度Errors:错误数或错误率 apiserver指标 400、500错误qps访问延迟队列深度 etcd指标kube-scheduler和kube-controller-manager 监控4大黄金指标 …

PHPMailer在PHP5.3.3以下版本的使用详解

《PHPMailer在PHP5.3.3以下版本的使用详解》 PHPMailer是一款广泛使用的PHP邮件发送类库,它提供了一套完整的邮件发送解决方案,包括SMTP验证、HTML邮件支持等功能。在PHP5.3.3及以下版本的环境中,由于语言特性和库的限制,选择适合…

【学习笔记】TLS/SSL握手

前言:本篇将介绍TLS握手的实际握手过程,TLS握手创建了Client和Server之间“被保护的通道”,2个单向通道用来保护批量数据的传输(通过Confidentiality、Integrity和Authentication),一个通道是从Client到Ser…

辞职后你说你想去外面玩玩,我看你寸步未行,原来你是去了JDK以外的方面玩玩

按需阅读 兄弟们!我被面试官吊打了Java面试Question A:如果距离世界末日只剩一天你能干什么?面试官:世界末日前我想看视频面试官:给点创意好不好?面试官:如果有一天我想换个姿势看图片 Java面试…

C++基础:第一个C++程序

初学C #include<iostream> int main() {std::cout << "Enter two numbers:" << std::endl;int v1 0, v2 0;std::cin >> v1 >> v2;std::cout << "The sum of "<< v1 << " and " << v2&…

string和oj题以及vector的接口介绍

前言 上篇博客学习了一些string类的模拟实现erase、find、substr、比较大小、流输入、流输出&#xff0c;这篇博客将介绍剩下的一些string的知识以及vector的一些使用方式。 string 传统深拷贝的写法 //拷贝构造 string(const string& s) {_str new char[s._capacity …

1.4 边界值分析法

欢迎大家订阅【软件测试】 专栏&#xff0c;开启你的软件测试学习之旅&#xff01; 文章目录 前言1 定义2 选取3 具体步骤4 案例分析 本篇文章参考黑马程序员 前言 边界值分析法是一种广泛应用于软件测试中的技术&#xff0c;旨在识别输入值范围内的潜在缺陷。本文将详细探讨…

【Linux】深度解析与实战应用:GCC/G++编译器入门指南

&#x1f525; 个人主页&#xff1a;大耳朵土土垚 &#x1f525; 所属专栏&#xff1a;Linux系统编程 这里将会不定期更新有关Linux的内容&#xff0c;欢迎大家点赞&#xff0c;收藏&#xff0c;评论&#x1f973;&#x1f973;&#x1f389;&#x1f389;&#x1f389; 文章目…

Mysql—主从复制的slave添加及延迟回放

MySQL 主从复制是什么&#xff1f; ​ MySQL 主从复制是指数据可以从一个 MySQL 数据库服务器主节点复制到一个或多个从节点。MySQL 默认采用异步复制方式&#xff0c;这样从节点不用一直访问主服务器来更新自己的数据&#xff0c;数据的更新可以在远程连接上进行&#xff0c;…

滑动窗口专题

通过以下几道题来熟悉滑动窗口 滑动窗口3大问题&#xff1a;如何移入窗口&#xff0c;如何移出窗口&#xff0c;如何更新答案 209. 长度最小的子数组 我们考虑通过窗口来计算和&#xff0c;快慢指针从左开始遍历。 移入窗口&#xff1a;直接把当前元素加进来。 移出窗口&am…

重大喜讯!科研界之大变革——“5分钟提交+24小时反馈”,投稿效率直线上升!

盘点允许“一稿多投”的SCI “一稿多投”一直被认为是学术不端的行为&#xff0c;但“禁止一稿多投”是纸质时代遗留下的产物&#xff0c;已不符合当今社会的发展。 一篇文章一审就是好几个月甚至是一两年&#xff0c;在科研圈子里都是平常事&#xff0c;每个科研人都曾深陷于…

乐道L60、MONA M03、理想L6,蔚小理围剿「特斯拉」

作者 |老缅 编辑 |德新 9月19日&#xff0c;蔚来全新品牌乐道首款车型——乐道L60正式上市&#xff0c;定位家庭智能电动SUV。 60kWh标准续航版&#xff0c;售价20.69万元85kWh长续航版&#xff0c;售价23.59万元&#xff1b;如果采用BaaS电池租用服务&#xff0c;则低至14.9…

如何在云端使用 Browserless 进行网页抓取?

云浏览器是什么&#xff1f; 云浏览器是一种基于云的组合&#xff0c;它将网页浏览器应用程序与一个虚拟化的容器相结合&#xff0c;实现了远程浏览器隔离的概念。开发人员可以使用流行的工具&#xff08;如 Playwright 和​ Puppeteer​&#xff09;来自动化网页浏览器&#…

cmake--list

教程 list--链接 list关键字的作用 list的操作 list追加字符串--APPEND set(str1 "aaaaaaaa") message(STATUS "str1${str1}") list(APPEND str1 "bbbb") message(STATUS "str1${str1}") list字符串拼接并不是直接拼接&#xff0c…

C# 用Timer控件简单写一个倒计时60s功能

先放界面上一个Label和一个Timer控件&#xff0c;Label用来展示倒计时秒数 添加事件 设置属性&#xff0c;设置每隔一秒执行一次 放代码&#xff1a; //设置时间控件开始运行&#xff0c;具体放在哪里看具体需求 this.timer1.Start();//定义一个全局变量表示秒数 int time…

在线版宣传册是如何制作的

​亲爱的创作者们&#xff0c;你是否想过将传统的纸质宣传册升级为更具吸引力的在线版&#xff1f;在这个数字化时代&#xff0c;在线版宣传册不仅能够节省印刷成本&#xff0c;还能让信息传递更加迅速、精准。今天&#xff0c;就让我们一起探索在线版宣传册的制作奥秘吧&#…

利用Mongoose库实现MQTT通信

Mongoose官方Github地址 官方对于Mongoose的简介&#xff1a; Mongoose - Embedded Web Server / Embedded Network Library Mongoose is a network library for C/C. It provides event-driven non-blocking APIs for TCP, UDP, HTTP, WebSocket, MQTT, and other protocol…

【吉林一号卫星简介】

吉林一号卫星 吉林一号卫星是中国长光卫星技术有限公司研制的遥感卫星&#xff0c;也是该公司在建的核心工程&#xff0c;是中国重要的光学遥感卫星星座。以下是对吉林一号卫星的详细介绍&#xff1a; 一、卫星概况 中文名&#xff1a;吉林一号外文名&#xff1a;Jilin 1 Bus…

视频汇聚EasyCVR视频监控平台调取接口提示“认证过期”是什么原因?

视频汇聚EasyCVR视频监控平台&#xff0c;作为一款智能视频监控综合管理平台&#xff0c;凭借其强大的视频融合汇聚能力和灵活的视频能力&#xff0c;在各行各业的应用中发挥着越来越重要的作用。EasyCVR平台具备强大的拓展性和灵活性&#xff0c;支持多种视频流的外部分发&…

丝杆支撑座许用条件的解析

丝杆支撑座连接滚珠丝杆使用能够支撑滚珠丝杆&#xff0c;使之更加平稳的运动&#xff0c;显著提高传动效率、降低噪音、提高精度、延长使用寿命等优势&#xff0c;是自动化设备中重要的传动元件。影响丝杆支撑座的因素主要包括轴承类型、润滑脂的使用、密封圈的保护、使用环境…