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

Zqiang posted 1 patch 4 weeks ago
kernel/workqueue.c | 2 --
1 file changed, 2 deletions(-)
[PATCH] workqueue: Remove redundant rcu_read_lock/unlock() in workqueue_congested()
Posted by Zqiang 4 weeks ago
The preempt_disable/enable() has already formed RCU read crtical
section, this commit therefore remove rcu_read_lock/unlock() in
workqueue_congested().

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

diff --git a/kernel/workqueue.c b/kernel/workqueue.c
index c6b79b3675c3..831754e90071 100644
--- a/kernel/workqueue.c
+++ b/kernel/workqueue.c
@@ -6046,7 +6046,6 @@ bool workqueue_congested(int cpu, struct workqueue_struct *wq)
 	struct pool_workqueue *pwq;
 	bool ret;
 
-	rcu_read_lock();
 	preempt_disable();
 
 	if (cpu == WORK_CPU_UNBOUND)
@@ -6056,7 +6055,6 @@ bool workqueue_congested(int cpu, struct workqueue_struct *wq)
 	ret = !list_empty(&pwq->inactive_works);
 
 	preempt_enable();
-	rcu_read_unlock();
 
 	return ret;
 }
-- 
2.17.1
Re: [PATCH] workqueue: Remove redundant rcu_read_lock/unlock() in workqueue_congested()
Posted by Tejun Heo 4 weeks ago
On Thu, Sep 04, 2025 at 07:31:32PM +0800, Zqiang wrote:
> The preempt_disable/enable() has already formed RCU read crtical
> section, this commit therefore remove rcu_read_lock/unlock() in
> workqueue_congested().
> 
> Signed-off-by: Zqiang <qiang.zhang@linux.dev>

Applied to wq/for-6.18.

Thanks.

-- 
tejun
[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