mirror of
https://gitee.com/bianbu-linux/linux-6.6
synced 2025-04-24 14:07:52 -04:00
mm: Update ptep_get_lockless()'s comment
Improve the comment. Suggested-by: Matthew Wilcox <willy@infradead.org> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Link: https://lkml.kernel.org/r/20221022114424.515572025%40infradead.org
This commit is contained in:
parent
60463628c9
commit
93b3037a14
1 changed files with 6 additions and 9 deletions
|
@ -300,15 +300,12 @@ static inline pte_t ptep_get(pte_t *ptep)
|
|||
|
||||
#ifdef CONFIG_GUP_GET_PTE_LOW_HIGH
|
||||
/*
|
||||
* WARNING: only to be used in the get_user_pages_fast() implementation.
|
||||
*
|
||||
* With get_user_pages_fast(), we walk down the pagetables without taking any
|
||||
* locks. For this we would like to load the pointers atomically, but sometimes
|
||||
* that is not possible (e.g. without expensive cmpxchg8b on x86_32 PAE). What
|
||||
* we do have is the guarantee that a PTE will only either go from not present
|
||||
* to present, or present to not present or both -- it will not switch to a
|
||||
* completely different present page without a TLB flush in between; something
|
||||
* that we are blocking by holding interrupts off.
|
||||
* For walking the pagetables without holding any locks. Some architectures
|
||||
* (eg x86-32 PAE) cannot load the entries atomically without using expensive
|
||||
* instructions. We are guaranteed that a PTE will only either go from not
|
||||
* present to present, or present to not present -- it will not switch to a
|
||||
* completely different present page without a TLB flush inbetween; which we
|
||||
* are blocking by holding interrupts off.
|
||||
*
|
||||
* Setting ptes from not present to present goes:
|
||||
*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue