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指针,也就是线程切换之前都是一个裸机程序的状态。

相关推荐
LeonNo117 分钟前
golangb并发,Sync包中Mutes,WaitGroup, NewCond的适应
学习
thesky12345627 分钟前
活着就好20241226
学习·算法
远离UE41 小时前
UE5 渲染管线 学习笔记
笔记·学习·ue5
cwtlw2 小时前
CSS学习记录20
前端·css·笔记·学习
紫罗兰盛开3 小时前
分布式调度框架学习笔记
笔记·学习
Kobebryant-Manba3 小时前
kafka基本概念
分布式·学习·kafka
地球空间-技术小鱼3 小时前
YUM(Yellowdog Updater, Modified)和DNF(Dandified YUM)简介
linux·运维·服务器·笔记·学习
小码的头发丝、4 小时前
Java进阶学习笔记|面向对象
java·笔记·学习
坊钰4 小时前
【Java 数据结构】移除链表元素
java·开发语言·数据结构·学习·链表
阿七想学习5 小时前
数据结构《排序》
java·数据结构·学习·算法·排序算法