mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-01 10:42:11 +00:00
tools/memory-model: Add KCSAN LF mentorship session citation
Add a citation to Marco's LF mentorship session presentation entitled "The Kernel Concurrency Sanitizer" [ paulmck: Apply Marco Elver feedback. ] Reported-by: Marco Elver <elver@google.com> Signed-off-by: Paul E. McKenney <paulmck@kernel.org> Acked-by: Andrea Parri <parri.andrea@gmail.com> Reviewed-by: Akira Yokosawa <akiyks@gmail.com> Acked-by: Marco Elver <elver@google.com> Cc: Alan Stern <stern@rowland.harvard.edu> Cc: Will Deacon <will@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Boqun Feng <boqun.feng@gmail.com> Cc: Nicholas Piggin <npiggin@gmail.com> Cc: David Howells <dhowells@redhat.com> Cc: Jade Alglave <j.alglave@ucl.ac.uk> Cc: Luc Maranget <luc.maranget@inria.fr> Cc: Daniel Lustig <dlustig@nvidia.com> Cc: Joel Fernandes <joel@joelfernandes.org> Cc: <linux-arch@vger.kernel.org>
This commit is contained in:
parent
1613e604df
commit
1e029b73b7
@ -6,7 +6,8 @@ normal accesses to shared memory, that is "normal" as in accesses that do
|
|||||||
not use read-modify-write atomic operations. It also describes how to
|
not use read-modify-write atomic operations. It also describes how to
|
||||||
document these accesses, both with comments and with special assertions
|
document these accesses, both with comments and with special assertions
|
||||||
processed by the Kernel Concurrency Sanitizer (KCSAN). This discussion
|
processed by the Kernel Concurrency Sanitizer (KCSAN). This discussion
|
||||||
builds on an earlier LWN article [1].
|
builds on an earlier LWN article [1] and Linux Foundation mentorship
|
||||||
|
session [2].
|
||||||
|
|
||||||
|
|
||||||
ACCESS-MARKING OPTIONS
|
ACCESS-MARKING OPTIONS
|
||||||
@ -31,7 +32,7 @@ example:
|
|||||||
WRITE_ONCE(a, b + data_race(c + d) + READ_ONCE(e));
|
WRITE_ONCE(a, b + data_race(c + d) + READ_ONCE(e));
|
||||||
|
|
||||||
Neither plain C-language accesses nor data_race() (#1 and #2 above) place
|
Neither plain C-language accesses nor data_race() (#1 and #2 above) place
|
||||||
any sort of constraint on the compiler's choice of optimizations [2].
|
any sort of constraint on the compiler's choice of optimizations [3].
|
||||||
In contrast, READ_ONCE() and WRITE_ONCE() (#3 and #4 above) restrict the
|
In contrast, READ_ONCE() and WRITE_ONCE() (#3 and #4 above) restrict the
|
||||||
compiler's use of code-motion and common-subexpression optimizations.
|
compiler's use of code-motion and common-subexpression optimizations.
|
||||||
Therefore, if a given access is involved in an intentional data race,
|
Therefore, if a given access is involved in an intentional data race,
|
||||||
@ -594,5 +595,8 @@ REFERENCES
|
|||||||
[1] "Concurrency bugs should fear the big bad data-race detector (part 2)"
|
[1] "Concurrency bugs should fear the big bad data-race detector (part 2)"
|
||||||
https://lwn.net/Articles/816854/
|
https://lwn.net/Articles/816854/
|
||||||
|
|
||||||
[2] "Who's afraid of a big bad optimizing compiler?"
|
[2] "The Kernel Concurrency Sanitizer"
|
||||||
|
https://www.linuxfoundation.org/webinars/the-kernel-concurrency-sanitizer
|
||||||
|
|
||||||
|
[3] "Who's afraid of a big bad optimizing compiler?"
|
||||||
https://lwn.net/Articles/793253/
|
https://lwn.net/Articles/793253/
|
||||||
|
Loading…
Reference in New Issue
Block a user