diff options
author | Waiman Long <longman@redhat.com> | 2021-08-26 22:21:22 -0400 |
---|---|---|
committer | Paul E. McKenney <paulmck@kernel.org> | 2021-09-16 10:24:05 -0700 |
commit | 925da92ba5cb0c82d07cdd5049a07e40f54e9c44 (patch) | |
tree | d08eedefce6c6633753798c3ee93fbc02b63b3b9 /include/linux/rcupdate.h | |
parent | f0b2b2df5423fb369ac762c77900bc7765496d58 (diff) | |
download | linux-925da92ba5cb0c82d07cdd5049a07e40f54e9c44.tar.gz linux-925da92ba5cb0c82d07cdd5049a07e40f54e9c44.tar.bz2 linux-925da92ba5cb0c82d07cdd5049a07e40f54e9c44.zip |
rcu: Avoid unneeded function call in rcu_read_unlock()
Since commit aa40c138cc8f3 ("rcu: Report QS for outermost PREEMPT=n
rcu_read_unlock() for strict GPs") the function rcu_read_unlock_strict()
is invoked by the inlined rcu_read_unlock() function. However,
rcu_read_unlock_strict() is an empty function in production kernels,
which are built with CONFIG_RCU_STRICT_GRACE_PERIOD=n.
There is a mention of rcu_read_unlock_strict() in the BPF verifier,
but this is in a deny-list, meaning that BPF does not care whether
rcu_read_unlock_strict() is ever called.
This commit therefore provides a slight performance improvement
by hoisting the check of CONFIG_RCU_STRICT_GRACE_PERIOD from
rcu_read_unlock_strict() into rcu_read_unlock(), thus avoiding the
pointless call to an empty function.
Cc: Alexei Starovoitov <alexei.starovoitov@gmail.com>
Acked-by: Andrii Nakryiko <andrii@kernel.org>
Signed-off-by: Waiman Long <longman@redhat.com>
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Diffstat (limited to 'include/linux/rcupdate.h')
-rw-r--r-- | include/linux/rcupdate.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/include/linux/rcupdate.h b/include/linux/rcupdate.h index 434d12fe2d4f..5e0beb5c5659 100644 --- a/include/linux/rcupdate.h +++ b/include/linux/rcupdate.h @@ -71,7 +71,8 @@ static inline void __rcu_read_lock(void) static inline void __rcu_read_unlock(void) { preempt_enable(); - rcu_read_unlock_strict(); + if (IS_ENABLED(CONFIG_RCU_STRICT_GRACE_PERIOD)) + rcu_read_unlock_strict(); } static inline int rcu_preempt_depth(void) |