diff options
author | Ingo Molnar <mingo@elte.hu> | 2008-03-03 03:53:17 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-04-17 11:40:52 -0400 |
commit | 9fc34113f6880b215cbea4e7017fc818700384c2 (patch) | |
tree | 588ae8053ae866cac9dc174b3bf403a7ebe44365 | |
parent | 40869cd038a0ecb867a7227aba46806224e4d11d (diff) |
x86: debug pmd_bad()
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | arch/x86/mm/pgtable_32.c | 7 | ||||
-rw-r--r-- | include/asm-x86/pgtable_32.h | 6 |
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 | |||
385 | int 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 | |
94 | extern 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 | ||