大家好:
当程序运行在用户空间中时候。使用的是用户堆栈。到了系统内部使用的是系统堆栈。这个理解最为直观的就是:同样是运行,但是SP指针所指向的地址不一样了。
假设用户程序运行时 sp 指针的数值是 0x8000 0000,那么这个时候中断到来。用户程序被中断,从而进入系统空间中,这个时候sp指针的地址是否还是0x8000 0000?
我看了一下代码 armv-entry.S 中 vector_stub 没有对sp进行过切换之类的操作。那么就是说arm的cpu中中断用户程序,使用的堆栈还是用户空间的指针是这样吗?
看了arm cpu 的体系架构介绍 中断进入svc模式中有自己的sp指针 叫做 r13_SVC。这个模式下的sp指针是怎么告诉硬件的 又是什么时候初始化的?
SVC模式下使用SP,指的就是sp_svc,已经不是usr模式下的sp了
那么这个svc下的sp指向哪里,又是在哪里初始化的?
希望高手回答一下。
谢谢 |