如何更改页表条目以在Linux中引发页面错误?

时间:2015-01-26 12:49:16

标签: linux linux-kernel kernel kernel-module

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

1 个答案:

答案 0 :(得分:0)

交换页面PTE和内存页面PTE具有完全不同的结构。交换条目显示页面放置在第二个存储中的位置,而普通PTE描述物理页面地址+标志。 实际上,页面错误机制正在运行,但是你的页面错误处理程序应该搜索swapped(没有页面存在标志)页面?