[PATCH] workqueue: Remove rcu_read_lock/unlock() in wq_watchdog_timer_fn()

Zqiang posted 1 patch 4 weeks ago
kernel/workqueue.c | 4 ----
1 file changed, 4 deletions(-)
[PATCH] workqueue: Remove rcu_read_lock/unlock() in wq_watchdog_timer_fn()
Posted by Zqiang 4 weeks ago
The wq_watchdog_timer_fn() is executed in the softirq context, this
is already in the RCU read critical section, this commit therefore
remove rcu_read_lock/unlock() in wq_watchdog_timer_fn().

Signed-off-by: Zqiang <qiang.zhang@linux.dev>
---
 kernel/workqueue.c | 4 ----
 1 file changed, 4 deletions(-)

diff --git a/kernel/workqueue.c b/kernel/workqueue.c
index 831754e90071..63b2685c2cb4 100644
--- a/kernel/workqueue.c
+++ b/kernel/workqueue.c
@@ -7544,8 +7544,6 @@ static void wq_watchdog_timer_fn(struct timer_list *unused)
 	if (!thresh)
 		return;
 
-	rcu_read_lock();
-
 	for_each_pool(pool, pi) {
 		unsigned long pool_ts, touched, ts;
 
@@ -7587,8 +7585,6 @@ static void wq_watchdog_timer_fn(struct timer_list *unused)
 
 	}
 
-	rcu_read_unlock();
-
 	if (lockup_detected)
 		show_all_workqueues();
 
-- 
2.17.1
Re: [PATCH] workqueue: Remove rcu_read_lock/unlock() in wq_watchdog_timer_fn()
Posted by Tejun Heo 4 weeks ago
On Thu, Sep 04, 2025 at 07:31:33PM +0800, Zqiang wrote:
> The wq_watchdog_timer_fn() is executed in the softirq context, this
> is already in the RCU read critical section, this commit therefore
> remove rcu_read_lock/unlock() in wq_watchdog_timer_fn().
> 
> Signed-off-by: Zqiang <qiang.zhang@linux.dev>

Applied to wq/for-6.18.

Thanks.

-- 
tejun