summaryrefslogtreecommitdiffstats
path: root/kernel/rcu
diff options
context:
space:
mode:
authorPaul E. McKenney <paulmck@kernel.org>2021-01-20 13:38:08 -0800
committerPaul E. McKenney <paulmck@kernel.org>2021-03-08 14:18:07 -0800
commit7ffc9ec8eac196cbd85669a4d7920cd80f186a51 (patch)
tree91692f5101bbeef9055de2382cd4fd539a1bdebe /kernel/rcu
parentb01b405092b7940bd366053a27ed54a87c84e96a (diff)
downloadlinux-7ffc9ec8eac196cbd85669a4d7920cd80f186a51.tar.gz
linux-7ffc9ec8eac196cbd85669a4d7920cd80f186a51.tar.bz2
linux-7ffc9ec8eac196cbd85669a4d7920cd80f186a51.zip
kvfree_rcu: Make krc_this_cpu_unlock() use raw_spin_unlock_irqrestore()
The krc_this_cpu_unlock() function does a raw_spin_unlock() immediately followed by a local_irq_restore(). This commit saves a line of code by merging them into a raw_spin_unlock_irqrestore(). This transformation also reduces scheduling latency because raw_spin_unlock_irqrestore() responds immediately to a reschedule request. In contrast, local_irq_restore() does a scheduling-oblivious enabling of interrupts. Reported-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Diffstat (limited to 'kernel/rcu')
-rw-r--r--kernel/rcu/tree.c3
1 files changed, 1 insertions, 2 deletions
diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c
index 08b50441ebe8..7ee83f3a15ea 100644
--- a/kernel/rcu/tree.c
+++ b/kernel/rcu/tree.c
@@ -3229,8 +3229,7 @@ krc_this_cpu_lock(unsigned long *flags)
static inline void
krc_this_cpu_unlock(struct kfree_rcu_cpu *krcp, unsigned long flags)
{
- raw_spin_unlock(&krcp->lock);
- local_irq_restore(flags);
+ raw_spin_unlock_irqrestore(&krcp->lock, flags);
}
static inline struct kvfree_rcu_bulk_data *