diff options
author | Tejun Heo <tj@kernel.org> | 2025-06-16 10:13:25 -1000 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2025-06-17 08:19:55 -1000 |
commit | 33796b91871ad4010c8188372dd1faf97cf0f1c0 (patch) | |
tree | e5fc2e04c0868a5157e5a634c41b73ecb50af7f3 /kernel/bpf/arraymap.c | |
parent | c50784e99f0e7199cdb12dbddf02229b102744ef (diff) |
sched_ext, sched/core: Don't call scx_group_set_weight() prematurely from sched_create_group()
During task_group creation, sched_create_group() calls
scx_group_set_weight() with CGROUP_WEIGHT_DFL to initialize the sched_ext
portion. This is premature and ends up calling ops.cgroup_set_weight() with
an incorrect @cgrp before ops.cgroup_init() is called.
sched_create_group() should just initialize SCX related fields in the new
task_group. Fix it by factoring out scx_tg_init() from sched_init() and
making sched_create_group() call that function instead of
scx_group_set_weight().
v2: Retain CONFIG_EXT_GROUP_SCHED ifdef in sched_init() as removing it leads
to build failures on !CONFIG_GROUP_SCHED configs.
Signed-off-by: Tejun Heo <tj@kernel.org>
Fixes: 819513666966 ("sched_ext: Add cgroup support")
Cc: stable@vger.kernel.org # v6.12+
Diffstat (limited to 'kernel/bpf/arraymap.c')
0 files changed, 0 insertions, 0 deletions