๐Ÿ” CVE Alert

CVE-2024-57982

HIGH 7.1

xfrm: state: fix out-of-bounds read during lookup

CVSS Score
7.1
EPSS Score
0.0%
EPSS Percentile
0th

In the Linux kernel, the following vulnerability has been resolved: xfrm: state: fix out-of-bounds read during lookup lookup and resize can run in parallel. The xfrm_state_hash_generation seqlock ensures a retry, but the hash functions can observe a hmask value that is too large for the new hlist array. rehash does: rcu_assign_pointer(net->xfrm.state_bydst, ndst) [..] net->xfrm.state_hmask = nhashmask; While state lookup does: h = xfrm_dst_hash(net, daddr, saddr, tmpl->reqid, encap_family); hlist_for_each_entry_rcu(x, net->xfrm.state_bydst + h, bydst) { This is only safe in case the update to state_bydst is larger than net->xfrm.xfrm_state_hmask (or if the lookup function gets serialized via state spinlock again). Fix this by prefetching state_hmask and the associated pointers. The xfrm_state_hash_generation seqlock retry will ensure that the pointer and the hmask will be consistent. The existing helpers, like xfrm_dst_hash(), are now unsafe for RCU side, add lockdep assertions to document that they are only safe for insert side. xfrm_state_lookup_byaddr() uses the spinlock rather than RCU. AFAICS this is an oversight from back when state lookup was converted to RCU, this lock should be replaced with RCU in a future patch.

Vendor linux
Product linux
Ecosystems
Industries
Technology
Published Feb 27, 2025
Last Updated May 11, 2026
Stay Ahead of the Next One

Get instant alerts for linux linux

Be the first to know when new high vulnerabilities affecting linux linux are published โ€” delivered to Slack, Telegram or Discord.

Get Free Alerts โ†’ Free ยท No credit card ยท 60 sec setup

Affected Versions

Linux / Linux
c2f672fc94642bae96821a393f342edcfa9794a6 < b86dc510308d7a8955f3f47a4fea4bef887653e4 c2f672fc94642bae96821a393f342edcfa9794a6 < a16871c7832ea6435abb6e0b58289ae7dcb7e4fc c2f672fc94642bae96821a393f342edcfa9794a6 < dd4c2a174994238d55ab54da2545543d36f4e0d0 c2f672fc94642bae96821a393f342edcfa9794a6 < e952837f3ddb0ff726d5b582aa1aad9aa38d024d
Linux / Linux
4.9

References

NVD โ†— CVE.org โ†— EPSS Data โ†—
git.kernel.org: https://git.kernel.org/stable/c/b86dc510308d7a8955f3f47a4fea4bef887653e4 git.kernel.org: https://git.kernel.org/stable/c/a16871c7832ea6435abb6e0b58289ae7dcb7e4fc git.kernel.org: https://git.kernel.org/stable/c/dd4c2a174994238d55ab54da2545543d36f4e0d0 git.kernel.org: https://git.kernel.org/stable/c/e952837f3ddb0ff726d5b582aa1aad9aa38d024d