今天写2440的引导程序的时候,出现了一个奇怪的现象,关机之后再开机发现串口没有打印。
废了九牛二虎之力终于找到了问题所在,原来是引导程序切换到用户模式之后没有重新设置栈(SP)。

这张表是2440的通用寄存器和程序计数器表。
程序开机启动的时候,进入的是Supervisor模式,在引导程序切换到User模式的时候,需要设置SP。
原因是由上图可知每种模式之下r13都是不同的,r13既是栈指针(Stack Pointer (r13) )存放的位置。
下图为证:

所以,如果模式切换之后没有设置栈(SP)的话,程序会没法执行。
为ARM有7种执行状态,每一种状态的栈指针寄存器(SP)都是独立的。因此,对程序中需要用到的每一种模式都要给SP定义一个栈地址。方法是给SP赋值。

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

被折叠的 条评论
为什么被折叠?



