我观察到其中一个匿名段中的 Linux PTE 被设置为不可写和脏……这种组合意味着什么?
TL;DR - 这仅仅意味着该页面不在后备存储中并且它是只读的。
脏只是意味着没有写入后备存储(交换、mmap 文件或 inode)。诸如代码之类的许多东西总是从文件中读取,因此它们由 inode 支持。
例如,如果您mmap
有一些只读存储器,那么您可以获得这种组合。其他可能性是堆栈保护、分配器运行时缓冲区溢出检测和写时复制功能。
这些都不正常。对于典型的分配,您将拥有由 swap 支持的东西,只有写入才会导致页面变脏。因此,这种情况可能不太常见但有效。
请参阅:ARM Linux PTE 位
ARM Linux 模拟脏/访问
似乎很少有关于年轻位意味着 什么的文档。年轻是关于交换什么的信息。如果某些东西很年轻并且很长时间没有访问过,那么它是一个很好的驱逐对象。反之,脏是看是否需要交换。如果页面是脏的,那么它还没有被写入后备存储(交换文件或 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.
例如,不存在和脏似乎是不可能的条件,但脏和只读是有效的。