/openbmc/linux/arch/powerpc/mm/book3s64/ |
H A D | hash_64k.c | 71 } while (!pte_xchg(ptep, __pte(old_pte), __pte(new_pte))); in __hash_page_4K() 86 rflags = hash_page_do_lazy_icache(rflags, __pte(old_pte), trap); in __hash_page_4K() 91 rpte = __real_pte(__pte(old_pte), ptep, PTRS_PER_PTE); in __hash_page_4K() 131 *ptep = __pte(new_pte & ~H_PAGE_BUSY); in __hash_page_4K() 152 pa = pte_pfn(__pte(old_pte)) << HW_PAGE_SHIFT; in __hash_page_4K() 154 pa = pte_pfn(__pte(old_pte)) << PAGE_SHIFT; in __hash_page_4K() 212 *ptep = __pte(old_pte); in __hash_page_4K() 224 *ptep = __pte(new_pte & ~H_PAGE_BUSY); in __hash_page_4K() 266 } while (!pte_xchg(ptep, __pte(old_pte), __pte(new_pte))); in __hash_page_64K() 269 rpte = __real_pte(__pte(old_pte), ptep, PTRS_PER_PTE); in __hash_page_64K() [all …]
|
H A D | hugetlbpage.c | 64 } while(!pte_xchg(ptep, __pte(old_pte), __pte(new_pte))); in __hash_page_huge() 75 rpte = __real_pte(__pte(old_pte), ptep, offset); in __hash_page_huge() 82 rflags = hash_page_do_lazy_icache(rflags, __pte(old_pte), trap); in __hash_page_huge() 98 pa = pte_pfn(__pte(old_pte)) << PAGE_SHIFT; in __hash_page_huge() 111 *ptep = __pte(old_pte); in __hash_page_huge() 123 *ptep = __pte(new_pte & ~H_PAGE_BUSY); in __hash_page_huge() 140 return __pte(pte_val); in huge_ptep_modify_prot_start()
|
H A D | hash_4k.c | 53 } while (!pte_xchg(ptep, __pte(old_pte), __pte(new_pte))); in __hash_page_4K() 60 rpte = __real_pte(__pte(old_pte), ptep, PTRS_PER_PTE); in __hash_page_4K() 64 rflags = hash_page_do_lazy_icache(rflags, __pte(old_pte), trap); in __hash_page_4K() 81 pa = pte_pfn(__pte(old_pte)) << PAGE_SHIFT; in __hash_page_4K() 116 *ptep = __pte(old_pte); in __hash_page_4K() 127 *ptep = __pte(new_pte & ~H_PAGE_BUSY); in __hash_page_4K()
|
/openbmc/linux/drivers/iommu/amd/ |
H A D | io_pgtable_v2.c | 147 u64 __pte, __npte; in v2_alloc_pte() local 149 __pte = *pte; in v2_alloc_pte() 151 if (IOMMU_PTE_PRESENT(__pte) && is_large_pte(__pte)) { in v2_alloc_pte() 158 if (!IOMMU_PTE_PRESENT(__pte)) { in v2_alloc_pte() 165 if (cmpxchg64(pte, __pte, __npte) != __pte) in v2_alloc_pte() 167 else if (IOMMU_PTE_PRESENT(__pte)) in v2_alloc_pte() 174 pte = get_pgtable_pte(__pte); in v2_alloc_pte() 180 u64 *__pte; in v2_alloc_pte() local 183 __pte = get_pgtable_pte(*pte); in v2_alloc_pte() 186 free_pgtable(__pte, end_level - 1); in v2_alloc_pte() [all …]
|
H A D | io_pgtable.c | 223 u64 __pte, __npte; in alloc_pte() local 226 __pte = *pte; in alloc_pte() 227 pte_level = PM_PTE_LEVEL(__pte); in alloc_pte() 233 if (IOMMU_PTE_PRESENT(__pte) && in alloc_pte() 245 cmpxchg64(&lpte[i], __pte, 0ULL); in alloc_pte() 251 if (!IOMMU_PTE_PRESENT(__pte) || in alloc_pte() 261 if (!try_cmpxchg64(pte, &__pte, __npte)) in alloc_pte() 263 else if (IOMMU_PTE_PRESENT(__pte)) in alloc_pte() 275 pte = IOMMU_PTE_PAGE(__pte); in alloc_pte() 370 u64 __pte, *pte; in iommu_v1_map_pages() local [all …]
|
/openbmc/linux/arch/sparc/include/asm/ |
H A D | pgtable_32.h | 160 set_pte(ptep, __pte(0)); in __pte_clear() 185 set_pte((pte_t *)&pmd_val(*pmdp), __pte(0)); in pmd_clear() 205 set_pte((pte_t *)pudp, __pte(0)); in pud_clear() 229 return __pte(pte_val(pte) & ~SRMMU_WRITE); in pte_wrprotect() 234 return __pte(pte_val(pte) & ~SRMMU_DIRTY); in pte_mkclean() 239 return __pte(pte_val(pte) & ~SRMMU_REF); in pte_mkold() 244 return __pte(pte_val(pte) | SRMMU_WRITE); in pte_mkwrite_novma() 249 return __pte(pte_val(pte) | SRMMU_DIRTY); in pte_mkdirty() 254 return __pte(pte_val(pte) | SRMMU_REF); in pte_mkyoung() 281 return __pte((page_to_pfn(page) << (PAGE_SHIFT-4)) | pgprot_val(pgprot)); in mk_pte() [all …]
|
H A D | pgtable_64.h | 226 return __pte(paddr | pgprot_val(prot)); in pfn_pte() 317 return __pte((pte_val(pte) & mask) | (pgprot_val(prot) & ~mask)); in pte_modify() 323 pte_t pte = __pte(pmd_val(pmd)); in pmd_modify() 420 return __pte(pte_val(pte) | __pte_default_huge_mask()); in pte_mkhuge() 443 pte_t pte = __pte(pmd_val(pmd)); in pmd_mkhuge() 475 return __pte(val); in __pte_mkhwwrite() 493 pte = __pte(val | mask); in pte_mkdirty() 518 return __pte(val); in pte_mkclean() 536 pte = __pte(val | mask); in pte_mkwrite_novma() 561 return __pte(val); in pte_wrprotect() [all …]
|
/openbmc/linux/arch/powerpc/include/asm/book3s/32/ |
H A D | pgtable.h | 311 *p = __pte((old & ~(pte_basic_t)clr) | set); in pte_update() 339 return __pte(pte_update(mm, addr, ptep, ~_PAGE_HASHPTE, 0, 0)); in ptep_get_and_clear() 396 return __pte(pte_val(pte) | _PAGE_SWP_EXCLUSIVE); in pte_swp_mkexclusive() 401 return __pte(pte_val(pte) & ~_PAGE_SWP_EXCLUSIVE); in pte_swp_clear_exclusive() 461 return __pte(((pte_basic_t)(pfn) << PTE_RPN_SHIFT) | in pfn_pte() 468 return __pte(pte_val(pte) & ~_PAGE_RW); in pte_wrprotect() 473 return __pte(pte_val(pte) & ~_PAGE_EXEC); in pte_exprotect() 478 return __pte(pte_val(pte) & ~_PAGE_DIRTY); in pte_mkclean() 483 return __pte(pte_val(pte) & ~_PAGE_ACCESSED); in pte_mkold() 488 return __pte(pte_val(pte) | _PAGE_EXEC); in pte_mkexec() [all …]
|
/openbmc/linux/arch/powerpc/include/asm/nohash/ |
H A D | pgtable.h | 104 return __pte(((pte_basic_t)(pfn) << PTE_RPN_SHIFT) | in pfn_pte() 110 return __pte(pte_val(pte) & ~_PAGE_EXEC); in pte_exprotect() 115 return __pte(pte_val(pte) & ~_PAGE_DIRTY); in pte_mkclean() 120 return __pte(pte_val(pte) & ~_PAGE_ACCESSED); in pte_mkold() 125 return __pte(pte_val(pte) | _PAGE_SPECIAL); in pte_mkspecial() 131 return __pte(pte_val(pte)); in pte_mkhuge() 138 return __pte(pte_val(pte) & ~_PAGE_USER); in pte_mkprivileged() 145 return __pte(pte_val(pte) | _PAGE_USER); in pte_mkuser() 151 return __pte((pte_val(pte) & _PAGE_CHG_MASK) | pgprot_val(newprot)); in pte_modify() 161 return __pte(pte_val(pte) | _PAGE_SWP_EXCLUSIVE); in pte_swp_mkexclusive() [all …]
|
H A D | pte-e500.h | 104 return __pte((pte_val(pte) & ~_PAGE_USER) | _PAGE_PRIVILEGED); in pte_mkprivileged() 111 return __pte((pte_val(pte) & ~_PAGE_PRIVILEGED) | _PAGE_USER); in pte_mkuser() 119 return __pte((pte_val(pte) & ~_PAGE_BAP_SX) | _PAGE_BAP_UX); in pte_mkexec() 121 return __pte((pte_val(pte) & ~_PAGE_BAP_UX) | _PAGE_BAP_SX); in pte_mkexec()
|
/openbmc/linux/arch/ia64/include/asm/ |
H A D | pgtable.h | 215 ({ pte_t __pte; pte_val(__pte) = ((pfn) << PAGE_SHIFT) | pgprot_val(pgprot); __pte; }) 224 ({ pte_t __pte; pte_val(__pte) = physpage + pgprot_val(pgprot); __pte; }) 227 (__pte((pte_val(_pte) & ~_PAGE_CHG_MASK) | (pgprot_val(newprot) & _PAGE_CHG_MASK))) 271 #define pte_wrprotect(pte) (__pte(pte_val(pte) & ~_PAGE_AR_RW)) 272 #define pte_mkwrite_novma(pte) (__pte(pte_val(pte) | _PAGE_AR_RW)) 273 #define pte_mkold(pte) (__pte(pte_val(pte) & ~_PAGE_A)) 274 #define pte_mkyoung(pte) (__pte(pte_val(pte) | _PAGE_A)) 275 #define pte_mkclean(pte) (__pte(pte_val(pte) & ~_PAGE_D)) 276 #define pte_mkdirty(pte) (__pte(pte_val(pte) | _PAGE_D)) 277 #define pte_mkhuge(pte) (__pte(pte_val(pte))) [all …]
|
/openbmc/linux/arch/powerpc/include/asm/nohash/64/ |
H A D | pgtable.h | 90 return __pte(pte_val(pte) | _PAGE_RW); in pte_mkwrite_novma() 95 return __pte(pte_val(pte) | _PAGE_DIRTY); in pte_mkdirty() 100 return __pte(pte_val(pte) | _PAGE_ACCESSED); in pte_mkyoung() 105 return __pte(pte_val(pte) & ~_PAGE_RW); in pte_wrprotect() 123 return __pte(pmd_val(pmd)); in pmd_pte() 158 return __pte(pud_val(pud)); in pud_pte() 181 *ptep = __pte((old & ~clr) | set); in pte_update() 247 return __pte(old); in ptep_get_and_clear() 267 *ptep = __pte(old | bits); in __ptep_set_access_flags() 308 #define __swp_entry_to_pte(x) __pte((x).val)
|
/openbmc/linux/arch/riscv/include/asm/ |
H A D | pgtable.h | 285 return __pte(pmd_val(pmd)); in pmd_pte() 290 return __pte(pud_val(pud)); in pud_pte() 311 return __pte((pte_val(pte) & napot_mask) | napot_bit | _PAGE_NAPOT); in pte_mknapot() 345 return __pte((pfn << _PAGE_PFN_SHIFT) | prot_val); in pfn_pte() 399 return __pte(pte_val(pte) & ~(_PAGE_WRITE)); in pte_wrprotect() 406 return __pte(pte_val(pte) | _PAGE_WRITE); in pte_mkwrite_novma() 413 return __pte(pte_val(pte) | _PAGE_DIRTY); in pte_mkdirty() 418 return __pte(pte_val(pte) & ~(_PAGE_DIRTY)); in pte_mkclean() 423 return __pte(pte_val(pte) | _PAGE_ACCESSED); in pte_mkyoung() 428 return __pte(pte_va in pte_mkold() [all...] |
H A D | kfence.h | 21 set_pte(pte, __pte(pte_val(ptep_get(pte)) & ~_PAGE_PRESENT)); in kfence_protect_page() 23 set_pte(pte, __pte(pte_val(ptep_get(pte)) | _PAGE_PRESENT)); in kfence_protect_page()
|
/openbmc/linux/arch/xtensa/mm/ |
H A D | mmu.c | 110 write_dtlb_entry(__pte(xtensa_kio_paddr + CA_WRITEBACK), in init_kio() 112 write_itlb_entry(__pte(xtensa_kio_paddr + CA_WRITEBACK), in init_kio() 114 write_dtlb_entry(__pte(xtensa_kio_paddr + CA_BYPASS), in init_kio() 116 write_itlb_entry(__pte(xtensa_kio_paddr + CA_BYPASS), in init_kio()
|
/openbmc/linux/arch/powerpc/include/asm/nohash/32/ |
H A D | hugetlb-8xx.h | 63 unsigned long clr = ~pte_val(pte_wrprotect(__pte(~0))); in huge_ptep_set_wrprotect() 64 unsigned long set = pte_val(pte_wrprotect(__pte(0))); in huge_ptep_set_wrprotect() 75 return __pte(pte_val(entry) | _PAGE_SPS); in arch_make_huge_pte() 77 return __pte(pte_val(entry) | _PAGE_SPS | _PAGE_HUGE); in arch_make_huge_pte()
|
H A D | pte-8xx.h | 92 return __pte(pte_val(pte) | _PAGE_RO); in pte_wrprotect() 113 return __pte(pte_val(pte) & ~_PAGE_RO); in pte_mkwrite_novma() 127 return __pte(pte_val(pte) | _PAGE_SH); in pte_mkprivileged() 134 return __pte(pte_val(pte) & ~_PAGE_SH); in pte_mkuser() 141 return __pte(pte_val(pte) | _PAGE_SPS | _PAGE_HUGE); in pte_mkhuge()
|
H A D | pgtable.h | 176 return __pte(pte_val(pte) | _PAGE_RW); in pte_mkwrite_novma() 182 return __pte(pte_val(pte) | _PAGE_DIRTY); in pte_mkdirty() 187 return __pte(pte_val(pte) | _PAGE_ACCESSED); in pte_mkyoung() 193 return __pte(pte_val(pte) & ~_PAGE_RW); in pte_wrprotect() 200 return __pte(pte_val(pte) | _PAGE_EXEC); in pte_mkexec() 289 *p = __pte(new); in pte_update() 314 return __pte(pte_update(mm, addr, ptep, ~0, 0, 0)); in ptep_get_and_clear()
|
/openbmc/linux/arch/mips/include/asm/ |
H A D | page.h | 126 #define __pte(x) ({ pte_t __pte = {(x), ((unsigned long long)(x)) >> 32}; __pte; }) macro 130 #define __pte(x) ((pte_t) { (x) } ) macro 135 #define __pte(x) ((pte_t) { (x) } ) macro
|
/openbmc/linux/arch/sh/include/asm/ |
H A D | page.h | 81 #define __pte(x) \ macro 82 ({ pte_t __pte = {(x), ((unsigned long long)(x)) >> 32}; __pte; }) 88 #define __pte(x) ((pte_t) { (x) } ) macro
|
/openbmc/linux/arch/csky/include/asm/ |
H A D | pgtable.h | 35 (((unsigned int) addr >= PAGE_OFFSET) ? __pte(_PAGE_GLOBAL) : __pte(0))) 39 #define pfn_pte(pfn, prot) __pte(((unsigned long long)(pfn) << PAGE_SHIFT) \ 46 #define __mk_pte(page_nr, pgprot) __pte(((page_nr) << PAGE_SHIFT) | \ 259 return __pte((pte_val(pte) & _PAGE_CHG_MASK) | in pte_modify()
|
/openbmc/linux/arch/parisc/include/asm/ |
H A D | kfence.h | 35 set_pte(pte, __pte(pte_val(*pte) & ~_PAGE_PRESENT)); in kfence_protect_page() 37 set_pte(pte, __pte(pte_val(*pte) | _PAGE_PRESENT)); in kfence_protect_page()
|
/openbmc/linux/arch/s390/include/asm/ |
H A D | pgtable.h | 539 return __pte(pte_val(pte) & ~pgprot_val(prot)); in clear_pte_bit() 544 return __pte(pte_val(pte) | pgprot_val(prot)); in set_pte_bit() 982 set_pte(ptep, __pte(_PAGE_INVALID)); in pte_clear() 1157 res = ptep_xchg_lazy(mm, addr, ptep, __pte(_PAGE_INVALID)); in ptep_get_and_clear() 1175 res = ptep_xchg_direct(vma->vm_mm, addr, ptep, __pte(_PAGE_INVALID)); in ptep_clear_flush() 1198 set_pte(ptep, __pte(_PAGE_INVALID)); in ptep_get_and_clear_full() 1200 res = ptep_xchg_lazy(mm, addr, ptep, __pte(_PAGE_INVALID)); in ptep_get_and_clear_full() 1342 entry = __pte(pte_val(entry) + PAGE_SIZE); in set_ptes() 1351 entry = __pte(pte_val(entry) + PAGE_SIZE); in set_ptes() 1363 pte_t __pte; in mk_pte_phys() local [all …]
|
/openbmc/linux/arch/x86/include/asm/ |
H A D | kfence.h | 57 set_pte(pte, __pte(pte_val(*pte) & ~_PAGE_PRESENT)); in kfence_protect_page() 59 set_pte(pte, __pte(pte_val(*pte) | _PAGE_PRESENT)); in kfence_protect_page()
|
/openbmc/linux/arch/loongarch/include/asm/ |
H A D | kfence.h | 50 set_pte(pte, __pte(pte_val(*pte) & ~(_PAGE_VALID | _PAGE_PRESENT))); in kfence_protect_page() 52 set_pte(pte, __pte(pte_val(*pte) | (_PAGE_VALID | _PAGE_PRESENT))); in kfence_protect_page()
|