CM3基础(持续更新)

2024-03-31 06:38
文章标签 基础 更新 持续 cm3

本文主要是介绍CM3基础(持续更新),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CM3基础

操作模式和特权级别

参考Cortex-M3操作模式和特权级别

总结

系统有两种模式,handler模式和线程模式,前者始终位于特权级(用于处理异常),后者有特权和用户级两种。特权级别能够访问更多的数据范围。在系统复位后运行在线程模式的特权级下,位于特权级可以通过置为control[0]来进入用户级,而用户级别要进入特权级,只能被动等待异常出现然后进入handler模式来进入特权级。如下图
特权级和用户级

MSP&PSP

SP是堆栈指针,用于指向系统当前使用的堆栈位置,其实际位置取决于MSP或者PSP指向的地址,Cortex-M3的有两个堆栈指针寄存器MSP和PSP,任何时刻只能使用一个寄存器作为SP堆栈指针的索引值,可以在特权模式下通过修改control[1]来设置当前使用哪个寄存器,当系统位于handle模式时,只能使用MSP,即handle模式下虽然是特权模式但control[1]=0(即只能使用MSP),当处于线程模式时,则在特权级时可以设置为0(MSP)或者1(PSP)。
当然,我们不用担心何时去切换SP所对应寄存器地址,牢记一点:当处于中断中时,系统使用MSP,出中断前后使用PSP。更一般的,进入中断前,系统会自动使用PSP保存部分寄存器(R0-R3,R12,14,15,XPSR)到任务堆栈,在出中断前,系统会调用SP恢复寄存器,但出中断时仍处于MSP,所以在出中断前要先设置当前SP参考寄存器为PSPORR LR, LR, #0x04,这样出中断过程中会根据PSP恢复对应的软件堆栈寄存器(R0-R3,R12,14,15,XPSR)。


使用这种双指针是为了保护系统内核的堆栈数据,当系统位于软件层面时,系统使用的堆栈指针为PSP,而处理系统级别事务时则使用MSP,由于两个寄存器的储存值不同,系统堆栈和任务堆栈被人为分开了,这样能够确保软件层面的操作不会影响到系统层面。
MSP堆栈指针实际上就是整个SRAM的堆栈指针,而PSP指针只是作为任务堆栈指针来使用。
下图为MSP堆栈指针的初始化示例。因为代码中使用的数据结构可能不同(如使用了大量的数组时,位于最后的堆栈指针MSP所指的位置肯定要更靠后,即地址更高),导致实际的MSP的初始位置不同。
MSP和PSP堆栈1
在初始化SRAM时,诸如数组这样的全局变量占用SRAM低地址空间,这些数组在系统中就作为任务堆栈的储存空间,数组的末尾(数组的高地址段)就作为储存任务寄存器的地方,其中PSP就指向所压入堆栈的最后一个寄存器的地址。这样在空间上就把任务堆栈(PSP)和系统堆栈(MSP)分离开,分别标志不同的地址位,互不干扰。同时,不同的任务都有一个自己保存好的任务堆栈栈顶备份(位于TCB中),当切换回该任务时,会把自己的栈顶备份写入PSP寄存器,实现不同任务间的切换。
MSP和PSP指向不同的堆栈位置
MSP和PSP堆栈2
参考
Cortex-M3 双堆栈指针(MSP&PSP)
STM32双堆栈及其在uC/OS-II中的使用
PendSVC切换任务时,PSP和MSP的使用

这篇关于CM3基础(持续更新)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/863665

相关文章

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

Linux Mint Xia 22.1重磅发布: 重要更新一览

《LinuxMintXia22.1重磅发布:重要更新一览》Beta版LinuxMint“Xia”22.1发布,新版本基于Ubuntu24.04,内核版本为Linux6.8,这... linux Mint 22.1「Xia」正式发布啦!这次更新带来了诸多优化和改进,进一步巩固了 Mint 在 Linux 桌面

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

Ubuntu 24.04 LTS怎么关闭 Ubuntu Pro 更新提示弹窗?

《Ubuntu24.04LTS怎么关闭UbuntuPro更新提示弹窗?》Ubuntu每次开机都会弹窗提示安全更新,设置里最多只能取消自动下载,自动更新,但无法做到直接让自动更新的弹窗不出现,... 如果你正在使用 Ubuntu 24.04 LTS,可能会注意到——在使用「软件更新器」或运行 APT 命令时,

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]