Commit f476961c authored by Jeremy Fitzhardinge's avatar Jeremy Fitzhardinge

x86: unify pud_page

Impact: cleanup

Unify and demacro pud_page.
Signed-off-by: default avatarJeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
parent aca159db
...@@ -115,8 +115,6 @@ static inline void pud_clear(pud_t *pudp) ...@@ -115,8 +115,6 @@ static inline void pud_clear(pud_t *pudp)
write_cr3(pgd); write_cr3(pgd);
} }
#define pud_page(pud) pfn_to_page(pud_val(pud) >> PAGE_SHIFT)
/* Find an entry in the second-level page table.. */ /* Find an entry in the second-level page table.. */
#define pmd_offset(pud, address) ((pmd_t *)pud_page_vaddr(*(pud)) + \ #define pmd_offset(pud, address) ((pmd_t *)pud_page_vaddr(*(pud)) + \
pmd_index(address)) pmd_index(address))
......
...@@ -438,6 +438,7 @@ static inline void __init paravirt_pagetable_setup_done(pgd_t *base) ...@@ -438,6 +438,7 @@ static inline void __init paravirt_pagetable_setup_done(pgd_t *base)
#endif #endif
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
#include <linux/mm_types.h>
static inline int pte_none(pte_t pte) static inline int pte_none(pte_t pte)
{ {
...@@ -477,6 +478,11 @@ static inline unsigned long pud_page_vaddr(pud_t pud) ...@@ -477,6 +478,11 @@ static inline unsigned long pud_page_vaddr(pud_t pud)
{ {
return (unsigned long)__va((unsigned long)pud_val(pud) & PTE_PFN_MASK); return (unsigned long)__va((unsigned long)pud_val(pud) & PTE_PFN_MASK);
} }
static inline struct page *pud_page(pud_t pud)
{
return pfn_to_page(pud_val(pud) >> PAGE_SHIFT);
}
#endif /* PAGETABLE_LEVELS > 2 */ #endif /* PAGETABLE_LEVELS > 2 */
#if PAGETABLE_LEVELS > 3 #if PAGETABLE_LEVELS > 3
......
...@@ -185,7 +185,6 @@ static inline int pgd_large(pgd_t pgd) { return 0; } ...@@ -185,7 +185,6 @@ static inline int pgd_large(pgd_t pgd) { return 0; }
/* PUD - Level3 access */ /* PUD - Level3 access */
/* to find an entry in a page-table-directory. */ /* to find an entry in a page-table-directory. */
#define pud_page(pud) (pfn_to_page(pud_val((pud)) >> PAGE_SHIFT))
#define pud_index(address) (((address) >> PUD_SHIFT) & (PTRS_PER_PUD - 1)) #define pud_index(address) (((address) >> PUD_SHIFT) & (PTRS_PER_PUD - 1))
#define pud_offset(pgd, address) \ #define pud_offset(pgd, address) \
((pud_t *)pgd_page_vaddr(*(pgd)) + pud_index((address))) ((pud_t *)pgd_page_vaddr(*(pgd)) + pud_index((address)))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment