diff options
| author | Peter Zijlstra <[email protected]> | 2021-02-24 11:31:09 +0100 | 
|---|---|---|
| committer | Ingo Molnar <[email protected]> | 2021-03-06 12:40:21 +0100 | 
| commit | 9e81889c7648d48dd5fe13f41cbc99f3c362484a (patch) | |
| tree | e2b33a0421643459bbedd3333ac6f8264380aef7 /tools/testing/selftests/bpf/progs/sendmsg_unix_prog.c | |
| parent | 3f1bc119cd7fc987c8ed25ffb717f99403bb308c (diff) | |
sched: Fix affine_move_task() self-concurrency
Consider:
   sched_setaffinity(p, X);		sched_setaffinity(p, Y);
Then the first will install p->migration_pending = &my_pending; and
issue stop_one_cpu_nowait(pending); and the second one will read
p->migration_pending and _also_ issue: stop_one_cpu_nowait(pending),
the _SAME_ @pending.
This causes stopper list corruption.
Add set_affinity_pending::stop_pending, to indicate if a stopper is in
progress.
Fixes: 6d337eab041d ("sched: Fix migrate_disable() vs set_cpus_allowed_ptr()")
Cc: [email protected]
Signed-off-by: Peter Zijlstra (Intel) <[email protected]>
Signed-off-by: Ingo Molnar <[email protected]>
Reviewed-by: Valentin Schneider <[email protected]>
Link: https://lkml.kernel.org/r/[email protected]
Diffstat (limited to 'tools/testing/selftests/bpf/progs/sendmsg_unix_prog.c')
0 files changed, 0 insertions, 0 deletions