我正在尝试编写一个函数,对给定 vm_area_struct
中的每个 pte
进行写保护。为给定地址提供 ptep
的函数是什么?我有:
pte_t *ptep;
for (addr = start; addr < end; addr += PAGE_SIZE) {
ptep = WHATS_THIS_FUNCTION_CALLED(addr);
ptep_set_wrprotect(mm, addr, ptep);
}
WHATS_THIS_FUNCTION_CALLED
叫什么?
最佳答案
您问题的简短答案是使用 __get_locked_pte
。但是,我不建议这样做,因为有更好的方法(在资源争用方面高效且公平)可以实现您的目标。
在 linux 中,遍历页表的典型习惯用法是使用嵌套的 for 循环四层深(四是 linux 支持的页表层数)。有关示例,请参阅 copy_page_range
和 apply_to_page_range
in mm/memory.c .事实上,如果你仔细观察 copy_page_range
,它是在 kernel/fork.c 中从 dup_mmap
fork 时调用的。它本质上对整个 vm_area_struct
进行操作。
您可以复制其中任一函数中使用的习语。但是,有一些注意事项。例如,copy_page_range
通过在 copy_pmd_range
中使用完全独立的 copy_huge_pmd
完全支持透明大页面 (2.6.38)。除非您想编写两个单独的函数(一个用于普通页面,一个用于透明大页面,请参阅 Documentation/vm/transhuge.txt
中的 Gracefull fallback
。
关键是 linux 中的虚拟内存非常复杂,所以一定要完全理解每一个可能的用例。 follow_page
在 mm/memory.c应该演示如何涵盖所有基础。
关于linux - 如何找到给定地址的 ptep?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9640038/