在内核 4.16.7 的 Ubuntu 上,我正在编写一个自定义系统调用,并且我想设置特定页表条目的 NX 位。到目前为止,我有这段代码,我正在执行页表遍历以获得我想要的 PTE,然后尝试设置它的 NX 位:
pgd = pgd_offset(mm, addr);
if (pgd_none(*pgd) || pgd_bad(*pgd)){
printk("Invalid pgd");
return -1;
}
p4d = p4d_offset(pgd, addr);
if (p4d_none(*p4d) || p4d_bad(*p4d)){
printk("Invalid p4d");
return -1;
}
pud = pud_offset(p4d, addr);
if (pud_none(*pud) || pud_bad(*pud)){
printk("Invalid pud");
return -1;
}
pmd = pmd_offset(pud, addr);
if (pmd_none(*pmd) || pmd_bad(*pmd)){
printk("Invalid pmd");
return -1;
}
ptep = pte_offset_map(pmd, addr);
if (!ptep){
printk("Invalid ptep");
return -1;
}
pte = *ptep;
if (pte_present(pte)){
printk("pte_set_flags");
printk("NX bit before: %d", pte_exec(pte));
// pte_set_flags(pte, _PAGE_NX);
// printk("NX bit after : %d", pte_exec(pte));
printk("pte_clear_flags");
// pte_clear_flags(pte, _PAGE_NX); // Same as pte_mkexec()
pte_mkexec(pte);
printk("NX bit after : %d", pte_exec(pte));
page = pte_page(pte);
if (page){
printk("Page frame struct is @ %p", page);
}
pte_unmap(ptep);
}
但它不起作用。所有printk
命令都显示相同的结果。有什么见解吗?
所以我自己找到了。代码如下:
因此特定 PTE 的 NX 位被改变。