aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorJeremy Fitzhardinge <jeremy@goop.org>2009-02-05 14:30:48 -0500
committerJeremy Fitzhardinge <jeremy@goop.org>2009-02-06 15:31:07 -0500
commit5ba7c91341be61e0942f792c237ac067d9f32f51 (patch)
treef4c823f02eef1ab39749f9cec5e86da950ea546b /arch
parent7c683851d96c8313586c0695b25ca41bde9f0f73 (diff)
x86: unify pud_present
Impact: cleanup Unify and demacro pud_present. Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/include/asm/pgtable-3level.h5
-rw-r--r--arch/x86/include/asm/pgtable.h7
-rw-r--r--arch/x86/include/asm/pgtable_64.h1
3 files changed, 7 insertions, 6 deletions
diff --git a/arch/x86/include/asm/pgtable-3level.h b/arch/x86/include/asm/pgtable-3level.h
index 51832fa04743..524bd91b9952 100644
--- a/arch/x86/include/asm/pgtable-3level.h
+++ b/arch/x86/include/asm/pgtable-3level.h
@@ -28,11 +28,6 @@ static inline int pud_bad(pud_t pud)
28 return (pud_val(pud) & ~(PTE_PFN_MASK | _KERNPG_TABLE | _PAGE_USER)) != 0; 28 return (pud_val(pud) & ~(PTE_PFN_MASK | _KERNPG_TABLE | _PAGE_USER)) != 0;
29} 29}
30 30
31static inline int pud_present(pud_t pud)
32{
33 return pud_val(pud) & _PAGE_PRESENT;
34}
35
36/* Rules for using set_pte: the pte being assigned *must* be 31/* Rules for using set_pte: the pte being assigned *must* be
37 * either not present or in a state where the hardware will 32 * either not present or in a state where the hardware will
38 * not attempt to update the pte. In places where this is 33 * not attempt to update the pte. In places where this is
diff --git a/arch/x86/include/asm/pgtable.h b/arch/x86/include/asm/pgtable.h
index 17fcc17d6b4f..c117b28df151 100644
--- a/arch/x86/include/asm/pgtable.h
+++ b/arch/x86/include/asm/pgtable.h
@@ -445,6 +445,13 @@ static inline int pte_present(pte_t a)
445 return pte_flags(a) & (_PAGE_PRESENT | _PAGE_PROTNONE); 445 return pte_flags(a) & (_PAGE_PRESENT | _PAGE_PROTNONE);
446} 446}
447 447
448#if PAGETABLE_LEVELS > 2
449static inline int pud_present(pud_t pud)
450{
451 return pud_val(pud) & _PAGE_PRESENT;
452}
453#endif /* PAGETABLE_LEVELS > 2 */
454
448#endif /* __ASSEMBLY__ */ 455#endif /* __ASSEMBLY__ */
449 456
450#ifdef CONFIG_X86_32 457#ifdef CONFIG_X86_32
diff --git a/arch/x86/include/asm/pgtable_64.h b/arch/x86/include/asm/pgtable_64.h
index 35b8dbc068e0..acdc27b202c8 100644
--- a/arch/x86/include/asm/pgtable_64.h
+++ b/arch/x86/include/asm/pgtable_64.h
@@ -194,7 +194,6 @@ static inline int pgd_large(pgd_t pgd) { return 0; }
194#define pud_index(address) (((address) >> PUD_SHIFT) & (PTRS_PER_PUD - 1)) 194#define pud_index(address) (((address) >> PUD_SHIFT) & (PTRS_PER_PUD - 1))
195#define pud_offset(pgd, address) \ 195#define pud_offset(pgd, address) \
196 ((pud_t *)pgd_page_vaddr(*(pgd)) + pud_index((address))) 196 ((pud_t *)pgd_page_vaddr(*(pgd)) + pud_index((address)))
197#define pud_present(pud) (pud_val((pud)) & _PAGE_PRESENT)
198 197
199static inline int pud_large(pud_t pte) 198static inline int pud_large(pud_t pte)
200{ 199{