.. | .. |
---|
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 */ |
---|