Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 80437
b: refs/heads/master
c: f0646e4
h: refs/heads/master
i:
  80435: 3306e04
v: v3
  • Loading branch information
Ingo Molnar committed Jan 30, 2008
1 parent b2d1512 commit 0700dc5
Show file tree
Hide file tree
Showing 8 changed files with 23 additions and 12 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: a5a5dc31794c3271c066835ad2c90c58a3805569
refs/heads/master: f0646e43acb18f0e00b00085dc88bc3f403e7930
3 changes: 2 additions & 1 deletion trunk/arch/x86/mm/fault_32.c
Original file line number Diff line number Diff line change
Expand Up @@ -613,7 +613,8 @@ void __kprobes do_page_fault(struct pt_regs *regs, unsigned long error_code)

#ifdef CONFIG_X86_PAE
if (error_code & PF_INSTR) {
pte_t *pte = lookup_address(address);
int level;
pte_t *pte = lookup_address(address, &level);

if (pte && pte_present(*pte) && !pte_exec(*pte))
printk(KERN_CRIT "kernel tried to execute "
Expand Down
3 changes: 2 additions & 1 deletion trunk/arch/x86/mm/init_32.c
Original file line number Diff line number Diff line change
Expand Up @@ -535,11 +535,12 @@ int __init set_kernel_exec(unsigned long vaddr, int enable)
{
pte_t *pte;
int ret = 1;
int level;

if (!nx_enabled)
goto out;

pte = lookup_address(vaddr);
pte = lookup_address(vaddr, &level);
BUG_ON(!pte);

if (!pte_exec(*pte))
Expand Down
7 changes: 5 additions & 2 deletions trunk/arch/x86/mm/pageattr_32.c
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
static DEFINE_SPINLOCK(cpa_lock);
static struct list_head df_list = LIST_HEAD_INIT(df_list);

pte_t *lookup_address(unsigned long address)
pte_t *lookup_address(unsigned long address, int *level)
{
pgd_t *pgd = pgd_offset_k(address);
pud_t *pud;
Expand All @@ -32,8 +32,10 @@ pte_t *lookup_address(unsigned long address)
pmd = pmd_offset(pud, address);
if (pmd_none(*pmd))
return NULL;
*level = 2;
if (pmd_large(*pmd))
return (pte_t *)pmd;
*level = 3;

return pte_offset_kernel(pmd, address);
}
Expand Down Expand Up @@ -156,11 +158,12 @@ static int __change_page_attr(struct page *page, pgprot_t prot)
struct page *kpte_page;
unsigned long address;
pte_t *kpte;
int level;

BUG_ON(PageHighMem(page));
address = (unsigned long)page_address(page);

kpte = lookup_address(address);
kpte = lookup_address(address, &level);
if (!kpte)
return -EINVAL;

Expand Down
7 changes: 5 additions & 2 deletions trunk/arch/x86/mm/pageattr_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
#include <asm/uaccess.h>
#include <asm/io.h>

pte_t *lookup_address(unsigned long address)
pte_t *lookup_address(unsigned long address, int *level)
{
pgd_t *pgd = pgd_offset_k(address);
pud_t *pud;
Expand All @@ -29,8 +29,10 @@ pte_t *lookup_address(unsigned long address)
pmd = pmd_offset(pud, address);
if (!pmd_present(*pmd))
return NULL;
*level = 3;
if (pmd_large(*pmd))
return (pte_t *)pmd;
*level = 4;

pte = pte_offset_kernel(pmd, address);
if (pte && !pte_present(*pte))
Expand Down Expand Up @@ -140,8 +142,9 @@ __change_page_attr(unsigned long address, unsigned long pfn, pgprot_t prot,
struct page *kpte_page;
pgprot_t ref_prot2;
pte_t *kpte;
int level;

kpte = lookup_address(address);
kpte = lookup_address(address, &level);
if (!kpte)
return 0;

Expand Down
9 changes: 6 additions & 3 deletions trunk/arch/x86/xen/mmu.c
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,8 @@

xmaddr_t arbitrary_virt_to_machine(unsigned long address)
{
pte_t *pte = lookup_address(address);
int level;
pte_t *pte = lookup_address(address, &level);
unsigned offset = address & PAGE_MASK;

BUG_ON(pte == NULL);
Expand All @@ -70,8 +71,9 @@ void make_lowmem_page_readonly(void *vaddr)
{
pte_t *pte, ptev;
unsigned long address = (unsigned long)vaddr;
int level;

pte = lookup_address(address);
pte = lookup_address(address, &level);
BUG_ON(pte == NULL);

ptev = pte_wrprotect(*pte);
Expand All @@ -84,8 +86,9 @@ void make_lowmem_page_readwrite(void *vaddr)
{
pte_t *pte, ptev;
unsigned long address = (unsigned long)vaddr;
int level;

pte = lookup_address(address);
pte = lookup_address(address, &level);
BUG_ON(pte == NULL);

ptev = pte_mkwrite(*pte);
Expand Down
2 changes: 1 addition & 1 deletion trunk/include/asm-x86/pgtable_32.h
Original file line number Diff line number Diff line change
Expand Up @@ -182,7 +182,7 @@ static inline void clone_pgd_range(pgd_t *dst, pgd_t *src, int count)
* NOTE: the return type is pte_t but if the pmd is PSE then we return it
* as a pte too.
*/
extern pte_t *lookup_address(unsigned long address);
extern pte_t *lookup_address(unsigned long address, int *level);

/*
* Make a given kernel text page executable/non-executable.
Expand Down
2 changes: 1 addition & 1 deletion trunk/include/asm-x86/pgtable_64.h
Original file line number Diff line number Diff line change
Expand Up @@ -240,7 +240,7 @@ extern struct list_head pgd_list;

extern int kern_addr_valid(unsigned long addr);

pte_t *lookup_address(unsigned long addr);
pte_t *lookup_address(unsigned long addr, int *level);

#define io_remap_pfn_range(vma, vaddr, pfn, size, prot) \
remap_pfn_range(vma, vaddr, pfn, size, prot)
Expand Down

0 comments on commit 0700dc5

Please sign in to comment.