关于切换执行模式之后的寄存器设置

本文探讨了在开发ARM处理器的引导程序时,如何确保从Supervisor模式切换到User模式后正确设置栈指针(SP)。作者揭示了模式切换后SP的重要性,并通过实例解释了不同模式下SP的变化。解决方法是为每种模式分配独立的栈地址,以保证程序的正常执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天写2440的引导程序的时候,出现了一个奇怪的现象,关机之后再开机发现串口没有打印。

废了九牛二虎之力终于找到了问题所在,原来是引导程序切换到用户模式之后没有重新设置栈(SP)。

 这张表是2440的通用寄存器和程序计数器表。

 

程序开机启动的时候,进入的是Supervisor模式,在引导程序切换到User模式的时候,需要设置SP。

原因是由上图可知每种模式之下r13都是不同的,r13既是栈指针(Stack Pointer (r13) )存放的位置。

下图为证:

 所以,如果模式切换之后没有设置栈(SP)的话,程序会没法执行。

为ARM有7种执行状态,每一种状态的栈指针寄存器(SP)都是独立的。因此,对程序中需要用到的每一种模式都要给SP定义一个栈地址。方法是给SP赋值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值