我正在尝试使用自定义内核和内核模块来估计进程的 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/

10-11 22:40
查看更多