aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/x86/include/asm/pgtable.h5
-rw-r--r--arch/x86/include/asm/pgtable_32.h1
-rw-r--r--arch/x86/include/asm/pgtable_64.h1
3 files changed, 5 insertions, 2 deletions
diff --git a/arch/x86/include/asm/pgtable.h b/arch/x86/include/asm/pgtable.h
index 339e49a9bb6c..147d3f097ab0 100644
--- a/arch/x86/include/asm/pgtable.h
+++ b/arch/x86/include/asm/pgtable.h
@@ -445,6 +445,11 @@ 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
448static inline int pmd_present(pmd_t pmd)
449{
450 return pmd_val(pmd) & _PAGE_PRESENT;
451}
452
448#if PAGETABLE_LEVELS > 2 453#if PAGETABLE_LEVELS > 2
449static inline int pud_present(pud_t pud) 454static inline int pud_present(pud_t pud)
450{ 455{
diff --git a/arch/x86/include/asm/pgtable_32.h b/arch/x86/include/asm/pgtable_32.h
index 188073713fed..f35160730b65 100644
--- a/arch/x86/include/asm/pgtable_32.h
+++ b/arch/x86/include/asm/pgtable_32.h
@@ -87,7 +87,6 @@ extern unsigned long pg0[];
87 87
88/* To avoid harmful races, pmd_none(x) should check only the lower when PAE */ 88/* To avoid harmful races, pmd_none(x) should check only the lower when PAE */
89#define pmd_none(x) (!(unsigned long)pmd_val((x))) 89#define pmd_none(x) (!(unsigned long)pmd_val((x)))
90#define pmd_present(x) (pmd_val((x)) & _PAGE_PRESENT)
91#define pmd_bad(x) ((pmd_val(x) & (PTE_FLAGS_MASK & ~_PAGE_USER)) != _KERNPG_TABLE) 90#define pmd_bad(x) ((pmd_val(x) & (PTE_FLAGS_MASK & ~_PAGE_USER)) != _KERNPG_TABLE)
92 91
93#define pages_to_mb(x) ((x) >> (20-PAGE_SHIFT)) 92#define pages_to_mb(x) ((x) >> (20-PAGE_SHIFT))
diff --git a/arch/x86/include/asm/pgtable_64.h b/arch/x86/include/asm/pgtable_64.h
index 447634698f5d..471b3058f3d7 100644
--- a/arch/x86/include/asm/pgtable_64.h
+++ b/arch/x86/include/asm/pgtable_64.h
@@ -208,7 +208,6 @@ static inline int pud_large(pud_t pte)
208#define pmd_offset(dir, address) ((pmd_t *)pud_page_vaddr(*(dir)) + \ 208#define pmd_offset(dir, address) ((pmd_t *)pud_page_vaddr(*(dir)) + \
209 pmd_index(address)) 209 pmd_index(address))
210#define pmd_none(x) (!pmd_val((x))) 210#define pmd_none(x) (!pmd_val((x)))
211#define pmd_present(x) (pmd_val((x)) & _PAGE_PRESENT)
212#define pfn_pmd(nr, prot) (__pmd(((nr) << PAGE_SHIFT) | pgprot_val((prot)))) 211#define pfn_pmd(nr, prot) (__pmd(((nr) << PAGE_SHIFT) | pgprot_val((prot))))
213#define pmd_pfn(x) ((pmd_val((x)) & __PHYSICAL_MASK) >> PAGE_SHIFT) 212#define pmd_pfn(x) ((pmd_val((x)) & __PHYSICAL_MASK) >> PAGE_SHIFT)
214 213