我正在尝试使用自定义内核和内核模块来估计进程的WSS(工作集大小)。
我首先找到进程的task_struct并遍历mm_struct
的所有vm区域。通过遍历页面表并检查是否存在页面并估计RSS(驻留集大小),我能够访问所有PTE。
我现在要做的是更改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
答案 0 :(得分:0)
交换页面PTE和内存页面PTE具有完全不同的结构。交换条目显示页面放置在第二个存储中的位置,而普通PTE描述物理页面地址+标志。 实际上,页面错误机制正在运行,但是你的页面错误处理程序应该搜索swapped(没有页面存在标志)页面?