2 * This file is subject to the terms and conditions of the GNU General Public
3 * License. See the file "COPYING" in the main directory of this archive
6 * Copyright (C) 2003 Ralf Baechle
11 #include <linux/mm_types.h>
12 #include <linux/mmzone.h>
14 #include <asm/pgtable-32.h>
17 #include <asm/pgtable-64.h>
20 #include <asm/cmpxchg.h>
22 #include <asm/pgtable-bits.h>
23 #include <asm/cpu-features.h>
26 struct vm_area_struct;
28 #define PAGE_SHARED vm_get_page_prot(VM_READ|VM_WRITE|VM_SHARED)
30 #define PAGE_KERNEL __pgprot(_PAGE_PRESENT | __READABLE | __WRITEABLE | \
31 _PAGE_GLOBAL | _page_cachable_default)
32 #define PAGE_KERNEL_NC __pgprot(_PAGE_PRESENT | __READABLE | __WRITEABLE | \
33 _PAGE_GLOBAL | _CACHE_CACHABLE_NONCOHERENT)
34 #define PAGE_KERNEL_UNCACHED __pgprot(_PAGE_PRESENT | __READABLE | \
35 __WRITEABLE | _PAGE_GLOBAL | _CACHE_UNCACHED)
38 * If _PAGE_NO_EXEC is not defined, we can't do page protection for
39 * execute, and consider it to be the same as read. Also, write
40 * permissions imply read permissions. This is the closest we can get
41 * by reasonable means..
44 extern unsigned long _page_cachable_default;
45 extern void __update_cache(unsigned long address, pte_t pte);
48 * ZERO_PAGE is a global shared page that is always zero; used
49 * for zero-mapped memory areas etc..
52 extern unsigned long empty_zero_page;
53 extern unsigned long zero_page_mask;
55 #define ZERO_PAGE(vaddr) \
56 (virt_to_page((void *)(empty_zero_page + (((unsigned long)(vaddr)) & zero_page_mask))))
57 #define __HAVE_COLOR_ZERO_PAGE
59 extern void paging_init(void);
62 * Conversion functions: convert a page and protection to a page entry,
63 * and a page entry and page directory to the page they refer to.
65 #define pmd_phys(pmd) virt_to_phys((void *)pmd_val(pmd))
67 static inline unsigned long pmd_pfn(pmd_t pmd)
69 return pmd_val(pmd) >> _PFN_SHIFT;
72 #ifndef CONFIG_MIPS_HUGE_TLB_SUPPORT
73 #define pmd_page(pmd) (pfn_to_page(pmd_phys(pmd) >> PAGE_SHIFT))
74 #endif /* CONFIG_MIPS_HUGE_TLB_SUPPORT */
76 #define pmd_page_vaddr(pmd) pmd_val(pmd)
80 unsigned long __flags; \
83 local_irq_save(__flags); \
84 if(!raw_current_cpu_data.htw_seq++) { \
85 write_c0_pwctl(read_c0_pwctl() & \
86 ~(1 << MIPS_PWCTL_PWEN_SHIFT)); \
87 back_to_back_c0_hazard(); \
89 local_irq_restore(__flags); \
95 unsigned long __flags; \
98 local_irq_save(__flags); \
99 if (!--raw_current_cpu_data.htw_seq) { \
100 write_c0_pwctl(read_c0_pwctl() | \
101 (1 << MIPS_PWCTL_PWEN_SHIFT)); \
102 back_to_back_c0_hazard(); \
104 local_irq_restore(__flags); \
108 static inline void set_pte_at(struct mm_struct *mm, unsigned long addr,
109 pte_t *ptep, pte_t pteval);
111 #if defined(CONFIG_PHYS_ADDR_T_64BIT) && defined(CONFIG_CPU_MIPS32)
114 # define pte_none(pte) (!(((pte).pte_high) & ~_PAGE_GLOBAL))
116 # define pte_none(pte) (!(((pte).pte_low | (pte).pte_high) & ~_PAGE_GLOBAL))
119 #define pte_present(pte) ((pte).pte_low & _PAGE_PRESENT)
120 #define pte_no_exec(pte) ((pte).pte_low & _PAGE_NO_EXEC)
122 static inline void set_pte(pte_t *ptep, pte_t pte)
124 ptep->pte_high = pte.pte_high;
126 ptep->pte_low = pte.pte_low;
129 if (pte.pte_high & _PAGE_GLOBAL) {
131 if (pte.pte_low & _PAGE_GLOBAL) {
133 pte_t *buddy = ptep_buddy(ptep);
135 * Make sure the buddy is global too (if it's !none,
136 * it better already be global)
138 if (pte_none(*buddy)) {
139 if (!IS_ENABLED(CONFIG_XPA))
140 buddy->pte_low |= _PAGE_GLOBAL;
141 buddy->pte_high |= _PAGE_GLOBAL;
146 static inline void pte_clear(struct mm_struct *mm, unsigned long addr, pte_t *ptep)
148 pte_t null = __pte(0);
151 /* Preserve global status for the pair */
152 if (IS_ENABLED(CONFIG_XPA)) {
153 if (ptep_buddy(ptep)->pte_high & _PAGE_GLOBAL)
154 null.pte_high = _PAGE_GLOBAL;
156 if (ptep_buddy(ptep)->pte_low & _PAGE_GLOBAL)
157 null.pte_low = null.pte_high = _PAGE_GLOBAL;
160 set_pte_at(mm, addr, ptep, null);
165 #define pte_none(pte) (!(pte_val(pte) & ~_PAGE_GLOBAL))
166 #define pte_present(pte) (pte_val(pte) & _PAGE_PRESENT)
167 #define pte_no_exec(pte) (pte_val(pte) & _PAGE_NO_EXEC)
170 * Certain architectures need to do special things when pte's
171 * within a page table are directly modified. Thus, the following
172 * hook is made available.
174 static inline void set_pte(pte_t *ptep, pte_t pteval)
177 #if !defined(CONFIG_CPU_R3K_TLB)
178 if (pte_val(pteval) & _PAGE_GLOBAL) {
179 pte_t *buddy = ptep_buddy(ptep);
181 * Make sure the buddy is global too (if it's !none,
182 * it better already be global)
184 # if defined(CONFIG_PHYS_ADDR_T_64BIT) && !defined(CONFIG_CPU_MIPS32)
185 cmpxchg64(&buddy->pte, 0, _PAGE_GLOBAL);
187 cmpxchg(&buddy->pte, 0, _PAGE_GLOBAL);
193 static inline void pte_clear(struct mm_struct *mm, unsigned long addr, pte_t *ptep)
196 #if !defined(CONFIG_CPU_R3K_TLB)
197 /* Preserve global status for the pair */
198 if (pte_val(*ptep_buddy(ptep)) & _PAGE_GLOBAL)
199 set_pte_at(mm, addr, ptep, __pte(_PAGE_GLOBAL));
202 set_pte_at(mm, addr, ptep, __pte(0));
207 static inline void set_pte_at(struct mm_struct *mm, unsigned long addr,
208 pte_t *ptep, pte_t pteval)
211 if (!pte_present(pteval))
212 goto cache_sync_done;
214 if (pte_present(*ptep) && (pte_pfn(*ptep) == pte_pfn(pteval)))
215 goto cache_sync_done;
217 __update_cache(addr, pteval);
219 set_pte(ptep, pteval);
223 * (pmds are folded into puds so this doesn't get actually called,
224 * but the define is needed for a generic inline function.)
226 #define set_pmd(pmdptr, pmdval) do { *(pmdptr) = (pmdval); } while(0)
228 #ifndef __PAGETABLE_PMD_FOLDED
230 * (puds are folded into pgds so this doesn't get actually called,
231 * but the define is needed for a generic inline function.)
233 #define set_pud(pudptr, pudval) do { *(pudptr) = (pudval); } while(0)
236 #define PGD_T_LOG2 (__builtin_ffs(sizeof(pgd_t)) - 1)
237 #define PMD_T_LOG2 (__builtin_ffs(sizeof(pmd_t)) - 1)
238 #define PTE_T_LOG2 (__builtin_ffs(sizeof(pte_t)) - 1)
241 * We used to declare this array with size but gcc 3.3 and older are not able
242 * to find that this expression is a constant, so the size is dropped.
244 extern pgd_t swapper_pg_dir[];
247 * Platform specific pte_special() and pte_mkspecial() definitions
248 * are required only when ARCH_HAS_PTE_SPECIAL is enabled.
250 #if defined(CONFIG_ARCH_HAS_PTE_SPECIAL)
251 #if defined(CONFIG_PHYS_ADDR_T_64BIT) && defined(CONFIG_CPU_MIPS32)
252 static inline int pte_special(pte_t pte)
254 return pte.pte_low & _PAGE_SPECIAL;
257 static inline pte_t pte_mkspecial(pte_t pte)
259 pte.pte_low |= _PAGE_SPECIAL;
263 static inline int pte_special(pte_t pte)
265 return pte_val(pte) & _PAGE_SPECIAL;
268 static inline pte_t pte_mkspecial(pte_t pte)
270 pte_val(pte) |= _PAGE_SPECIAL;
274 #endif /* CONFIG_ARCH_HAS_PTE_SPECIAL */
277 * The following only work if pte_present() is true.
278 * Undefined behaviour if not..
280 #if defined(CONFIG_PHYS_ADDR_T_64BIT) && defined(CONFIG_CPU_MIPS32)
281 static inline int pte_write(pte_t pte) { return pte.pte_low & _PAGE_WRITE; }
282 static inline int pte_dirty(pte_t pte) { return pte.pte_low & _PAGE_MODIFIED; }
283 static inline int pte_young(pte_t pte) { return pte.pte_low & _PAGE_ACCESSED; }
285 static inline pte_t pte_wrprotect(pte_t pte)
287 pte.pte_low &= ~_PAGE_WRITE;
288 if (!IS_ENABLED(CONFIG_XPA))
289 pte.pte_low &= ~_PAGE_SILENT_WRITE;
290 pte.pte_high &= ~_PAGE_SILENT_WRITE;
294 static inline pte_t pte_mkclean(pte_t pte)
296 pte.pte_low &= ~_PAGE_MODIFIED;
297 if (!IS_ENABLED(CONFIG_XPA))
298 pte.pte_low &= ~_PAGE_SILENT_WRITE;
299 pte.pte_high &= ~_PAGE_SILENT_WRITE;
303 static inline pte_t pte_mkold(pte_t pte)
305 pte.pte_low &= ~_PAGE_ACCESSED;
306 if (!IS_ENABLED(CONFIG_XPA))
307 pte.pte_low &= ~_PAGE_SILENT_READ;
308 pte.pte_high &= ~_PAGE_SILENT_READ;
312 static inline pte_t pte_mkwrite(pte_t pte)
314 pte.pte_low |= _PAGE_WRITE;
315 if (pte.pte_low & _PAGE_MODIFIED) {
316 if (!IS_ENABLED(CONFIG_XPA))
317 pte.pte_low |= _PAGE_SILENT_WRITE;
318 pte.pte_high |= _PAGE_SILENT_WRITE;
323 static inline pte_t pte_mkdirty(pte_t pte)
325 pte.pte_low |= _PAGE_MODIFIED;
326 if (pte.pte_low & _PAGE_WRITE) {
327 if (!IS_ENABLED(CONFIG_XPA))
328 pte.pte_low |= _PAGE_SILENT_WRITE;
329 pte.pte_high |= _PAGE_SILENT_WRITE;
334 static inline pte_t pte_mkyoung(pte_t pte)
336 pte.pte_low |= _PAGE_ACCESSED;
337 if (!(pte.pte_low & _PAGE_NO_READ)) {
338 if (!IS_ENABLED(CONFIG_XPA))
339 pte.pte_low |= _PAGE_SILENT_READ;
340 pte.pte_high |= _PAGE_SILENT_READ;
345 static inline int pte_write(pte_t pte) { return pte_val(pte) & _PAGE_WRITE; }
346 static inline int pte_dirty(pte_t pte) { return pte_val(pte) & _PAGE_MODIFIED; }
347 static inline int pte_young(pte_t pte) { return pte_val(pte) & _PAGE_ACCESSED; }
349 static inline pte_t pte_wrprotect(pte_t pte)
351 pte_val(pte) &= ~(_PAGE_WRITE | _PAGE_SILENT_WRITE);
355 static inline pte_t pte_mkclean(pte_t pte)
357 pte_val(pte) &= ~(_PAGE_MODIFIED | _PAGE_SILENT_WRITE);
361 static inline pte_t pte_mkold(pte_t pte)
363 pte_val(pte) &= ~(_PAGE_ACCESSED | _PAGE_SILENT_READ);
367 static inline pte_t pte_mkwrite(pte_t pte)
369 pte_val(pte) |= _PAGE_WRITE;
370 if (pte_val(pte) & _PAGE_MODIFIED)
371 pte_val(pte) |= _PAGE_SILENT_WRITE;
375 static inline pte_t pte_mkdirty(pte_t pte)
377 pte_val(pte) |= _PAGE_MODIFIED | _PAGE_SOFT_DIRTY;
378 if (pte_val(pte) & _PAGE_WRITE)
379 pte_val(pte) |= _PAGE_SILENT_WRITE;
383 static inline pte_t pte_mkyoung(pte_t pte)
385 pte_val(pte) |= _PAGE_ACCESSED;
386 if (!(pte_val(pte) & _PAGE_NO_READ))
387 pte_val(pte) |= _PAGE_SILENT_READ;
391 #define pte_sw_mkyoung pte_mkyoung
393 #ifdef CONFIG_MIPS_HUGE_TLB_SUPPORT
394 static inline int pte_huge(pte_t pte) { return pte_val(pte) & _PAGE_HUGE; }
396 static inline pte_t pte_mkhuge(pte_t pte)
398 pte_val(pte) |= _PAGE_HUGE;
402 #define pmd_write pmd_write
403 static inline int pmd_write(pmd_t pmd)
405 return !!(pmd_val(pmd) & _PAGE_WRITE);
408 static inline struct page *pmd_page(pmd_t pmd)
410 if (pmd_val(pmd) & _PAGE_HUGE)
411 return pfn_to_page(pmd_pfn(pmd));
413 return pfn_to_page(pmd_phys(pmd) >> PAGE_SHIFT);
415 #endif /* CONFIG_MIPS_HUGE_TLB_SUPPORT */
417 #ifdef CONFIG_HAVE_ARCH_SOFT_DIRTY
418 static inline bool pte_soft_dirty(pte_t pte)
420 return pte_val(pte) & _PAGE_SOFT_DIRTY;
422 #define pte_swp_soft_dirty pte_soft_dirty
424 static inline pte_t pte_mksoft_dirty(pte_t pte)
426 pte_val(pte) |= _PAGE_SOFT_DIRTY;
429 #define pte_swp_mksoft_dirty pte_mksoft_dirty
431 static inline pte_t pte_clear_soft_dirty(pte_t pte)
433 pte_val(pte) &= ~(_PAGE_SOFT_DIRTY);
436 #define pte_swp_clear_soft_dirty pte_clear_soft_dirty
438 #endif /* CONFIG_HAVE_ARCH_SOFT_DIRTY */
443 * Macro to make mark a page protection value as "uncacheable". Note
444 * that "protection" is really a misnomer here as the protection value
445 * contains the memory attribute bits, dirty bits, and various other
448 #define pgprot_noncached pgprot_noncached
450 static inline pgprot_t pgprot_noncached(pgprot_t _prot)
452 unsigned long prot = pgprot_val(_prot);
454 prot = (prot & ~_CACHE_MASK) | _CACHE_UNCACHED;
456 return __pgprot(prot);
459 #define pgprot_writecombine pgprot_writecombine
461 static inline pgprot_t pgprot_writecombine(pgprot_t _prot)
463 unsigned long prot = pgprot_val(_prot);
465 /* cpu_data[0].writecombine is already shifted by _CACHE_SHIFT */
466 prot = (prot & ~_CACHE_MASK) | cpu_data[0].writecombine;
468 return __pgprot(prot);
471 static inline void flush_tlb_fix_spurious_fault(struct vm_area_struct *vma,
472 unsigned long address)
476 #define __HAVE_ARCH_PTE_SAME
477 static inline int pte_same(pte_t pte_a, pte_t pte_b)
479 return pte_val(pte_a) == pte_val(pte_b);
482 #define __HAVE_ARCH_PTEP_SET_ACCESS_FLAGS
483 static inline int ptep_set_access_flags(struct vm_area_struct *vma,
484 unsigned long address, pte_t *ptep,
485 pte_t entry, int dirty)
487 if (!pte_same(*ptep, entry))
488 set_pte_at(vma->vm_mm, address, ptep, entry);
490 * update_mmu_cache will unconditionally execute, handling both
491 * the case that the PTE changed and the spurious fault case.
497 * Conversion functions: convert a page and protection to a page entry,
498 * and a page entry and page directory to the page they refer to.
500 #define mk_pte(page, pgprot) pfn_pte(page_to_pfn(page), (pgprot))
502 #if defined(CONFIG_XPA)
503 static inline pte_t pte_modify(pte_t pte, pgprot_t newprot)
505 pte.pte_low &= (_PAGE_MODIFIED | _PAGE_ACCESSED | _PFNX_MASK);
506 pte.pte_high &= (_PFN_MASK | _CACHE_MASK);
507 pte.pte_low |= pgprot_val(newprot) & ~_PFNX_MASK;
508 pte.pte_high |= pgprot_val(newprot) & ~(_PFN_MASK | _CACHE_MASK);
511 #elif defined(CONFIG_PHYS_ADDR_T_64BIT) && defined(CONFIG_CPU_MIPS32)
512 static inline pte_t pte_modify(pte_t pte, pgprot_t newprot)
514 pte.pte_low &= _PAGE_CHG_MASK;
515 pte.pte_high &= (_PFN_MASK | _CACHE_MASK);
516 pte.pte_low |= pgprot_val(newprot);
517 pte.pte_high |= pgprot_val(newprot) & ~(_PFN_MASK | _CACHE_MASK);
521 static inline pte_t pte_modify(pte_t pte, pgprot_t newprot)
523 pte_val(pte) &= _PAGE_CHG_MASK;
524 pte_val(pte) |= pgprot_val(newprot) & ~_PAGE_CHG_MASK;
525 if ((pte_val(pte) & _PAGE_ACCESSED) && !(pte_val(pte) & _PAGE_NO_READ))
526 pte_val(pte) |= _PAGE_SILENT_READ;
532 extern void __update_tlb(struct vm_area_struct *vma, unsigned long address,
535 static inline void update_mmu_cache(struct vm_area_struct *vma,
536 unsigned long address, pte_t *ptep)
539 __update_tlb(vma, address, pte);
542 #define __HAVE_ARCH_UPDATE_MMU_TLB
543 #define update_mmu_tlb update_mmu_cache
545 static inline void update_mmu_cache_pmd(struct vm_area_struct *vma,
546 unsigned long address, pmd_t *pmdp)
548 pte_t pte = *(pte_t *)pmdp;
550 __update_tlb(vma, address, pte);
554 * Allow physical addresses to be fixed up to help 36-bit peripherals.
556 #ifdef CONFIG_MIPS_FIXUP_BIGPHYS_ADDR
557 phys_addr_t fixup_bigphys_addr(phys_addr_t addr, phys_addr_t size);
558 int io_remap_pfn_range(struct vm_area_struct *vma, unsigned long vaddr,
559 unsigned long pfn, unsigned long size, pgprot_t prot);
560 #define io_remap_pfn_range io_remap_pfn_range
562 #define fixup_bigphys_addr(addr, size) (addr)
563 #endif /* CONFIG_MIPS_FIXUP_BIGPHYS_ADDR */
565 #ifdef CONFIG_TRANSPARENT_HUGEPAGE
567 /* We don't have hardware dirty/accessed bits, generic_pmdp_establish is fine.*/
568 #define pmdp_establish generic_pmdp_establish
570 #define has_transparent_hugepage has_transparent_hugepage
571 extern int has_transparent_hugepage(void);
573 static inline int pmd_trans_huge(pmd_t pmd)
575 return !!(pmd_val(pmd) & _PAGE_HUGE);
578 static inline pmd_t pmd_mkhuge(pmd_t pmd)
580 pmd_val(pmd) |= _PAGE_HUGE;
585 extern void set_pmd_at(struct mm_struct *mm, unsigned long addr,
586 pmd_t *pmdp, pmd_t pmd);
588 static inline pmd_t pmd_wrprotect(pmd_t pmd)
590 pmd_val(pmd) &= ~(_PAGE_WRITE | _PAGE_SILENT_WRITE);
594 static inline pmd_t pmd_mkwrite(pmd_t pmd)
596 pmd_val(pmd) |= _PAGE_WRITE;
597 if (pmd_val(pmd) & _PAGE_MODIFIED)
598 pmd_val(pmd) |= _PAGE_SILENT_WRITE;
603 static inline int pmd_dirty(pmd_t pmd)
605 return !!(pmd_val(pmd) & _PAGE_MODIFIED);
608 static inline pmd_t pmd_mkclean(pmd_t pmd)
610 pmd_val(pmd) &= ~(_PAGE_MODIFIED | _PAGE_SILENT_WRITE);
614 static inline pmd_t pmd_mkdirty(pmd_t pmd)
616 pmd_val(pmd) |= _PAGE_MODIFIED | _PAGE_SOFT_DIRTY;
617 if (pmd_val(pmd) & _PAGE_WRITE)
618 pmd_val(pmd) |= _PAGE_SILENT_WRITE;
623 #define pmd_young pmd_young
624 static inline int pmd_young(pmd_t pmd)
626 return !!(pmd_val(pmd) & _PAGE_ACCESSED);
629 static inline pmd_t pmd_mkold(pmd_t pmd)
631 pmd_val(pmd) &= ~(_PAGE_ACCESSED|_PAGE_SILENT_READ);
636 static inline pmd_t pmd_mkyoung(pmd_t pmd)
638 pmd_val(pmd) |= _PAGE_ACCESSED;
640 if (!(pmd_val(pmd) & _PAGE_NO_READ))
641 pmd_val(pmd) |= _PAGE_SILENT_READ;
646 #ifdef CONFIG_HAVE_ARCH_SOFT_DIRTY
647 static inline int pmd_soft_dirty(pmd_t pmd)
649 return !!(pmd_val(pmd) & _PAGE_SOFT_DIRTY);
652 static inline pmd_t pmd_mksoft_dirty(pmd_t pmd)
654 pmd_val(pmd) |= _PAGE_SOFT_DIRTY;
658 static inline pmd_t pmd_clear_soft_dirty(pmd_t pmd)
660 pmd_val(pmd) &= ~(_PAGE_SOFT_DIRTY);
664 #endif /* CONFIG_HAVE_ARCH_SOFT_DIRTY */
666 /* Extern to avoid header file madness */
667 extern pmd_t mk_pmd(struct page *page, pgprot_t prot);
669 static inline pmd_t pmd_modify(pmd_t pmd, pgprot_t newprot)
671 pmd_val(pmd) = (pmd_val(pmd) & (_PAGE_CHG_MASK | _PAGE_HUGE)) |
672 (pgprot_val(newprot) & ~_PAGE_CHG_MASK);
676 static inline pmd_t pmd_mkinvalid(pmd_t pmd)
678 pmd_val(pmd) &= ~(_PAGE_PRESENT | _PAGE_VALID | _PAGE_DIRTY);
684 * The generic version pmdp_huge_get_and_clear uses a version of pmd_clear() with a
685 * different prototype.
687 #define __HAVE_ARCH_PMDP_HUGE_GET_AND_CLEAR
688 static inline pmd_t pmdp_huge_get_and_clear(struct mm_struct *mm,
689 unsigned long address, pmd_t *pmdp)
698 #endif /* CONFIG_TRANSPARENT_HUGEPAGE */
701 #define pmd_leaf(pmd) ((pmd_val(pmd) & _PAGE_HUGE) != 0)
702 #define pud_leaf(pud) ((pud_val(pud) & _PAGE_HUGE) != 0)
705 #define gup_fast_permitted(start, end) (!cpu_has_dc_aliases)
708 * We provide our own get_unmapped area to cope with the virtual aliasing
709 * constraints placed on us by the cache architecture.
711 #define HAVE_ARCH_UNMAPPED_AREA
712 #define HAVE_ARCH_UNMAPPED_AREA_TOPDOWN
714 #endif /* _ASM_PGTABLE_H */