aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorIngo Molnar <mingo@elte.hu>2008-03-03 03:53:17 -0500
committerIngo Molnar <mingo@elte.hu>2008-04-17 11:40:52 -0400
commit9fc34113f6880b215cbea4e7017fc818700384c2 (patch)
tree588ae8053ae866cac9dc174b3bf403a7ebe44365
parent40869cd038a0ecb867a7227aba46806224e4d11d (diff)
x86: debug pmd_bad()
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r--arch/x86/mm/pgtable_32.c7
-rw-r--r--include/asm-x86/pgtable_32.h6
2 files changed, 12 insertions, 1 deletions
diff --git a/arch/x86/mm/pgtable_32.c b/arch/x86/mm/pgtable_32.c
index 2f9e9afcb9f4..76e4f4d26272 100644
--- a/arch/x86/mm/pgtable_32.c
+++ b/arch/x86/mm/pgtable_32.c
@@ -381,3 +381,10 @@ void __pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd)
381} 381}
382 382
383#endif 383#endif
384
385int pmd_bad(pmd_t pmd)
386{
387 WARN_ON_ONCE(pmd_bad_v1(pmd) != pmd_bad_v2(pmd));
388
389 return pmd_bad_v1(pmd);
390}
diff --git a/include/asm-x86/pgtable_32.h b/include/asm-x86/pgtable_32.h
index 997c36c6b4d7..1e2c0d839528 100644
--- a/include/asm-x86/pgtable_32.h
+++ b/include/asm-x86/pgtable_32.h
@@ -90,7 +90,11 @@ extern unsigned long pg0[];
90/* To avoid harmful races, pmd_none(x) should check only the lower when PAE */ 90/* To avoid harmful races, pmd_none(x) should check only the lower when PAE */
91#define pmd_none(x) (!(unsigned long)pmd_val(x)) 91#define pmd_none(x) (!(unsigned long)pmd_val(x))
92#define pmd_present(x) (pmd_val(x) & _PAGE_PRESENT) 92#define pmd_present(x) (pmd_val(x) & _PAGE_PRESENT)
93#define pmd_bad(x) ((pmd_val(x) \ 93
94extern int pmd_bad(pmd_t pmd);
95
96#define pmd_bad_v1(x) ((pmd_val(x) & (~PAGE_MASK & ~_PAGE_USER)) != _KERNPG_TABLE)
97#define pmd_bad_v2(x) ((pmd_val(x) \
94 & ~(PAGE_MASK | _PAGE_USER | _PAGE_PSE | _PAGE_NX)) \ 98 & ~(PAGE_MASK | _PAGE_USER | _PAGE_PSE | _PAGE_NX)) \
95 != _KERNPG_TABLE) 99 != _KERNPG_TABLE)
96 100