diff options
| author | 2025-05-07 19:26:05 +0800 | |
|---|---|---|
| committer | 2025-07-08 23:42:51 +0530 | |
| commit | 1bba3900ca18bdae28d1b9fa10f16a8f8cb2ada1 (patch) | |
| tree | cf460664117260f913053dd1461b33908dc75fc0 /rust/helpers/helpers.c | |
| parent | rcu/nocb: Dump gp state even if rdp gp itself is not offloaded (diff) | |
| download | wireguard-linux-1bba3900ca18bdae28d1b9fa10f16a8f8cb2ada1.tar.xz wireguard-linux-1bba3900ca18bdae28d1b9fa10f16a8f8cb2ada1.zip | |
rcu/nocb: Fix possible invalid rdp's->nocb_cb_kthread pointer access
In the preparation stage of CPU online, if the corresponding
the rdp's->nocb_cb_kthread does not exist, will be created,
there is a situation where the rdp's rcuop kthreads creation fails,
and then de-offload this CPU's rdp, does not assign this CPU's
rdp->nocb_cb_kthread pointer, but this rdp's->nocb_gp_rdp and
rdp's->rdp_gp->nocb_gp_kthread is still valid.
This will cause the subsequent re-offload operation of this offline
CPU, which will pass the conditional check and the kthread_unpark()
will access invalid rdp's->nocb_cb_kthread pointer.
This commit therefore use rdp's->nocb_gp_kthread instead of
rdp_gp's->nocb_gp_kthread for safety check.
Signed-off-by: Zqiang <qiang.zhang1211@gmail.com>
Reviewed-by: Frederic Weisbecker <frederic@kernel.org>
Signed-off-by: Neeraj Upadhyay (AMD) <neeraj.upadhyay@kernel.org>
Diffstat (limited to 'rust/helpers/helpers.c')
0 files changed, 0 insertions, 0 deletions
