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.mfbz.cn/a/882653.html

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

相关文章

PMP--二模--解题--91-100

文章目录 14.敏捷91、 [单选] 在敏捷团队完成三次迭代之后,项目经理确定团队在这三次迭代中的平均速度是30个故事点。还有292个故事点来完成项目的剩余部分。团队需要多少次额外的迭代才能完成项目? 9.资源管理92、 [单选] 项目经理前往另一个国家执行最…

python yield用法

1 yield关键字 yield在函数中的功能类似于return,不同的是yield每次返回结果之后函数并没有退出,而是 每次遇到yield关键字后返回相应结果,并保留函数当前的运行状态,等待下一次的调用。如果 一个函数需要多次循环执行一个动作&am…

【自动驾驶】控制算法(九)深度解析车辆纵向控制 | 从算法基础到 Carsim 仿真实践

写在前面: 🌟 欢迎光临 清流君 的博客小天地,这里是我分享技术与心得的温馨角落。📝 个人主页:清流君_CSDN博客,期待与您一同探索 移动机器人 领域的无限可能。 🔍 本文系 清流君 原创之作&…

『功能项目』QFrameWorkBug关联Slot(插槽)【67】

我们打开上一篇66QFrameWorkBug拖拽功能的项目, 本章要做的事情是关联插槽Slot 修改脚本:UISlot.cs 修改脚本:UGUICanvas.cs 此时关联Slot已经完成 接下来的文章内容: 1.QFrameWork扔到地上UGUI 2.位置存储功能 3.点击名称寻…

Python可迭代对象(2)

目录 3。字典 字典的构造 字典的添加和修改 字典推导式的使用 以上全部代码编译结果展示 字典复习 4。集合(set) 集合的创建 集合的运算 集合的添加和删除元素 以上全部代码的编译结果 序列解包(Sequence unpacking) 3。字典 字典的构造 #字…

【Linux】nginx连接前端项目

文章目录 一、项目编译1.编译文件2.dist文件 二、Linux nginx配置三、启动nginx 一、项目编译 1.编译文件 2.dist文件 二、Linux nginx配置 在Xshell软件中,点击CtrlAltF进入文件传输找到地址:/usr/local/nginx/html将dist文件传入 找到nginx.conf&…

R包:VennDiagram韦恩图

加载R包 library(VennDiagram)数据 # Prepare character vectors v1 <- c("DKK1", "NPC1", "NAPG", "ERG", "VHL", "BTD", "MALL", "HAUS1") v2 <- c("SMAD4", "DKK1…

【计算机网络 - 基础问题】每日 3 题(十九)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏&…

【Python】curl命令、Api POST导入cURL、python直接使用cURL

文章目录 一、浏览器复制cURL二、API POST直接使用cURL创建接口三、python直接使用cURL构建网络请求四、curl命令详解语法选项实例 cURL是一种命令行工具&#xff0c;常用于通过各种协议&#xff08;如HTTP、HTTPS、FTP等&#xff09;传输数据。它的名字来源于"Client URL…

Python爬虫之requests模块(一)

Python爬虫之requests模块&#xff08;一&#xff09; 学完urllib之后对爬虫应该有一定的了解了&#xff0c;随后就来学习鼎鼎有名的requests模块吧。 一、requests简介。 1、什么是request模块&#xff1f; requests其实就是py原生的一个基于网络请求的模块&#xff0c;模拟…

「漏洞复现」灵当CRM marketing/index.php SQL注入漏洞

0x01 免责声明 请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;作者不为此承担任何责任。工具来自网络&#xff0c;安全性自测&#xff0c;如有侵权请联系删…

python爬虫初体验(一)

文章目录 1. 什么是爬虫&#xff1f;2. 为什么选择 Python&#xff1f;3. 爬虫小案例3.1 安装python3.2 安装依赖3.3 requests请求设置3.4 完整代码 4. 总结 1. 什么是爬虫&#xff1f; 爬虫&#xff08;Web Scraping&#xff09;是一种从网站自动提取数据的技术。简单来说&am…

c++调用python函数进行传参计算和返回

目录 前言&#xff1a;配置环境&#xff1a;基础夯实&#xff1a;1. 初始化Python解释器2. 导入Python模块3. 获取函数对象4. 调用Python函数5. 处理返回值6. 错误处理7. 资源管理8. 编译和链接9. 线程安全性10. 进一步学习 效果展示&#xff1a;实现功能&#xff1a;操作步骤&…

CentOS上使用Mosquitto实现Mqtt主题消息发布和订阅mqtt主题消息连同时间戳记录到文件

场景 CentOS上使用rpm离线安装Mosquitto(Linux上Mqtt协议调试工具)附资源下载&#xff1a; CentOS上使用rpm离线安装Mosquitto(Linux上Mqtt协议调试工具)附资源下载-CSDN博客 上面介绍了mosquitto的离线安装。 如果业务场景中需要订阅某mqtt主题的消息并将收到消息的时间以…

Android轻量级RTSP服务使用场景分析和设计探讨

技术背景 好多开发者&#xff0c;对我们Android平台轻量级RTSP服务模块有些陌生&#xff0c;不知道这个模块具体适用于怎样的场景&#xff0c;有什么优缺点&#xff0c;实际上&#xff0c;我们的Android平台轻量级RTSP服务模块更适用于内网环境下、对并发要求不高的场景&#…

Activiti7《第九式:破气式》——流畅驱动工作流进程。面试题大全

冲冲冲&#xff01;开干 这篇文章将分为九个篇章&#xff0c;带你逐步掌握工作流的核心知识。“破气式”&#xff0c;代表着工作流中的 无形之力&#xff0c;它是贯穿整个流程的 关键驱动 不知不觉已经到了独孤九剑最后一式了&#xff0c;我相信到这里之后各位都已经出神入化…

windows桌面管理软件推荐:一键整理桌面!美化电脑桌面小助手!

windows桌面管理软件推荐来咯&#xff01;在繁忙的工作和生活中&#xff0c;一个整洁、有序的电脑桌面不仅能提升工作效率&#xff0c;还能带来愉悦的视觉体验。然而&#xff0c;随着文件的增多&#xff0c;桌面往往变得杂乱无章。幸运的是&#xff0c;市面上有许多优秀的Windo…

构建高可用和高防御力的云服务架构第五部分:PolarDB(5/5)

引言 云计算与数据库服务 云计算作为一种革命性的技术&#xff0c;已经深刻改变了信息技术行业的面貌。它通过提供按需分配的计算资源&#xff0c;使得数据存储、处理和分析变得更加灵活和高效。在云计算的众多服务中&#xff0c;数据库服务扮演着核心角色。数据库服务不仅负…

​地质图制图规范大全资料分享

我们在《2024年最新测绘地理信息规范在线查看下载》一文整理460个测绘地理信息相关规范的在线查看链接。 现在我们又整理了地质图制图规范大全分享给大家&#xff0c;你可以在文末查看该文档的领取方法。 地质图制图规范大全 这些地质图制图规范来自地质科学数据出版系统&am…

Rustrover2024.2 正式发布:个人非商用免费,泰裤辣

如果这个世界本身 已经足够荒唐 那究竟什么才能算是疯狂 爱情就是这样 一旦错过了 就会有另一个人代替 我们知道 jetbrains 在今年的早些时候正式为 rust 语言发布了专用的 IDE &#xff0c;也就是 rustrover。如今 rustrover 也正式跻身为 jetbrains IDE 系列的一员猛将。…