我正在尝试使用自定义内核和内核模块来估计进程的 WSS(工作集大小)。
我首先找到进程的 task_struct 并从 mm_struct
遍历所有 vm 区域。我能够通过遍历页表来访问所有 PTE,并检查页面是否存在并估计 RSS(常驻集大小)。
我现在想要做的是更改 VM 区域的 PTE,这样它会导致页面错误,并且我的自定义内核将在我所需的地址范围内记录页面错误。从页面错误中,我可以估计 WSS。但是,当我尝试更改 _PAGE_PRESENT
或 _PAGE_PROTNONE
时,出现 swap_dup: Bad swap file entry
错误并且进程崩溃。为什么在更改标志时实际的页面错误机制不起作用?我究竟做错了什么?
这是我的代码片段
for (addr = vmstart->vm_start; addr < vmstart->vm_end; addr += PAGE_SIZE) {
//Get PTE by walking page table
pte_t *pte = walk_page_table(task->mm,addr),tmp_pte;
//Only count present addresses:
if(pte && (pte_val(*pte) & _PAGE_PRESENT)) {
tmp_pte = *pte;
set_pte(pte , pte_clear_flags(tmp_pte, _PAGE_PRESENT) );
printk(KERN_INFO "Flag changed at %lx , Name %s\n", addr,name);
}
}
//unmap accessed page
if(pte) pte_unmap(pte);
}
walk_page_table
返回给定虚拟地址的 pte。请给出建议。我得到的错误是
swap_dup: Bad swap file entry
BUG: Bad page map in process
最佳答案
交换页 PTE 和内存页 PTE 具有完全不同的结构。交换条目显示页面在第二个存储中的位置,而普通 PTE 描述物理页面地址 + 标志。
所以,实际上,缺页机制正在发挥作用,但是您的缺页处理程序应该在哪里搜索已交换(无页面存在标志)的页面?
关于linux - 如何更改页表条目以在 linux 中引发页面错误?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28150437/