aboutsummaryrefslogtreecommitdiff
path: root/lib/mpi/mpi-mod.c
diff options
context:
space:
mode:
authorJisheng Zhang <[email protected]>2022-10-30 20:45:17 +0800
committerPalmer Dabbelt <[email protected]>2022-11-29 18:16:55 -0800
commit7e1864332fbc1b993659eab7974da9fe8bf8c128 (patch)
tree3c6cd7287a3463cb214208ffceb5b4f0210360b0 /lib/mpi/mpi-mod.c
parent31da94c25aea835ceac00575a9fd206c5a833fed (diff)
riscv: fix race when vmap stack overflow
Currently, when detecting vmap stack overflow, riscv firstly switches to the so called shadow stack, then use this shadow stack to call the get_overflow_stack() to get the overflow stack. However, there's a race here if two or more harts use the same shadow stack at the same time. To solve this race, we introduce spin_shadow_stack atomic var, which will be swap between its own address and 0 in atomic way, when the var is set, it means the shadow_stack is being used; when the var is cleared, it means the shadow_stack isn't being used. Fixes: 31da94c25aea ("riscv: add VMAP_STACK overflow detection") Signed-off-by: Jisheng Zhang <[email protected]> Suggested-by: Guo Ren <[email protected]> Reviewed-by: Guo Ren <[email protected]> Link: https://lore.kernel.org/r/[email protected] [Palmer: Add AQ to the swap, and also some comments.] Signed-off-by: Palmer Dabbelt <[email protected]>
Diffstat (limited to 'lib/mpi/mpi-mod.c')
0 files changed, 0 insertions, 0 deletions