|
@@ -179,6 +179,17 @@ static inline unsigned long pud_pfn(pud_t pud)
|
|
|
return (pud_val(pud) & pud_pfn_mask(pud)) >> PAGE_SHIFT;
|
|
|
}
|
|
|
|
|
|
+static inline unsigned long p4d_pfn(p4d_t p4d)
|
|
|
+{
|
|
|
+ return (p4d_val(p4d) & p4d_pfn_mask(p4d)) >> PAGE_SHIFT;
|
|
|
+}
|
|
|
+
|
|
|
+static inline int p4d_large(p4d_t p4d)
|
|
|
+{
|
|
|
+ /* No 512 GiB pages yet */
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
#define pte_page(pte) pfn_to_page(pte_pfn(pte))
|
|
|
|
|
|
static inline int pmd_large(pmd_t pte)
|
|
@@ -770,6 +781,16 @@ static inline int pud_large(pud_t pud)
|
|
|
}
|
|
|
#endif /* CONFIG_PGTABLE_LEVELS > 2 */
|
|
|
|
|
|
+static inline unsigned long pud_index(unsigned long address)
|
|
|
+{
|
|
|
+ return (address >> PUD_SHIFT) & (PTRS_PER_PUD - 1);
|
|
|
+}
|
|
|
+
|
|
|
+static inline unsigned long p4d_index(unsigned long address)
|
|
|
+{
|
|
|
+ return (address >> P4D_SHIFT) & (PTRS_PER_P4D - 1);
|
|
|
+}
|
|
|
+
|
|
|
#if CONFIG_PGTABLE_LEVELS > 3
|
|
|
static inline int pgd_present(pgd_t pgd)
|
|
|
{
|
|
@@ -788,11 +809,6 @@ static inline unsigned long pgd_page_vaddr(pgd_t pgd)
|
|
|
#define pgd_page(pgd) pfn_to_page(pgd_val(pgd) >> PAGE_SHIFT)
|
|
|
|
|
|
/* to find an entry in a page-table-directory. */
|
|
|
-static inline unsigned long pud_index(unsigned long address)
|
|
|
-{
|
|
|
- return (address >> PUD_SHIFT) & (PTRS_PER_PUD - 1);
|
|
|
-}
|
|
|
-
|
|
|
static inline pud_t *pud_offset(pgd_t *pgd, unsigned long address)
|
|
|
{
|
|
|
return (pud_t *)pgd_page_vaddr(*pgd) + pud_index(address);
|