diff options
| author | Jake Hillion <jake@hillion.co.uk> | 2025-03-26 01:41:52 +0300 | 
|---|---|---|
| committer | Tejun Heo <tj@kernel.org> | 2025-03-26 23:30:36 +0300 | 
| commit | a8897ed8523d4c9d782e282b18005a3779c92714 (patch) | |
| tree | 3720ef28fa064eed74d91a921169553825dc39f8 /tools/perf/scripts/python/netdev-times.py | |
| parent | 883cc35e9fef6ee5cedf535d26d7143172d60225 (diff) | |
| download | linux-a8897ed8523d4c9d782e282b18005a3779c92714.tar.xz | |
sched_ext: create_dsq: Return -EEXIST on duplicate request
create_dsq and therefore the scx_bpf_create_dsq kfunc currently silently
ignore duplicate entries. As a sched_ext scheduler is creating each DSQ
for a different purpose this is surprising behaviour.
Replace rhashtable_insert_fast which ignores duplicates with
rhashtable_lookup_insert_fast that reports duplicates (though doesn't
return their value). The rest of the code is structured correctly and
this now returns -EEXIST.
Tested by adding an extra scx_bpf_create_dsq to scx_simple. Previously
this was ignored, now init fails with a -17 code. Also ran scx_lavd
which continued to work well.
Signed-off-by: Jake Hillion <jake@hillion.co.uk>
Acked-by: Andrea Righi <arighi@nvidia.com>
Fixes: f0e1a0643a59 ("sched_ext: Implement BPF extensible scheduler class")
Cc: stable@vger.kernel.org # v6.12+
Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'tools/perf/scripts/python/netdev-times.py')
0 files changed, 0 insertions, 0 deletions
