Lines Matching +full:write +full:- +full:protect

1 // SPDX-License-Identifier: GPL-2.0
11 * struct wp_walk - Private struct for pagetable walk callbacks
25 * wp_pte - Write-protect a pte
31 * The function write-protects a pte and records the range in
37 struct wp_walk *wpwalk = walk->private; in wp_pte()
41 pte_t old_pte = ptep_modify_prot_start(walk->vma, addr, pte); in wp_pte()
44 ptep_modify_prot_commit(walk->vma, addr, pte, old_pte, ptent); in wp_pte()
45 wpwalk->total++; in wp_pte()
46 wpwalk->tlbflush_start = min(wpwalk->tlbflush_start, addr); in wp_pte()
47 wpwalk->tlbflush_end = max(wpwalk->tlbflush_end, in wp_pte()
55 * struct clean_walk - Private struct for the clean_record_pte function.
76 * clean_record_pte - Clean a pte and record its address space offset in a
92 struct wp_walk *wpwalk = walk->private; in clean_record_pte()
97 pgoff_t pgoff = ((addr - walk->vma->vm_start) >> PAGE_SHIFT) + in clean_record_pte()
98 walk->vma->vm_pgoff - cwalk->bitmap_pgoff; in clean_record_pte()
99 pte_t old_pte = ptep_modify_prot_start(walk->vma, addr, pte); in clean_record_pte()
102 ptep_modify_prot_commit(walk->vma, addr, pte, old_pte, ptent); in clean_record_pte()
104 wpwalk->total++; in clean_record_pte()
105 wpwalk->tlbflush_start = min(wpwalk->tlbflush_start, addr); in clean_record_pte()
106 wpwalk->tlbflush_end = max(wpwalk->tlbflush_end, in clean_record_pte()
109 __set_bit(pgoff, cwalk->bitmap); in clean_record_pte()
110 cwalk->start = min(cwalk->start, pgoff); in clean_record_pte()
111 cwalk->end = max(cwalk->end, pgoff + 1); in clean_record_pte()
118 * wp_clean_pmd_entry - The pagewalk pmd callback.
120 * Dirty-tracking should take place on the PTE level, so
135 walk->action = ACTION_AGAIN; in wp_clean_pmd_entry()
140 walk->action = ACTION_CONTINUE; in wp_clean_pmd_entry()
148 * wp_clean_pud_entry - The pagewalk pud callback.
150 * Dirty-tracking should take place on the PTE level, so
165 walk->action = ACTION_AGAIN; in wp_clean_pud_entry()
171 walk->action = ACTION_CONTINUE; in wp_clean_pud_entry()
180 * wp_clean_pre_vma - The pagewalk pre_vma callback.
188 struct wp_walk *wpwalk = walk->private; in wp_clean_pre_vma()
190 wpwalk->tlbflush_start = end; in wp_clean_pre_vma()
191 wpwalk->tlbflush_end = start; in wp_clean_pre_vma()
193 mmu_notifier_range_init(&wpwalk->range, MMU_NOTIFY_PROTECTION_PAGE, 0, in wp_clean_pre_vma()
194 walk->vma, walk->mm, start, end); in wp_clean_pre_vma()
195 mmu_notifier_invalidate_range_start(&wpwalk->range); in wp_clean_pre_vma()
196 flush_cache_range(walk->vma, start, end); in wp_clean_pre_vma()
203 inc_tlb_flush_pending(walk->mm); in wp_clean_pre_vma()
209 * wp_clean_post_vma - The pagewalk post_vma callback.
216 struct wp_walk *wpwalk = walk->private; in wp_clean_post_vma()
218 if (mm_tlb_flush_nested(walk->mm)) in wp_clean_post_vma()
219 flush_tlb_range(walk->vma, wpwalk->range.start, in wp_clean_post_vma()
220 wpwalk->range.end); in wp_clean_post_vma()
221 else if (wpwalk->tlbflush_end > wpwalk->tlbflush_start) in wp_clean_post_vma()
222 flush_tlb_range(walk->vma, wpwalk->tlbflush_start, in wp_clean_post_vma()
223 wpwalk->tlbflush_end); in wp_clean_post_vma()
225 mmu_notifier_invalidate_range_end(&wpwalk->range); in wp_clean_post_vma()
226 dec_tlb_flush_pending(walk->mm); in wp_clean_post_vma()
230 * wp_clean_test_walk - The pagewalk test_walk callback.
232 * Won't perform dirty-tracking on COW, read-only or HUGETLB vmas.
237 unsigned long vm_flags = READ_ONCE(walk->vma->vm_flags); in wp_clean_test_walk()
239 /* Skip non-applicable VMAs */ in wp_clean_test_walk()
266 * wp_shared_mapping_range - Write-protect all ptes in an address space range
267 * @mapping: The address_space we want to write protect
271 * Note: This function currently skips transhuge page-table entries, since
272 * it's intended for dirty-tracking on the PTE level. It will warn on
273 * encountering transhuge write-enabled entries, though, and can easily be
276 * Return: The number of ptes actually write-protected. Note that
277 * already write-protected ptes are not counted.
294 * clean_record_shared_mapping_range - Clean and record all ptes in an
316 * additional are added, it first needs to write-protect the address-space
318 * pfn_mkwrite(). And then after a TLB flush following the write-protection
321 * This function currently skips transhuge page-table entries, since
322 * it's intended for dirty-tracking on the PTE level. It will warn on