diff options
author | Tejun Heo <tj@kernel.org> | 2024-09-26 12:56:46 -1000 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2024-09-26 12:56:46 -1000 |
commit | 63fb3ec80516b256e9fc91de48567f5eda61d135 (patch) | |
tree | 8bba42f2f1cff6afa80867431589714f5736ae00 /rust/helpers/workqueue.c | |
parent | c9c809f4137c3c0f962226c10d245d3ce2fd5b7c (diff) |
sched_ext: Allow only user DSQs for scx_bpf_consume(), scx_bpf_dsq_nr_queued() and bpf_iter_scx_dsq_new()
SCX_DSQ_GLOBAL is special in that it can't be used as a priority queue and
is consumed implicitly, but all BPF DSQ related kfuncs could be used on it.
SCX_DSQ_GLOBAL will be split per-node for scalability and those operations
won't make sense anymore. Disallow SCX_DSQ_GLOBAL on scx_bpf_consume(),
scx_bpf_dsq_nr_queued() and bpf_iter_scx_dsq_new(). This means that
SCX_DSQ_GLOBAL can only be used as a dispatch target from BPF schedulers.
With scx_flatcg, which was using SCX_DSQ_GLOBAL as the fallback DSQ,
updated, this shouldn't affect any schedulers.
This leaves find_dsq_for_dispatch() the only user of find_non_local_dsq().
Open code and remove find_non_local_dsq().
Signed-off-by: tejun heo <tj@kernel.org>
Acked-by: David Vernet <void@manifault.com>
Diffstat (limited to 'rust/helpers/workqueue.c')
0 files changed, 0 insertions, 0 deletions