VDB
CVE-2026-31664
CVE-2026-31664
PUBLISHED
In the Linux kernel, the following vulnerability has been resolved: xfrm: clear trailing padding in build_polexpire() build_expire() clears the trailing padding bytes of struct xfrm_user_expire after setting the hard field via memset_after(), but the analogous function build_polexpire() does not do this for struct xfrm_user_polexpire. The padding bytes after the __u8 hard field are left uninitialized from the heap allocation, and are then sent to userspace via netlink multicast to XFRMNLGRP_EXPIRE listeners, leaking kernel heap memory contents. Add the missing memset_after() call, matching build_expire().
EPSS 0.01% · 2.9th percentile
Risk Scores
EPSS Score
0.01%
2.9th percentile
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| linux | linux_kernel | 2.6.12, 2.6.12, 2.6.12 |
| Linux | Linux | 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2, 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2, 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 |
Timeline
- Apr 24, 2026 CVE Published
- Apr 24, 2026 Security Advisory
- Apr 27, 2026 Security Advisory
- May 18, 2026 EPSS Score
- May 19, 2026 EPSS Score
- May 20, 2026 EPSS Score
- May 21, 2026 EPSS Score
- May 22, 2026 EPSS Score
- May 23, 2026 EPSS Score
- May 24, 2026 EPSS Score
- May 25, 2026 EPSS Score
- May 26, 2026 EPSS Score
References
- https://git.kernel.org/stable/c/ac6985903db047eaff54db929e4bf6b06782788e url
- https://git.kernel.org/stable/c/c221ed63a2769a0af8bd849dfe25740048f34ef4 url
- https://git.kernel.org/stable/c/eda30846ea54f8ed218468e5480c8305ca645e37 url
- https://git.kernel.org/stable/c/b1dfd6b27df35ef4f87825aa5f607378d23ff0f2 url
- https://git.kernel.org/stable/c/e1af65c669ebb1666c54576614c01a7f9ffcfff6 url
- https://git.kernel.org/stable/c/71a98248c63c535eaa4d4c22f099b68d902006d0 url
- https://nvd.nist.gov/vuln/detail/CVE-2026-31664 advisory