From: Su Zhidao <[email protected]>

scx_bypass_lb_timerfn() runs in softirq (BH) context, so
rcu_dereference_bh() is the correct RCU accessor. The previous
rcu_dereference_all() suppresses all sparse warnings and masks
potential RCU context issues.

Add a comment noting this is a transitional state: when
multi-scheduler support lands, the bypass LB timer will become
per-scheduler and the global scx_root reference will be removed.

Signed-off-by: Su Zhidao <[email protected]>
---
 kernel/sched/ext.c | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/kernel/sched/ext.c b/kernel/sched/ext.c
index 053d99c58802..c269e489902c 100644
--- a/kernel/sched/ext.c
+++ b/kernel/sched/ext.c
@@ -4170,7 +4170,13 @@ static void scx_bypass_lb_timerfn(struct timer_list 
*timer)
        int node;
        u32 intv_us;
 
-       sch = rcu_dereference_all(scx_root);
+       /*
+        * scx_bypass_lb_timer is a global timer that fires in softirq
+        * context while bypass mode is active. Use rcu_dereference_bh()
+        * matching the BH context. When multi-scheduler support lands,
+        * this timer will become per-scheduler instance.
+        */
+       sch = rcu_dereference_bh(scx_root);
        if (unlikely(!sch) || !READ_ONCE(scx_bypass_depth))
                return;
 
-- 
2.43.0


Reply via email to