CVE-2024-58237
Published: May 5, 2025
Modified: May 11, 2026
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.
| Vendor | Product | Versions |
|---|---|---|
Linux | Linux | affected 51c39bb1d5d105a02e29aa7960f0a395086e6342 - < f1692ee23dcaaddc24ba407b269707ee5df1301faffected 51c39bb1d5d105a02e29aa7960f0a395086e6342 - < 1c2244437f9ad3dd91215f920401a14f2542dbfcaffected 51c39bb1d5d105a02e29aa7960f0a395086e6342 - < 1a4607ffba35bf2a630aab299e34dd3f6e658d70 |
Linux | Linux | affected 5.6unaffected 0 - < 5.6unaffected 6.6.90 - <= 6.6.*unaffected 6.12.9 - <= 6.12.*unaffected 6.13 - <= * |
Security Training
Train your team to recognize and prevent security threats with our comprehensive security awareness program.
Start TrainingVulnerability Scanning
Discover vulnerabilities in your applications and infrastructure before attackers do.
Scan Now