CVE-2026-23319
Description
In the Linux kernel, the following vulnerability has been resolved:bpf: Fix a UAF issue in bpf_trampoline_link_cgroup_shimThe root cause of this bug is that when bpf_link_put reduces therefcount of shim_link->link.link to zero, the resource is consideredreleased but may still be referenced via tr->progs_hlist incgroup_shim_find. The actual cleanup of tr->progs_hlist inbpf_shim_tramp_link_release is deferred. During this window, anotherprocess can cause a use-after-free via bpf_trampoline_link_cgroup_shim.Based on Martin KaFai Laus suggestions, I have created a simple patch.To fix this: Add an atomic non-zero check in bpf_trampoline_link_cgroup_shim. Only increment the refcount if it is not already zero.Testing: I verified the fix by adding a delay in bpf_shim_tramp_link_release to make the bug easier to trigger:static void bpf_shim_tramp_link_release(struct bpf_link *link){/* ... */if (!shim_link->trampoline)return;+msleep(100);WARN_ON_ONCE(bpf_trampoline_unlink_prog(&shim_link->link,shim_link->trampoline, null));bpf_trampoline_put(shim_link->trampoline);}Before the patch, running a PoC easily reproduced the crash(almost 100%)with a call trace similar to KaiyanMs report.After the patch, the bug no longer occurs even after millions ofiterations.
Risk Information
Associated Vulnerability
No records foundPatch Details
No records foundReferences
https://nvd.nist.gov/vuln/detail/CVE-2023-1234
https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-1234