aboutsummaryrefslogtreecommitdiffstats
path: root/tools/bpf/bpftool/prog.c
diff options
context:
space:
mode:
authorKaixin Wang <[email protected]>2024-09-18 12:07:50 +0000
committerSebastian Reichel <[email protected]>2025-02-25 01:07:09 +0000
commite3f88665a78045fe35c7669d2926b8d97b892c11 (patch)
tree03503f48f49ba337277d7b26fd1e20f809c1ebc5 /tools/bpf/bpftool/prog.c
parentLinux 6.14-rc1 (diff)
downloadkernel-e3f88665a78045fe35c7669d2926b8d97b892c11.tar.gz
kernel-e3f88665a78045fe35c7669d2926b8d97b892c11.zip
HSI: ssi_protocol: Fix use after free vulnerability in ssi_protocol Driver Due to Race Condition
In the ssi_protocol_probe() function, &ssi->work is bound with ssip_xmit_work(), In ssip_pn_setup(), the ssip_pn_xmit() function within the ssip_pn_ops structure is capable of starting the work. If we remove the module which will call ssi_protocol_remove() to make a cleanup, it will free ssi through kfree(ssi), while the work mentioned above will be used. The sequence of operations that may lead to a UAF bug is as follows: CPU0 CPU1 | ssip_xmit_work ssi_protocol_remove | kfree(ssi); | | struct hsi_client *cl = ssi->cl; | // use ssi Fix it by ensuring that the work is canceled before proceeding with the cleanup in ssi_protocol_remove(). Signed-off-by: Kaixin Wang <[email protected]> Acked-by: Andy Shevchenko <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Sebastian Reichel <[email protected]>
Diffstat (limited to 'tools/bpf/bpftool/prog.c')
0 files changed, 0 insertions, 0 deletions