diff options
| author | Ryan Newton <newton@meta.com> | 2025-10-15 11:50:36 -0400 |
|---|---|---|
| committer | Tejun Heo <tj@kernel.org> | 2025-10-15 06:46:36 -1000 |
| commit | 5aff3b319997eb8d0e25b8d2e3b5c88ed07395ac (patch) | |
| tree | 19c6a54bdd4cd6915c3f4b8c92f56c313c21a7e1 /rust/helpers/build_bug.c | |
| parent | 44f5c8ec5b9ad8ed4ade08d727f803b2bb07f1c3 (diff) | |
sched_ext: Add a selftest for scx_bpf_dsq_peek
This commit adds two tests. The first is the most basic unit test:
make sure an empty queue peeks as empty, and when we put one element
in the queue, make sure peek returns that element.
However, even this simple test is a little complicated by the different
behavior of scx_bpf_dsq_insert in different calling contexts:
- insert is for direct dispatch in enqueue
- insert is delayed when called from select_cpu
In this case we split the insert and the peek that verifies the
result between enqueue/dispatch.
Note: An alternative would be to call `scx_bpf_dsq_move_to_local` on an
empty queue, which in turn calls `flush_dispatch_buf`, in order to flush
the buffered insert. Unfortunately, this is not viable within the
enqueue path, as it attempts a voluntary context switch within an RCU
read-side critical section.
The second test is a stress test that performs many peeks on all DSQs
and records the observed tasks.
Signed-off-by: Ryan Newton <newton@meta.com>
Reviewed-by: Christian Loehle <christian.loehle@arm.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'rust/helpers/build_bug.c')
0 files changed, 0 insertions, 0 deletions
