CVE-2024-58237

MEDIUM

Linux Kernel 5.6-6.6.89, 6.7-6.12.8, 6.13 - Use-After-Free in BPF Tail Call Packet Pointer Handling

Title source: llm
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: bpf: consider that tail calls invalidate packet pointers Tail-called programs could execute any of the helpers that invalidate packet pointers. Hence, conservatively assume that each tail call invalidates packet pointers. Making the change in bpf_helper_changes_pkt_data() automatically makes use of check_cfg() logic that computes 'changes_pkt_data' effect for global sub-programs, such that the following program could be rejected: int tail_call(struct __sk_buff *sk) { bpf_tail_call_static(sk, &jmp_table, 0); return 0; } SEC("tc") int not_safe(struct __sk_buff *sk) { int *p = (void *)(long)sk->data; ... make p valid ... tail_call(sk); *p = 42; /* this is unsafe */ ... } The tc_bpf2bpf.c:subprog_tc() needs change: mark it as a function that can invalidate packet pointers. Otherwise, it can't be freplaced with tailcall_freplace.c:entry_freplace() that does a tail call.

Scores

CVSS v3 5.5
EPSS 0.0015
EPSS Percentile 4.2%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H

Details

CWE
CWE-476
Status published
Products (12)
linux/Kernel 5.6.0 - 6.6.90linux
linux/Kernel 6.7.0 - 6.12.9linux
Linux/Linux < 5.6
Linux/Linux 5.6
Linux/Linux 51c39bb1d5d105a02e29aa7960f0a395086e6342 - 1a4607ffba35bf2a630aab299e34dd3f6e658d70
Linux/Linux 51c39bb1d5d105a02e29aa7960f0a395086e6342 - 1c2244437f9ad3dd91215f920401a14f2542dbfc
Linux/Linux 51c39bb1d5d105a02e29aa7960f0a395086e6342 - f1692ee23dcaaddc24ba407b269707ee5df1301f
Linux/Linux 6.12.9 - 6.12.*
Linux/Linux 6.13
Linux/Linux 6.6.90 - 6.6.*
... and 2 more
Published May 05, 2025
Tracked Since Feb 18, 2026