3

我知道内核空间是操作系统核心执行和提供服务的内存部分,而用户空间是用户程序运行的地方。我还知道一个进程在其地址空间中有自己的堆栈、堆、数据和文本部分。但我对user stackkernel stack的概念感到困惑。我的问题是:

  1. 我之前提到的进程栈是由用户栈和内核栈组成的吗?
  2. 内核堆栈是内核空间的一部分吗?
  3. 两个堆栈是否在进程的虚拟内存地址中分开?
  4. 代码段中:void main(){user_mode_call(); system_call()}两次调用的栈帧是否分别驻留在用户栈和内核栈中?


感谢您的宝贵时间,任何相关的文献和链接也会有所帮助!
(我的问题可能很幼稚,但一旦我知道如何以更专业的方式提出它们,我会继续更新它们)

4

1 回答 1

2

堆栈结构通常由处理器指定。每个进程通常在每个处理器模式(用户、内核 + 处理器使用的任何其他模式)每个进程有一个堆栈,每个处理器有一个中断堆栈(另一个内核堆栈)。

我之前提到的进程栈是由用户栈和内核栈组成的吗?

不可以。必须保护内核堆栈免受用户模式访问。

内核堆栈是内核空间的一部分吗?

它可能是或可能是用户空间中受保护的内存。

两个堆栈是否在进程的虚拟内存地址中分开?

是的。

在代码段中: void main(){user_mode_call(); system_call()} 两个调用的栈帧是否分别驻留在用户栈和内核栈中?

“代码段”是教学结构。两者的堆栈帧都在用户堆栈中。系统调用调用一个包装函数,该函数设置寄存器值,然后引发一个将处理器切换到内核模式的异常。此时,大多数处理器将默认堆栈更改为内核模式堆栈。必须将参数传递给系统调用,因为在内核模式下无法通过 SP 寄存器直接访问用户堆栈。

于 2018-01-01T04:06:08.587 回答