问题描述
- linux内核堆栈切换问题
- 假设每个进程有自己的页目录和页表。。用户进程运行时如果发生了中断。就会从特权级
3切换到特权级0。cpu此时自动从tss里面获取到esp0ss0,并将cseipeflags自动压入栈,
但此时的页目录还未切换,虽然已经进入内核栈空间,但此时经过页映射,物理地址还在
进程空间,linux是怎样实现当中断发生时,不破坏进程空间里面的值来切换到内核栈的?
注意,我说的不是0.xx的内核。。。整个CPU只用到了一个tss.
解决方案
我知道答案了。linux把地址分为内核空间和用户空间内核空间是3G以上,用户可用空间是3G以下,所以用户和内核空间是不会重合的,每个进程共享内核
空间,所以无论切不切换cr3都无所谓了。
时间: 2024-09-17 04:00:41