summaryrefslogtreecommitdiffstats
path: root/kernel/scftorture.c
diff options
context:
space:
mode:
authorPaul E. McKenney <paulmck@kernel.org>2021-06-03 01:04:11 +0200
committerPaul E. McKenney <paulmck@kernel.org>2021-07-27 20:39:30 +0200
commitaf5f6e27d52cdb2cb3826df19a69a74e9d5eff5e (patch)
tree751ec15273f6780b99c1a1b0b199c5dcafbe7dc5 /kernel/scftorture.c
parentlocktorture: Mark statistics data races (diff)
downloadlinux-af5f6e27d52cdb2cb3826df19a69a74e9d5eff5e.tar.xz
linux-af5f6e27d52cdb2cb3826df19a69a74e9d5eff5e.zip
locktorture: Count lock readers
Currently, the lock_is_read_held variable is bool, so that a reader sets it to true just after lock acquisition and then to false just before lock release. This works in a rough statistical sense, but can result in false negatives just after one of a pair of concurrent readers has released the lock. This approach does have low overhead, but at the expense of the setting to true potentially never leaving the reader's store buffer, thus resulting in an unconditional false negative. This commit therefore converts this variable to atomic_t and makes the reader use atomic_inc() just after acquisition and atomic_dec() just before release. This does increase overhead, but this increase is negligible compared to the 10-microsecond lock hold time. Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Diffstat (limited to 'kernel/scftorture.c')
0 files changed, 0 insertions, 0 deletions