gpt4 book ai didi

linux - 写入任何地方的用户空间程序

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:04:16 25 4
gpt4 key购买 nike

以 Unix 内核为例。在内核空间和用户空间方面,有些事情我不太了解。

我们将有用户空间应用程序代码和内核代码。内核代码可以不受限制地访问底层硬件,其代码和内存与用户空间代码完全分离。

当用户空间应用程序正在执行时,内核代码是否也在并行执行,例如内核线程总是检查事物?

我一直在阅读内核为试图访问受限内存部分的用户空间程序提供内存保护。这种内存保护是动态发生的,还是会在编译期间发生,如果用户空间代码试图写入内存的受限部分会出错?

一般来说,如果内核代码不同时执行,如何阻止用户空间程序写入内存中它想要的任何位置?我会猜测并说这是因为 MMU 和虚拟内存,但还有更多吗?谢谢

最佳答案

When a user space application is executing, is the kernel code also executing in parallel, such as kernel threads always checking things?

没有。

Is this memory protection happening dynamically, or will it be during compilation, an error if user space code tries to write to a restricted part of memory?

内存限制由内存管理硬件结合 CPU mode 动态强制执行。 .
内核在引导期间配置这些限制,即 MMU 初始化。

编译器通常不执行任何地址强制。生成越界访问数组的代码很容易。同样,很容易生成引用“受限”内存的指针。请注意,编译阶段通常不假设运行时环境(例如内核空间占用 32 位虚拟地址空间的 1GB 还是 2GB?),因此编译后的程序更具可移植性。

In general, what is to stop a user space program from writing to anywhere it wants in memory if the kernel code is not executing at the same time?

用户空间程序只是以限制某些操作的受限 CPU 权限执行。
此外,它在自己受限的虚拟内存空间中执行,与其他进程分开。
顺便说一句,CPU 一次(基本上)只能执行一条指令,因此不存在“内核代码...同时执行”,前提是无关紧要的。

is there more to it?

CPU 必须有 privilege mode(s) ;并非所有 CPU 都具有此功能。早期 PC 的英特尔 CPU,例如8088和80286,没有。

“当用户空间应用程序正在执行时”,CPU 处于用户模式,即具有最少特权/功能的模式。内核代码在主管/特权(又名内核)模式下执行。

When and where is the protection implemented?

在执行每条指令时,CPU 根据当前 CPU 模式验证该指令。试图在受限模式下执行特权指令会触发 CPU 异常。
如果指令还涉及内存引用,则 MMU 会根据当前 CPU 模式(即用户模式与内核模式)验证该虚拟内存地址(即用户空间与内核空间)。
对于有效的内存引用,MMU 将确认物理内存已映射到该虚拟地址,并且内存页已驻留。


附录

您似乎将访问虚拟内存和物理内存的限制混为一谈。
您的用户空间程序只能访问较低的虚拟内存。边界由内核定义。硬件拒绝访问内核空间,特别是 MMU 和 CPU 模式。

您的(用户空间)程序只能访问操作系统为其提供的内存空间。编程语言没有针对替代(例如物理而不是虚拟)地址空间的内置构造。保护模式 Windows(即 Windows NT 和更高版本,不是 Windows 3.x)不提供程序访问物理内存。 POSIX 操作系统提供伪设备 /dev/mem 用于将任何物理地址映射到用户(虚拟)地址空间的内存。

由于 ARM 处理器没有 I/O 指令或地址空间,因此所有 I/O 都是内存映射的。因此,/dev/mem 是用于访问连接到运行 Linux 的 ARM 处理器的外围设备的设备。
对伪设备 /dev/mem 的访问由内核使用文件系统权限控制(就像所有其他文件一样)。

关于linux - 写入任何地方的用户空间程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50656168/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com