diff options
Diffstat (limited to 'arch/mips/mm')
-rw-r--r-- | arch/mips/mm/c-r3k.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/c-r4k.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/c-tx39.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/fault.c | 10 | ||||
-rw-r--r-- | arch/mips/mm/init.c | 28 | ||||
-rw-r--r-- | arch/mips/mm/ioremap.c | 15 | ||||
-rw-r--r-- | arch/mips/mm/pgtable-32.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/tlb-andes.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/tlb-r4k.c | 4 |
9 files changed, 52 insertions, 25 deletions
diff --git a/arch/mips/mm/c-r3k.c b/arch/mips/mm/c-r3k.c index c659f99eb39a..03492a5c21f1 100644 --- a/arch/mips/mm/c-r3k.c +++ b/arch/mips/mm/c-r3k.c | |||
@@ -221,12 +221,14 @@ static inline unsigned long get_phys_page (unsigned long addr, | |||
221 | struct mm_struct *mm) | 221 | struct mm_struct *mm) |
222 | { | 222 | { |
223 | pgd_t *pgd; | 223 | pgd_t *pgd; |
224 | pud_t *pud; | ||
224 | pmd_t *pmd; | 225 | pmd_t *pmd; |
225 | pte_t *pte; | 226 | pte_t *pte; |
226 | unsigned long physpage; | 227 | unsigned long physpage; |
227 | 228 | ||
228 | pgd = pgd_offset(mm, addr); | 229 | pgd = pgd_offset(mm, addr); |
229 | pmd = pmd_offset(pgd, addr); | 230 | pud = pud_offset(pgd, addr); |
231 | pmd = pmd_offset(pud, addr); | ||
230 | pte = pte_offset(pmd, addr); | 232 | pte = pte_offset(pmd, addr); |
231 | 233 | ||
232 | if ((physpage = pte_val(*pte)) & _PAGE_VALID) | 234 | if ((physpage = pte_val(*pte)) & _PAGE_VALID) |
diff --git a/arch/mips/mm/c-r4k.c b/arch/mips/mm/c-r4k.c index 8ffb9f809ed9..b165b73e2583 100644 --- a/arch/mips/mm/c-r4k.c +++ b/arch/mips/mm/c-r4k.c | |||
@@ -372,12 +372,14 @@ static inline void local_r4k_flush_cache_page(void *args) | |||
372 | int exec = vma->vm_flags & VM_EXEC; | 372 | int exec = vma->vm_flags & VM_EXEC; |
373 | struct mm_struct *mm = vma->vm_mm; | 373 | struct mm_struct *mm = vma->vm_mm; |
374 | pgd_t *pgdp; | 374 | pgd_t *pgdp; |
375 | pud_t *pudp; | ||
375 | pmd_t *pmdp; | 376 | pmd_t *pmdp; |
376 | pte_t *ptep; | 377 | pte_t *ptep; |
377 | 378 | ||
378 | page &= PAGE_MASK; | 379 | page &= PAGE_MASK; |
379 | pgdp = pgd_offset(mm, page); | 380 | pgdp = pgd_offset(mm, page); |
380 | pmdp = pmd_offset(pgdp, page); | 381 | pudp = pud_offset(pgdp, page); |
382 | pmdp = pmd_offset(pudp, page); | ||
381 | ptep = pte_offset(pmdp, page); | 383 | ptep = pte_offset(pmdp, page); |
382 | 384 | ||
383 | /* | 385 | /* |
diff --git a/arch/mips/mm/c-tx39.c b/arch/mips/mm/c-tx39.c index ff5afab64b2f..5054a0ed2b6d 100644 --- a/arch/mips/mm/c-tx39.c +++ b/arch/mips/mm/c-tx39.c | |||
@@ -183,6 +183,7 @@ static void tx39_flush_cache_page(struct vm_area_struct *vma, unsigned long page | |||
183 | int exec = vma->vm_flags & VM_EXEC; | 183 | int exec = vma->vm_flags & VM_EXEC; |
184 | struct mm_struct *mm = vma->vm_mm; | 184 | struct mm_struct *mm = vma->vm_mm; |
185 | pgd_t *pgdp; | 185 | pgd_t *pgdp; |
186 | pud_t *pudp; | ||
186 | pmd_t *pmdp; | 187 | pmd_t *pmdp; |
187 | pte_t *ptep; | 188 | pte_t *ptep; |
188 | 189 | ||
@@ -195,7 +196,8 @@ static void tx39_flush_cache_page(struct vm_area_struct *vma, unsigned long page | |||
195 | 196 | ||
196 | page &= PAGE_MASK; | 197 | page &= PAGE_MASK; |
197 | pgdp = pgd_offset(mm, page); | 198 | pgdp = pgd_offset(mm, page); |
198 | pmdp = pmd_offset(pgdp, page); | 199 | pudp = pud_offset(pgdp, page); |
200 | pmdp = pmd_offset(pudp, page); | ||
199 | ptep = pte_offset(pmdp, page); | 201 | ptep = pte_offset(pmdp, page); |
200 | 202 | ||
201 | /* | 203 | /* |
diff --git a/arch/mips/mm/fault.c b/arch/mips/mm/fault.c index ec8077c74e9c..345a4d6ec20f 100644 --- a/arch/mips/mm/fault.c +++ b/arch/mips/mm/fault.c | |||
@@ -212,6 +212,7 @@ vmalloc_fault: | |||
212 | */ | 212 | */ |
213 | int offset = __pgd_offset(address); | 213 | int offset = __pgd_offset(address); |
214 | pgd_t *pgd, *pgd_k; | 214 | pgd_t *pgd, *pgd_k; |
215 | pud_t *pud, *pud_k; | ||
215 | pmd_t *pmd, *pmd_k; | 216 | pmd_t *pmd, *pmd_k; |
216 | pte_t *pte_k; | 217 | pte_t *pte_k; |
217 | 218 | ||
@@ -222,8 +223,13 @@ vmalloc_fault: | |||
222 | goto no_context; | 223 | goto no_context; |
223 | set_pgd(pgd, *pgd_k); | 224 | set_pgd(pgd, *pgd_k); |
224 | 225 | ||
225 | pmd = pmd_offset(pgd, address); | 226 | pud = pud_offset(pgd, address); |
226 | pmd_k = pmd_offset(pgd_k, address); | 227 | pud_k = pud_offset(pgd_k, address); |
228 | if (!pud_present(*pud_k)) | ||
229 | goto no_context; | ||
230 | |||
231 | pmd = pmd_offset(pud, address); | ||
232 | pmd_k = pmd_offset(pud_k, address); | ||
227 | if (!pmd_present(*pmd_k)) | 233 | if (!pmd_present(*pmd_k)) |
228 | goto no_context; | 234 | goto no_context; |
229 | set_pmd(pmd, *pmd_k); | 235 | set_pmd(pmd, *pmd_k); |
diff --git a/arch/mips/mm/init.c b/arch/mips/mm/init.c index 77cbccaff955..5e1967f14255 100644 --- a/arch/mips/mm/init.c +++ b/arch/mips/mm/init.c | |||
@@ -83,7 +83,7 @@ pte_t *kmap_pte; | |||
83 | pgprot_t kmap_prot; | 83 | pgprot_t kmap_prot; |
84 | 84 | ||
85 | #define kmap_get_fixmap_pte(vaddr) \ | 85 | #define kmap_get_fixmap_pte(vaddr) \ |
86 | pte_offset_kernel(pmd_offset(pgd_offset_k(vaddr), (vaddr)), (vaddr)) | 86 | pte_offset_kernel(pmd_offset(pud_offset(pgd_offset_k(vaddr), (vaddr)), (vaddr)), (vaddr)) |
87 | 87 | ||
88 | static void __init kmap_init(void) | 88 | static void __init kmap_init(void) |
89 | { | 89 | { |
@@ -101,26 +101,32 @@ void __init fixrange_init(unsigned long start, unsigned long end, | |||
101 | pgd_t *pgd_base) | 101 | pgd_t *pgd_base) |
102 | { | 102 | { |
103 | pgd_t *pgd; | 103 | pgd_t *pgd; |
104 | pud_t *pud; | ||
104 | pmd_t *pmd; | 105 | pmd_t *pmd; |
105 | pte_t *pte; | 106 | pte_t *pte; |
106 | int i, j; | 107 | int i, j, k; |
107 | unsigned long vaddr; | 108 | unsigned long vaddr; |
108 | 109 | ||
109 | vaddr = start; | 110 | vaddr = start; |
110 | i = __pgd_offset(vaddr); | 111 | i = __pgd_offset(vaddr); |
111 | j = __pmd_offset(vaddr); | 112 | j = __pud_offset(vaddr); |
113 | k = __pmd_offset(vaddr); | ||
112 | pgd = pgd_base + i; | 114 | pgd = pgd_base + i; |
113 | 115 | ||
114 | for ( ; (i < PTRS_PER_PGD) && (vaddr != end); pgd++, i++) { | 116 | for ( ; (i < PTRS_PER_PGD) && (vaddr != end); pgd++, i++) { |
115 | pmd = (pmd_t *)pgd; | 117 | pud = (pud_t *)pgd; |
116 | for (; (j < PTRS_PER_PMD) && (vaddr != end); pmd++, j++) { | 118 | for ( ; (j < PTRS_PER_PUD) && (vaddr != end); pud++, j++) { |
117 | if (pmd_none(*pmd)) { | 119 | pmd = (pmd_t *)pud; |
118 | pte = (pte_t *) alloc_bootmem_low_pages(PAGE_SIZE); | 120 | for (; (k < PTRS_PER_PMD) && (vaddr != end); pmd++, k++) { |
119 | set_pmd(pmd, __pmd(pte)); | 121 | if (pmd_none(*pmd)) { |
120 | if (pte != pte_offset_kernel(pmd, 0)) | 122 | pte = (pte_t *) alloc_bootmem_low_pages(PAGE_SIZE); |
121 | BUG(); | 123 | set_pmd(pmd, __pmd(pte)); |
124 | if (pte != pte_offset_kernel(pmd, 0)) | ||
125 | BUG(); | ||
126 | } | ||
127 | vaddr += PMD_SIZE; | ||
122 | } | 128 | } |
123 | vaddr += PMD_SIZE; | 129 | k = 0; |
124 | } | 130 | } |
125 | j = 0; | 131 | j = 0; |
126 | } | 132 | } |
diff --git a/arch/mips/mm/ioremap.c b/arch/mips/mm/ioremap.c index adf352273f63..d06107360db4 100644 --- a/arch/mips/mm/ioremap.c +++ b/arch/mips/mm/ioremap.c | |||
@@ -79,9 +79,14 @@ static int remap_area_pages(unsigned long address, phys_t phys_addr, | |||
79 | BUG(); | 79 | BUG(); |
80 | spin_lock(&init_mm.page_table_lock); | 80 | spin_lock(&init_mm.page_table_lock); |
81 | do { | 81 | do { |
82 | pud_t *pud; | ||
82 | pmd_t *pmd; | 83 | pmd_t *pmd; |
83 | pmd = pmd_alloc(&init_mm, dir, address); | 84 | |
84 | error = -ENOMEM; | 85 | error = -ENOMEM; |
86 | pud = pud_alloc(&init_mm, dir, address); | ||
87 | if (!pud) | ||
88 | break; | ||
89 | pmd = pmd_alloc(&init_mm, pud, address); | ||
85 | if (!pmd) | 90 | if (!pmd) |
86 | break; | 91 | break; |
87 | if (remap_area_pmd(pmd, address, end - address, | 92 | if (remap_area_pmd(pmd, address, end - address, |
@@ -141,7 +146,7 @@ void * __ioremap(phys_t phys_addr, phys_t size, unsigned long flags) | |||
141 | */ | 146 | */ |
142 | if (IS_LOW512(phys_addr) && IS_LOW512(last_addr) && | 147 | if (IS_LOW512(phys_addr) && IS_LOW512(last_addr) && |
143 | flags == _CACHE_UNCACHED) | 148 | flags == _CACHE_UNCACHED) |
144 | return (void *) KSEG1ADDR(phys_addr); | 149 | return (void *) CKSEG1ADDR(phys_addr); |
145 | 150 | ||
146 | /* | 151 | /* |
147 | * Don't allow anybody to remap normal RAM that we're using.. | 152 | * Don't allow anybody to remap normal RAM that we're using.. |
@@ -180,7 +185,7 @@ void * __ioremap(phys_t phys_addr, phys_t size, unsigned long flags) | |||
180 | return (void *) (offset + (char *)addr); | 185 | return (void *) (offset + (char *)addr); |
181 | } | 186 | } |
182 | 187 | ||
183 | #define IS_KSEG1(addr) (((unsigned long)(addr) & ~0x1fffffffUL) == KSEG1) | 188 | #define IS_KSEG1(addr) (((unsigned long)(addr) & ~0x1fffffffUL) == CKSEG1) |
184 | 189 | ||
185 | void __iounmap(volatile void __iomem *addr) | 190 | void __iounmap(volatile void __iomem *addr) |
186 | { | 191 | { |
@@ -190,10 +195,8 @@ void __iounmap(volatile void __iomem *addr) | |||
190 | return; | 195 | return; |
191 | 196 | ||
192 | p = remove_vm_area((void *) (PAGE_MASK & (unsigned long __force) addr)); | 197 | p = remove_vm_area((void *) (PAGE_MASK & (unsigned long __force) addr)); |
193 | if (!p) { | 198 | if (!p) |
194 | printk(KERN_ERR "iounmap: bad address %p\n", addr); | 199 | printk(KERN_ERR "iounmap: bad address %p\n", addr); |
195 | return; | ||
196 | } | ||
197 | 200 | ||
198 | kfree(p); | 201 | kfree(p); |
199 | } | 202 | } |
diff --git a/arch/mips/mm/pgtable-32.c b/arch/mips/mm/pgtable-32.c index 74492618f2ae..4a3c4919e314 100644 --- a/arch/mips/mm/pgtable-32.c +++ b/arch/mips/mm/pgtable-32.c | |||
@@ -35,6 +35,7 @@ void __init pagetable_init(void) | |||
35 | #ifdef CONFIG_HIGHMEM | 35 | #ifdef CONFIG_HIGHMEM |
36 | unsigned long vaddr; | 36 | unsigned long vaddr; |
37 | pgd_t *pgd, *pgd_base; | 37 | pgd_t *pgd, *pgd_base; |
38 | pud_t *pud; | ||
38 | pmd_t *pmd; | 39 | pmd_t *pmd; |
39 | pte_t *pte; | 40 | pte_t *pte; |
40 | #endif | 41 | #endif |
@@ -60,7 +61,8 @@ void __init pagetable_init(void) | |||
60 | fixrange_init(vaddr, vaddr + PAGE_SIZE*LAST_PKMAP, pgd_base); | 61 | fixrange_init(vaddr, vaddr + PAGE_SIZE*LAST_PKMAP, pgd_base); |
61 | 62 | ||
62 | pgd = swapper_pg_dir + __pgd_offset(vaddr); | 63 | pgd = swapper_pg_dir + __pgd_offset(vaddr); |
63 | pmd = pmd_offset(pgd, vaddr); | 64 | pud = pud_offset(pgd, vaddr); |
65 | pmd = pmd_offset(pud, vaddr); | ||
64 | pte = pte_offset_kernel(pmd, vaddr); | 66 | pte = pte_offset_kernel(pmd, vaddr); |
65 | pkmap_page_table = pte; | 67 | pkmap_page_table = pte; |
66 | #endif | 68 | #endif |
diff --git a/arch/mips/mm/tlb-andes.c b/arch/mips/mm/tlb-andes.c index 167e08e9661a..3f422a849c41 100644 --- a/arch/mips/mm/tlb-andes.c +++ b/arch/mips/mm/tlb-andes.c | |||
@@ -195,6 +195,7 @@ void __update_tlb(struct vm_area_struct * vma, unsigned long address, pte_t pte) | |||
195 | { | 195 | { |
196 | unsigned long flags; | 196 | unsigned long flags; |
197 | pgd_t *pgdp; | 197 | pgd_t *pgdp; |
198 | pud_t *pudp; | ||
198 | pmd_t *pmdp; | 199 | pmd_t *pmdp; |
199 | pte_t *ptep; | 200 | pte_t *ptep; |
200 | int idx, pid; | 201 | int idx, pid; |
@@ -220,7 +221,8 @@ void __update_tlb(struct vm_area_struct * vma, unsigned long address, pte_t pte) | |||
220 | write_c0_entryhi(address | (pid)); | 221 | write_c0_entryhi(address | (pid)); |
221 | pgdp = pgd_offset(vma->vm_mm, address); | 222 | pgdp = pgd_offset(vma->vm_mm, address); |
222 | tlb_probe(); | 223 | tlb_probe(); |
223 | pmdp = pmd_offset(pgdp, address); | 224 | pudp = pud_offset(pgdp, address); |
225 | pmdp = pmd_offset(pudp, address); | ||
224 | idx = read_c0_index(); | 226 | idx = read_c0_index(); |
225 | ptep = pte_offset_map(pmdp, address); | 227 | ptep = pte_offset_map(pmdp, address); |
226 | write_c0_entrylo0(pte_val(*ptep++) >> 6); | 228 | write_c0_entrylo0(pte_val(*ptep++) >> 6); |
diff --git a/arch/mips/mm/tlb-r4k.c b/arch/mips/mm/tlb-r4k.c index 09249a756016..08702202758d 100644 --- a/arch/mips/mm/tlb-r4k.c +++ b/arch/mips/mm/tlb-r4k.c | |||
@@ -227,6 +227,7 @@ void __update_tlb(struct vm_area_struct * vma, unsigned long address, pte_t pte) | |||
227 | { | 227 | { |
228 | unsigned long flags; | 228 | unsigned long flags; |
229 | pgd_t *pgdp; | 229 | pgd_t *pgdp; |
230 | pud_t *pudp; | ||
230 | pmd_t *pmdp; | 231 | pmd_t *pmdp; |
231 | pte_t *ptep; | 232 | pte_t *ptep; |
232 | int idx, pid; | 233 | int idx, pid; |
@@ -246,7 +247,8 @@ void __update_tlb(struct vm_area_struct * vma, unsigned long address, pte_t pte) | |||
246 | mtc0_tlbw_hazard(); | 247 | mtc0_tlbw_hazard(); |
247 | tlb_probe(); | 248 | tlb_probe(); |
248 | BARRIER; | 249 | BARRIER; |
249 | pmdp = pmd_offset(pgdp, address); | 250 | pudp = pud_offset(pgdp, address); |
251 | pmdp = pmd_offset(pudp, address); | ||
250 | idx = read_c0_index(); | 252 | idx = read_c0_index(); |
251 | ptep = pte_offset_map(pmdp, address); | 253 | ptep = pte_offset_map(pmdp, address); |
252 | 254 | ||