/Linux-v5.15/arch/powerpc/mm/book3s64/ |
D | hash_hugepage.c | 28 unsigned long old_pmd, new_pmd; in __hash_page_thp() local 38 old_pmd = pmd_val(pmd); in __hash_page_thp() 40 if (unlikely(old_pmd & H_PAGE_BUSY)) in __hash_page_thp() 43 if (unlikely(!check_pte_access(access, old_pmd))) in __hash_page_thp() 49 new_pmd = old_pmd | H_PAGE_BUSY | _PAGE_ACCESSED; in __hash_page_thp() 52 } while (!pmd_xchg(pmdp, __pmd(old_pmd), __pmd(new_pmd))); in __hash_page_thp() 57 if (!(old_pmd & (H_PAGE_THP_HUGE | _PAGE_DEVMAP))) in __hash_page_thp() 87 if ((old_pmd & H_PAGE_HASHPTE) && !(old_pmd & H_PAGE_COMBO)) { in __hash_page_thp() 133 pa = pmd_pfn(__pmd(old_pmd)) << PAGE_SHIFT; in __hash_page_thp() 165 *pmdp = __pmd(old_pmd); in __hash_page_thp() [all …]
|
D | hash_pgtable.c | 313 pmd_t *pmdp, unsigned long old_pmd) in hpte_do_hugepage_flush() argument 325 if (old_pmd & H_PAGE_COMBO) in hpte_do_hugepage_flush() 348 pmd_t old_pmd; in hash__pmdp_huge_get_and_clear() local 354 old_pmd = __pmd(old); in hash__pmdp_huge_get_and_clear() 367 return old_pmd; in hash__pmdp_huge_get_and_clear()
|
D | pgtable.c | 116 unsigned long old_pmd; in pmdp_invalidate() local 118 old_pmd = pmd_hugepage_update(vma->vm_mm, address, pmdp, _PAGE_PRESENT, _PAGE_INVALID); in pmdp_invalidate() 120 return __pmd(old_pmd); in pmdp_invalidate()
|
D | radix_pgtable.c | 1019 pmd_t old_pmd; in radix__pmdp_huge_get_and_clear() local 1023 old_pmd = __pmd(old); in radix__pmdp_huge_get_and_clear() 1024 return old_pmd; in radix__pmdp_huge_get_and_clear()
|
/Linux-v5.15/mm/ |
D | mremap.c | 134 static void move_ptes(struct vm_area_struct *vma, pmd_t *old_pmd, in move_ptes() argument 170 old_pte = pte_offset_map_lock(mm, old_pmd, old_addr, &old_ptl); in move_ptes() 224 unsigned long new_addr, pmd_t *old_pmd, pmd_t *new_pmd) in move_normal_pmd() argument 262 old_ptl = pmd_lock(vma->vm_mm, old_pmd); in move_normal_pmd() 268 pmd = *old_pmd; in move_normal_pmd() 269 pmd_clear(old_pmd); in move_normal_pmd() 283 unsigned long old_addr, unsigned long new_addr, pmd_t *old_pmd, in move_normal_pmd() argument 486 pmd_t *old_pmd, *new_pmd; in move_page_tables() local 525 old_pmd = get_old_pmd(vma->vm_mm, old_addr); in move_page_tables() 526 if (!old_pmd) in move_page_tables() [all …]
|
D | huge_memory.c | 1669 unsigned long new_addr, pmd_t *old_pmd, pmd_t *new_pmd) in move_huge_pmd() argument 1689 old_ptl = __pmd_trans_huge_lock(old_pmd, vma); in move_huge_pmd() 1694 pmd = pmdp_huge_get_and_clear(mm, old_addr, old_pmd); in move_huge_pmd() 1701 pgtable = pgtable_trans_huge_withdraw(mm, old_pmd); in move_huge_pmd() 1964 pmd_t old_pmd, _pmd; in __split_huge_pmd_locked() local 1978 old_pmd = pmdp_huge_clear_flush_notify(vma, haddr, pmd); in __split_huge_pmd_locked() 1987 if (unlikely(is_pmd_migration_entry(old_pmd))) { in __split_huge_pmd_locked() 1990 entry = pmd_to_swp_entry(old_pmd); in __split_huge_pmd_locked() 1993 page = pmd_page(old_pmd); in __split_huge_pmd_locked() 1994 if (!PageDirty(page) && pmd_dirty(old_pmd)) in __split_huge_pmd_locked() [all …]
|
/Linux-v5.15/arch/powerpc/include/asm/book3s/64/ |
D | hash.h | 236 pmd_t *pmdp, unsigned long old_pmd); 240 unsigned long old_pmd) in hpte_do_hugepage_flush() argument
|
/Linux-v5.15/include/linux/ |
D | pgtable.h | 490 pmd_t old_pmd = *pmdp; in pmdp_set_wrprotect() local 491 set_pmd_at(mm, address, pmdp, pmd_wrprotect(old_pmd)); in pmdp_set_wrprotect() 553 pmd_t old_pmd = *pmdp; in generic_pmdp_establish() local 555 return old_pmd; in generic_pmdp_establish()
|
D | huge_mm.h | 38 unsigned long new_addr, pmd_t *old_pmd, pmd_t *new_pmd);
|
/Linux-v5.15/arch/arm64/mm/ |
D | mmu.c | 227 pmd_t old_pmd = READ_ONCE(*pmdp); in init_pmd() local 240 BUG_ON(!pgattr_change_is_safe(pmd_val(old_pmd), in init_pmd() 246 BUG_ON(pmd_val(old_pmd) != 0 && in init_pmd() 247 pmd_val(old_pmd) != READ_ONCE(pmd_val(*pmdp))); in init_pmd()
|