Cortex-M3的双堆栈MSP和PSP(学习)

M3的栈,先进后出。

是局部变量内存的开销,函数的调用都离不开栈。

Cortex-M3内核使用了双堆栈,即MSP和PSP。

MSP:Main_Stack_Pointer,即主栈。

PSP:Process_Stack_Pointer,即任务栈。

SP:SP是堆栈指针,指向最后一个被压入元素的地址。

M3的压栈和弹栈过程。

  • 压栈:SP先自减4,然后将待压入的数据存放到SP所指的地址。
  • 弹栈:从SP指针所指的地址读出数据,然后SP指针自增4。

M3内核堆栈生长方向是向下生长,且是32位的。

M3内核何时使用MSP何时使用PSP?

M3双堆栈的意思是两个堆栈,但任何时候只能使用其中一个。

SP寄存器中的值在某一时刻到底是MSP还是PSP?

这是根据CONTROL寄存器的bit1来决定的,当CONTROL的bit1为0使用MSP(默认方式),为1时使用PSP。

控制寄存器有两个用途,其一用于定义特权级别,其二用于选择当前使用哪个堆栈指针。

设立双指针是为了保护OS的安全性和稳健性。
操作系统和异常事件用MSP。
用户程序(线程)用PSP。
MSP和PSP指针之间的切换会在处理异常事件时自动完成。

区别于用户程序使用PSP,操作系统和异常事件单独使用一个MSP指针的目的,为了保证栈数据不会被用户程序意外访问或栈空间被用户程序占用。

比如,当应用程序发生栈溢出问题时,必须要确保应用程序的故障不会影响到操作系统的运行和异常事件的处理------也就是需要保证始终有栈空间来执行异常事件。

裸机的时候,使用MSP指针。其实OS在上电复位到切换线程之前用的都是MSP指针,也就是线程切换之前都是一个裸机程序的状态。

相关推荐
JJJJ_iii4 分钟前
【机器学习08】模型评估与选择、偏差与方差、学习曲线
人工智能·笔记·python·深度学习·学习·机器学习
三次拒绝王俊凯16 分钟前
在实现“查询课程列表信息”功能时 出现的问题
学习
CosimaLi28 分钟前
CMake学习笔记
笔记·学习
正经教主1 小时前
【Trae+AI】和Trae学习搭建App_02:后端API开发
学习·app·1024程序员节
源代码•宸1 小时前
Qt6 学习——一个Qt桌面应用程序
开发语言·c++·经验分享·qt·学习·软件构建·windeployqt
讽刺人生Yan2 小时前
RFSOC学习记录(一)RF data converter总览
学习·fpga开发·rfsoc
Pluchon3 小时前
硅基计划2.0 学习总结 玖 图书管理系统 2.0复盘版(文字末尾源码可复制)
java·学习·项目·源码可复制
charlie1145141913 小时前
2D 计算机图形学基础速建——1
笔记·学习·教程·计算机图形学·基础
im_AMBER3 小时前
React 07
前端·笔记·学习·react.js·前端框架
on_pluto_4 小时前
GAN生成对抗网络学习-例子:生成逼真手写数字图
人工智能·深度学习·神经网络·学习·算法·机器学习·生成对抗网络