.. | .. |
---|
15 | 15 | #include <linux/init.h> |
---|
16 | 16 | #include <linux/bitops.h> |
---|
17 | 17 | #include <linux/mm.h> |
---|
18 | | -#include <linux/bootmem.h> |
---|
| 18 | +#include <linux/memblock.h> |
---|
19 | 19 | #include <linux/vmalloc.h> |
---|
20 | 20 | |
---|
21 | 21 | #include <asm/sun3x.h> |
---|
22 | 22 | #include <asm/dvma.h> |
---|
23 | 23 | #include <asm/io.h> |
---|
24 | 24 | #include <asm/page.h> |
---|
25 | | -#include <asm/pgtable.h> |
---|
26 | | -#include <asm/pgalloc.h> |
---|
| 25 | +#include <asm/tlbflush.h> |
---|
27 | 26 | |
---|
28 | 27 | /* IOMMU support */ |
---|
29 | 28 | |
---|
.. | .. |
---|
80 | 79 | unsigned long vaddr, int len) |
---|
81 | 80 | { |
---|
82 | 81 | pgd_t *pgd; |
---|
| 82 | + p4d_t *p4d; |
---|
| 83 | + pud_t *pud; |
---|
83 | 84 | unsigned long end; |
---|
84 | 85 | int ret = 0; |
---|
85 | 86 | |
---|
.. | .. |
---|
90 | 91 | |
---|
91 | 92 | pr_debug("dvma: mapping kern %08lx to virt %08lx\n", kaddr, vaddr); |
---|
92 | 93 | pgd = pgd_offset_k(vaddr); |
---|
| 94 | + p4d = p4d_offset(pgd, vaddr); |
---|
| 95 | + pud = pud_offset(p4d, vaddr); |
---|
93 | 96 | |
---|
94 | 97 | do { |
---|
95 | 98 | pmd_t *pmd; |
---|
96 | 99 | unsigned long end2; |
---|
97 | 100 | |
---|
98 | | - if((pmd = pmd_alloc(&init_mm, pgd, vaddr)) == NULL) { |
---|
| 101 | + if((pmd = pmd_alloc(&init_mm, pud, vaddr)) == NULL) { |
---|
99 | 102 | ret = -ENOMEM; |
---|
100 | 103 | goto out; |
---|
101 | 104 | } |
---|
.. | .. |
---|
196 | 199 | } |
---|
197 | 200 | |
---|
198 | 201 | } |
---|
199 | | - |
---|