linux-kernel - ARM Linux : PTE not writable but dirty

标签 linux-kernel arm virtual-memory page-tables

我知道 ARM 体系结构通过在页错误处理程序中设置它们来模拟 Linux 的新标志和脏标志,如讨论的那样 here .但最近对于一个小型二进制文件,我观察到其中一个匿名段中的 Linux PTE 被设置为不可写。观察到以下 Linux PTE 状态:

- L_PTE_PRESENT : 1
- L_PTE_YOUNG   : 1 
- L_PTE_DIRTY   : 1
- L_PTE_RDONLY  : 1
- L_PTE_XN      : 0

我找不到对这种 PTE 标志组合的解释。内核是否为特殊的匿名 VMA 段设置了这种组合?这个组合代表什么?任何指针都会有所帮助。提前致谢。

最佳答案

I observed that a Linux PTE in one of the anonymous segments was set to be not writable and dirty... What does this combination signify?

TL;DR - 这只是意味着该页面不在后备存储中并且它是只读的。


只是意味着没有写入后备存储(交换、mmap 文件或 inode)。许多东西(例如代码)总是从文件中读取,因此它们由 inode 支持。

例如,如果您mmap 一些只读内存,那么您可以获得这种组合。其他可能性是堆栈保护、分配器运行时缓冲区溢出检测和写时复制功能。

这些都不正常。对于典型的分配,您将有一些由交换支持的东西,只有写入才会导致页面变得。所以这种情况可能不太常见但有效。

参见:ARM Linux PTE bits
ARM Linux emulate dirty/accessed

young 位的含义似乎很少有文档。 young 是关于交换什么的信息。如果某些东西还很年轻并且长时间没有被访问,那么它是一个很好的驱逐对象。相比之下,dirty 表示是否需要 交换。如果一个页面是脏的,那么它还没有被写入后备存储(交换文件或 mmap 文件等)。然后寻呼机必须写出这个页面。如果它不是脏的(或干净的),那么寻呼机可以简单地丢弃内存并重新使用。

年轻肮脏之间的区别就像应该必须

- L_PTE_PRESENT : 1   - it has physical RAM (not swapped)
- L_PTE_YOUNG   : 1   - is has not been used
- L_PTE_DIRTY   : 1   - it is different than backing store
- L_PTE_RDONLY  : 1   - user space can not write.
- L_PTE_XN      : 0   - code can execute.

例如,不存在和脏似乎是不可能的条件,但脏和只读是有效的。

关于linux-kernel - ARM Linux : PTE not writable but dirty,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35345025/

相关文章:

linux-kernel - 梅尔·戈尔曼 (Mel Gorman) 的 "Understanding the Linux Virtual Memory Manager"是否太过时了?

c - Linux : what prevents us from reading the memory from code segment?

linux - 通过 remap_pfn_range 将 dmam_alloc_coherent 分配的内存映射到用户空间会给出指向错误内存区域的指针

ARM 汇编中的凯撒解码器

apache-spark - Apache Yarn - 分配比物理内存或 RAM 更多的内存

linux-kernel - 修改通过接口(interface)发送的所有网络数据包

linux - 设备树和GPIO

c - 应用多个 __attribute__ 时 map 文件中缺少变量

无法使用 pure64 更改 cr3 寄存器以指向新的 pml4 方向

Linux:如何检测进程是否抖动过多?