嵌入式堆栈、ARM寄存器

栈里面存放的内容:局部变量和系统信息,函数调用链路也是系统信息的一环

ARM寄存器
LR :程序跳转的时候,返回到的地址就保存到此处
PC :程序计数器,pc 要执行的下一条指令地址 ,就存放在此处,每次指令执行完,就自动+4

SP{MSP、PSP}:

MSP的含义是Main_Stack_Pointer,即主栈

PSP的含义是 Process_Stack_Pointer,即任务栈

**堆和栈 相向生长,**最好的办法就是让堆和栈一个向上涨,一个向下涨,这样它们就可以最大程度地共用这块剩余的地址空间,达到利用率的最大化!!
主堆栈指针(MSP) ,或写作 SP_main。这是缺省的堆栈指针,它由 OS 内核、异常服务例程 以及所有需要特权访问的应用程序代码来使用.
进程堆栈指针(PSP),或写作 SP_process。用于常规的应用程序代码(不处于异常服用例 程中时)

在OS开发中,当运行中断服务程序的时候CONTROL的bit1是0,SP使用的是MSP;当运行线程程序的时候CONTROL的bit1是1,SP使用的是PSP

MDK Debug方法:

ARM运行模式




ARM指令和Trumb指令:

在debug查找链路时,要是偶数地址,如果SP指向的地址,栈里面的地址是奇数,一般是减1.

在 32 位 ARM 状态下执行 字对齐的 ARM 指令,

当处理器执行在ARM状态:

1)所有指令32bits宽

2)所有指令必须 word 对齐

3)所有 pc 值由 [31:2] 决定,bits[1:0] 未定义( 所以指令不能 halfword/byte对齐 )

在 16位 Thumb 状态下,执行半字对齐的Thumb指令。

在 Thumb 状态下,程序计数器 PC (Program Counter) 使用位[1]选择另一个半字。

汇编语句:

PUSH: 把寄存器的地址往堆栈里面压,堆栈的地址从高到低使用,一个寄存器就占4个字节。

HardFault:结合寄存器保留的值,可以去map表查找是什么变量,以及结合SP查看代码运行到哪里

找到MSP指向的地址的上一个函数。

RTOS查看任务目前运行到哪个地方:

用TCB_t去看

通过pxTopOfStack 可以看目前任务运行的地方,可以通过pcTaskName 来确定目前任务是哪个

相关推荐
切糕师学AI8 小时前
ARM 应用程序状态寄存器APSR的整数状态(NZCV)位
arm开发·寄存器·apsr
早日退休!!!1 天前
ARM Cortex-M核 【保存上下文&恢复上下文】
arm开发·单片机·嵌入式硬件
早日退休!!!1 天前
ARM A核、ARM M核、X86与RISC-V架构:寄存器作用及上下文处理差异报告
arm开发·架构·risc-v
A-花开堪折1 天前
Qemu-NUC980(十一):SPI Controller
linux·arm开发·驱动开发·嵌入式硬件
Q_21932764552 天前
基于ARM的嵌入式温度控制系统的设计
arm开发
想你依然心痛2 天前
从x86到ARM的HPC之旅:鲲鹏开发工具链(编译器+数学库+MPI)上手与实战
java·开发语言·arm开发·鲲鹏·昇腾
MUTA️2 天前
x86 架构下运行 ARM-ROS2 Docker 镜像操作指南
arm开发·docker·架构
比奇堡派星星3 天前
Linux 杂项设备驱动框架详解
linux·arm开发·驱动开发
xingzhemengyou13 天前
LINUX 通过/proc/interrupts了解系统硬件中断的使用情况
linux·arm开发
rfidunion3 天前
ubuntu下使用qemu模拟ARM(一)-------安装samba服务器
服务器·arm开发·ubuntu