arm 用户和系统堆栈的切换?

时间:2021-04-26 15:47:31
大家好:
当程序运行在用户空间中时候。使用的是用户堆栈。到了系统内部使用的是系统堆栈。这个理解最为直观的就是:同样是运行,但是SP指针所指向的地址不一样了。
假设用户程序运行时 sp 指针的数值是 0x8000 0000,那么这个时候中断到来。用户程序被中断,从而进入系统空间中,这个时候sp指针的地址是否还是0x8000 0000?

我看了一下代码 armv-entry.S 中 vector_stub 没有对sp进行过切换之类的操作。那么就是说arm的cpu中中断用户程序,使用的堆栈还是用户空间的指针是这样吗?

看了arm cpu 的体系架构介绍 中断进入svc模式中有自己的sp指针 叫做 r13_SVC。这个模式下的sp指针是怎么告诉硬件的 又是什么时候初始化的?

希望高手回答一下。
谢谢

6 个解决方案

#1


SVC模式下使用SP,指的就是sp_svc,已经不是usr模式下的sp了

#2


to u010005681 :
SVC模式下使用SP,指的就是sp_svc,已经不是usr模式下的sp了 

兄弟你确定,那么这个svc下的sp指向哪里,又是在哪里初始化的?

谢谢

#3


我看了一下代码:
 .macro  usr_entry
     sub     sp, sp, #S_FRAME_SIZE
     stmib   sp, {r1 - r12}
  ...
  ...

如果是使用svc自己的堆栈那么没有必要再去减S_FRAME_SIZE,也就是说这个size之上的空间还是保留的。这这个堆栈空间是不是用户空间的堆栈保留下来的?

#4


stmib,用的是升序

#5


谢谢了 问题找到答案了

#6


我也遇到这个问题,不知楼主可否贴一下答案,非常感谢

#1


SVC模式下使用SP,指的就是sp_svc,已经不是usr模式下的sp了

#2


to u010005681 :
SVC模式下使用SP,指的就是sp_svc,已经不是usr模式下的sp了 

兄弟你确定,那么这个svc下的sp指向哪里,又是在哪里初始化的?

谢谢

#3


我看了一下代码:
 .macro  usr_entry
     sub     sp, sp, #S_FRAME_SIZE
     stmib   sp, {r1 - r12}
  ...
  ...

如果是使用svc自己的堆栈那么没有必要再去减S_FRAME_SIZE,也就是说这个size之上的空间还是保留的。这这个堆栈空间是不是用户空间的堆栈保留下来的?

#4


stmib,用的是升序

#5


谢谢了 问题找到答案了

#6


我也遇到这个问题,不知楼主可否贴一下答案,非常感谢