diff options
author | Christian Borntraeger <borntraeger@de.ibm.com> | 2014-11-21 10:29:40 -0500 |
---|---|---|
committer | Christian Borntraeger <borntraeger@de.ibm.com> | 2014-12-18 03:54:38 -0500 |
commit | 14cf3d977b80f5e355f8ac7547cf1b9ff9fb3e09 (patch) | |
tree | 26dff7a852d6e5c5f48c55404662c67cd94c604b /arch/x86/mm | |
parent | 4f9d1382e6f80dcfa891b2c02d5a35c53be485f1 (diff) |
x86/gup: Replace ACCESS_ONCE with READ_ONCE
ACCESS_ONCE does not work reliably on non-scalar types. For
example gcc 4.6 and 4.7 might remove the volatile tag for such
accesses during the SRA (scalar replacement of aggregates) step
(https://gcc.gnu.org/bugzilla/show_bug.cgi?id=58145)
Change the gup code to replace ACCESS_ONCE with READ_ONCE.
Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
Acked-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Diffstat (limited to 'arch/x86/mm')
-rw-r--r-- | arch/x86/mm/gup.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/x86/mm/gup.c b/arch/x86/mm/gup.c index 207d9aef662d..d7547824e763 100644 --- a/arch/x86/mm/gup.c +++ b/arch/x86/mm/gup.c | |||
@@ -15,7 +15,7 @@ | |||
15 | static inline pte_t gup_get_pte(pte_t *ptep) | 15 | static inline pte_t gup_get_pte(pte_t *ptep) |
16 | { | 16 | { |
17 | #ifndef CONFIG_X86_PAE | 17 | #ifndef CONFIG_X86_PAE |
18 | return ACCESS_ONCE(*ptep); | 18 | return READ_ONCE(*ptep); |
19 | #else | 19 | #else |
20 | /* | 20 | /* |
21 | * With get_user_pages_fast, we walk down the pagetables without taking | 21 | * With get_user_pages_fast, we walk down the pagetables without taking |