ARM Linux: PTE 不可写但脏了
ARM Linux: PTE not writable but dirty
我知道 ARM 体系结构通过在 here 讨论的页面错误处理程序中设置它们来模拟 Linux 的新标志和脏标志。但是最近对于一个小型二进制文件,我观察到其中一个匿名段中的 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 - 这只是意味着该页面不在后备存储中并且它是只读的。
Dirty 只是意味着 not 写入 backing store(交换、mmap 文件或索引节点)。代码等很多东西总是从文件中读取,所以它们由 inode 支持。
如果你mmap
一些只读内存,那么你可以获得这个组合,例如。其他可能性是堆栈保护、分配器 运行-time 缓冲区溢出检测和写时复制功能。
这些都不正常。对于典型的分配,您将有一些东西由交换支持,只有写入才会导致页面变得 脏 。所以这种情况可能不太常见但有效。
参见:ARM Linux PTE bits
关于 这位年轻人的意思的文档似乎很少。 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.
例如,不存在和脏似乎是不可能的条件,但脏和只读是有效的。
我知道 ARM 体系结构通过在 here 讨论的页面错误处理程序中设置它们来模拟 Linux 的新标志和脏标志。但是最近对于一个小型二进制文件,我观察到其中一个匿名段中的 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 - 这只是意味着该页面不在后备存储中并且它是只读的。
Dirty 只是意味着 not 写入 backing store(交换、mmap 文件或索引节点)。代码等很多东西总是从文件中读取,所以它们由 inode 支持。
如果你mmap
一些只读内存,那么你可以获得这个组合,例如。其他可能性是堆栈保护、分配器 运行-time 缓冲区溢出检测和写时复制功能。
这些都不正常。对于典型的分配,您将有一些东西由交换支持,只有写入才会导致页面变得 脏 。所以这种情况可能不太常见但有效。
参见:ARM Linux PTE bits
关于 这位年轻人的意思的文档似乎很少。 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.
例如,不存在和脏似乎是不可能的条件,但脏和只读是有效的。