| .. | .. |
|---|
| 4 | 4 | |
|---|
| 5 | 5 | #ifndef __ASSEMBLY__ |
|---|
| 6 | 6 | |
|---|
| 7 | | -#ifdef __ARCH_USE_5LEVEL_HACK |
|---|
| 8 | | -#include <asm-generic/pgtable-nop4d-hack.h> |
|---|
| 9 | | -#else |
|---|
| 10 | 7 | #include <asm-generic/pgtable-nop4d.h> |
|---|
| 11 | 8 | |
|---|
| 12 | 9 | #define __PAGETABLE_PUD_FOLDED 1 |
|---|
| .. | .. |
|---|
| 35 | 32 | #define pud_ERROR(pud) (p4d_ERROR((pud).p4d)) |
|---|
| 36 | 33 | |
|---|
| 37 | 34 | #define p4d_populate(mm, p4d, pud) do { } while (0) |
|---|
| 35 | +#define p4d_populate_safe(mm, p4d, pud) do { } while (0) |
|---|
| 38 | 36 | /* |
|---|
| 39 | 37 | * (puds are folded into p4ds so this doesn't get actually called, |
|---|
| 40 | 38 | * but the define is needed for a generic inline function.) |
|---|
| .. | .. |
|---|
| 45 | 43 | { |
|---|
| 46 | 44 | return (pud_t *)p4d; |
|---|
| 47 | 45 | } |
|---|
| 46 | +#define pud_offset pud_offset |
|---|
| 48 | 47 | |
|---|
| 49 | 48 | #define pud_val(x) (p4d_val((x).p4d)) |
|---|
| 50 | 49 | #define __pud(x) ((pud_t) { __p4d(x) }) |
|---|
| 51 | 50 | |
|---|
| 52 | 51 | #define p4d_page(p4d) (pud_page((pud_t){ p4d })) |
|---|
| 53 | | -#define p4d_page_vaddr(p4d) (pud_page_vaddr((pud_t){ p4d })) |
|---|
| 52 | +#define p4d_pgtable(p4d) ((pud_t *)(pud_pgtable((pud_t){ p4d }))) |
|---|
| 54 | 53 | |
|---|
| 55 | 54 | /* |
|---|
| 56 | 55 | * allocating and freeing a pud is trivial: the 1-entry pud is |
|---|
| .. | .. |
|---|
| 58 | 57 | */ |
|---|
| 59 | 58 | #define pud_alloc_one(mm, address) NULL |
|---|
| 60 | 59 | #define pud_free(mm, x) do { } while (0) |
|---|
| 61 | | -#define __pud_free_tlb(tlb, x, a) do { } while (0) |
|---|
| 60 | +#define pud_free_tlb(tlb, x, a) do { } while (0) |
|---|
| 62 | 61 | |
|---|
| 63 | 62 | #undef pud_addr_end |
|---|
| 64 | 63 | #define pud_addr_end(addr, end) (end) |
|---|
| 65 | 64 | |
|---|
| 66 | 65 | #endif /* __ASSEMBLY__ */ |
|---|
| 67 | | -#endif /* !__ARCH_USE_5LEVEL_HACK */ |
|---|
| 68 | 66 | #endif /* _PGTABLE_NOPUD_H */ |
|---|