当程序运行在用户空间中时候。使用的是用户堆栈。到了系统内部使用的是系统堆栈。这个理解最为直观的就是:同样是运行,但是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指向哪里,又是在哪里初始化的?
谢谢
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之上的空间还是保留的。这这个堆栈空间是不是用户空间的堆栈保留下来的?
.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指向哪里,又是在哪里初始化的?
谢谢
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之上的空间还是保留的。这这个堆栈空间是不是用户空间的堆栈保留下来的?
.macro usr_entry
sub sp, sp, #S_FRAME_SIZE
stmib sp, {r1 - r12}
...
...
如果是使用svc自己的堆栈那么没有必要再去减S_FRAME_SIZE,也就是说这个size之上的空间还是保留的。这这个堆栈空间是不是用户空间的堆栈保留下来的?
#4
stmib,用的是升序
#5
谢谢了 问题找到答案了
#6
我也遇到这个问题,不知楼主可否贴一下答案,非常感谢