CVE-2026-31429

Source
https://cve.org/CVERecord?id=CVE-2026-31429
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-31429.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2026-31429
Downstream
Published
2026-04-20T09:43:03.194Z
Modified
2026-05-28T03:54:22.301667471Z
Summary
net: skb: fix cross-cache free of KFENCE-allocated skb head
Details

In the Linux kernel, the following vulnerability has been resolved:

net: skb: fix cross-cache free of KFENCE-allocated skb head

SKBSMALLHEADCACHESIZE is intentionally set to a non-power-of-2 value (e.g. 704 on x8664) to avoid collisions with generic kmalloc bucket sizes. This ensures that skbkfreehead() can reliably use skbendoffset to distinguish skb heads allocated from skbsmallheadcache vs. generic kmalloc caches.

However, when KFENCE is enabled, kfenceksize() returns the exact requested allocation size instead of the slab bucket size. If a caller (e.g. bpftestinit) allocates skb head data via kzalloc() and the requested size happens to equal SKBSMALLHEADCACHESIZE, then slabbuildskb() -> ksize() returns that exact value. After subtracting skbsharedinfo overhead, skbendoffset ends up matching SKBSMALLHEADHEADROOM, causing skbkfreehead() to incorrectly free the object to skbsmallhead_cache instead of back to the original kmalloc cache, resulting in a slab cross-cache free:

kmemcachefree(skbuffsmallhead): Wrong slab cache. Expected skbuffsmallhead but got kmalloc-1k

Fix this by always calling kfree(head) in skbkfreehead(). This keeps the free path generic and avoids allocator-specific misclassification for KFENCE objects.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2026/31xxx/CVE-2026-31429.json",
    "cna_assigner": "Linux"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
bf9f1baa279f0758dc2297080360c5a616843927
Fixed
128b03ccb2582a643983a48a37fda58df80edbde
Fixed
60313768a8edc7094435975587c00c2d7b834083
Fixed
2d64618ea846d8d033477311f805ca487d6a6696
Fixed
474e00b935db250cac320d10c1d3cf4e44b46721
Fixed
0f42e3f4fe2a58394e37241d02d9ca6ab7b7d516

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-31429.json"

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
6.3.0
Fixed
6.6.136
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.82
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.18.23
Type
ECOSYSTEM
Events
Introduced
6.19.0
Fixed
6.19.13

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-31429.json"