]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
sched_ext: Make scx_group_set_weight() always update tg->scx.weight
authorTejun Heo <tj@kernel.org>
Sun, 6 Jul 2025 06:42:09 +0000 (02:42 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 10 Jul 2025 14:05:05 +0000 (16:05 +0200)
[ Upstream commit c50784e99f0e7199cdb12dbddf02229b102744ef ]

Otherwise, tg->scx.weight can go out of sync while scx_cgroup is not enabled
and ops.cgroup_init() may be called with a stale weight value.

Signed-off-by: Tejun Heo <tj@kernel.org>
Fixes: 819513666966 ("sched_ext: Add cgroup support")
Cc: stable@vger.kernel.org # v6.12+
Signed-off-by: Sasha Levin <sashal@kernel.org>
kernel/sched/ext.c

index ddd4fa785264ebffc33d99db0a7af104199e8b81..c801dd20c63d93f672ac6fb9abd9d00668c6a4da 100644 (file)
@@ -4058,12 +4058,12 @@ void scx_group_set_weight(struct task_group *tg, unsigned long weight)
 {
        percpu_down_read(&scx_cgroup_rwsem);
 
-       if (scx_cgroup_enabled && tg->scx_weight != weight) {
-               if (SCX_HAS_OP(cgroup_set_weight))
-                       SCX_CALL_OP(SCX_KF_UNLOCKED, cgroup_set_weight,
-                                   tg_cgrp(tg), weight);
-               tg->scx_weight = weight;
-       }
+       if (scx_cgroup_enabled && SCX_HAS_OP(cgroup_set_weight) &&
+           tg->scx_weight != weight)
+               SCX_CALL_OP(SCX_KF_UNLOCKED, cgroup_set_weight,
+                           tg_cgrp(tg), weight);
+
+       tg->scx_weight = weight;
 
        percpu_up_read(&scx_cgroup_rwsem);
 }