diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-02-14 13:54:28 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-02-14 13:54:28 -0500 |
commit | c833e17e276bd5d5f174aa924c4f102754ebc2be (patch) | |
tree | 90fb3d7c9b6ab66fa5d651675f054d5a7aa8a01a /include/linux/compiler.h | |
parent | fee5429e028c414d80d036198db30454cfd91b7a (diff) | |
parent | c5b19946eb76c67566aae6a84bf2b10ad59295ea (diff) |
Merge tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/borntraeger/linux
Pull ACCESS_ONCE() rule tightening from Christian Borntraeger:
"Tighten rules for ACCESS_ONCE
This series tightens the rules for ACCESS_ONCE to only work on scalar
types. It also contains the necessary fixups as indicated by build
bots of linux-next. Now everything is in place to prevent new
non-scalar users of ACCESS_ONCE and we can continue to convert code to
READ_ONCE/WRITE_ONCE"
* tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/borntraeger/linux:
kernel: Fix sparse warning for ACCESS_ONCE
next: sh: Fix compile error
kernel: tighten rules for ACCESS ONCE
mm/gup: Replace ACCESS_ONCE with READ_ONCE
x86/spinlock: Leftover conversion ACCESS_ONCE->READ_ONCE
x86/xen/p2m: Replace ACCESS_ONCE with READ_ONCE
ppc/hugetlbfs: Replace ACCESS_ONCE with READ_ONCE
ppc/kvm: Replace ACCESS_ONCE with READ_ONCE
Diffstat (limited to 'include/linux/compiler.h')
-rw-r--r-- | include/linux/compiler.h | 21 |
1 files changed, 16 insertions, 5 deletions
diff --git a/include/linux/compiler.h b/include/linux/compiler.h index 17f624cdf53c..d1ec10a940ff 100644 --- a/include/linux/compiler.h +++ b/include/linux/compiler.h | |||
@@ -451,12 +451,23 @@ static __always_inline void __write_once_size(volatile void *p, void *res, int s | |||
451 | * to make the compiler aware of ordering is to put the two invocations of | 451 | * to make the compiler aware of ordering is to put the two invocations of |
452 | * ACCESS_ONCE() in different C statements. | 452 | * ACCESS_ONCE() in different C statements. |
453 | * | 453 | * |
454 | * This macro does absolutely -nothing- to prevent the CPU from reordering, | 454 | * ACCESS_ONCE will only work on scalar types. For union types, ACCESS_ONCE |
455 | * merging, or refetching absolutely anything at any time. Its main intended | 455 | * on a union member will work as long as the size of the member matches the |
456 | * use is to mediate communication between process-level code and irq/NMI | 456 | * size of the union and the size is smaller than word size. |
457 | * handlers, all running on the same CPU. | 457 | * |
458 | * The major use cases of ACCESS_ONCE used to be (1) Mediating communication | ||
459 | * between process-level code and irq/NMI handlers, all running on the same CPU, | ||
460 | * and (2) Ensuring that the compiler does not fold, spindle, or otherwise | ||
461 | * mutilate accesses that either do not require ordering or that interact | ||
462 | * with an explicit memory barrier or atomic instruction that provides the | ||
463 | * required ordering. | ||
464 | * | ||
465 | * If possible use READ_ONCE/ASSIGN_ONCE instead. | ||
458 | */ | 466 | */ |
459 | #define ACCESS_ONCE(x) (*(volatile typeof(x) *)&(x)) | 467 | #define __ACCESS_ONCE(x) ({ \ |
468 | __maybe_unused typeof(x) __var = (__force typeof(x)) 0; \ | ||
469 | (volatile typeof(x) *)&(x); }) | ||
470 | #define ACCESS_ONCE(x) (*__ACCESS_ONCE(x)) | ||
460 | 471 | ||
461 | /* Ignore/forbid kprobes attach on very low level functions marked by this attribute: */ | 472 | /* Ignore/forbid kprobes attach on very low level functions marked by this attribute: */ |
462 | #ifdef CONFIG_KPROBES | 473 | #ifdef CONFIG_KPROBES |