HarborGuard / CVE
Back to search
HIGHCVE-2026-31532Published Modified CNA Linux

CVE-2026-31532: can: raw: fix ro->uniq use-after-free in raw_rcv()

In the Linux kernel, the following vulnerability has been resolved: can: raw: fix ro->uniq use-after-free in raw_rcv() raw_release() unregisters raw CAN receive filters via can_rx_unregister(), but receiver deletion is deferred with call_rcu(). This leaves a window where raw_rcv() may still be running in an RCU read-side critical section after raw_release() frees ro->uniq, leading to a use-after-free of the percpu uniq storage. Move free_percpu(ro->uniq) out of raw_release() and into a raw-specific socket destructor. can_rx_unregister() takes an extra reference to the socket and only drops it from the RCU callback, so freeing uniq from sk_destruct ensures the percpu area is not released until the relevant callbacks have drained. [mkl: applied manually]

Metrics

CVSS v3.1
7.8
Severity
HIGH
Fixed in
0
Affected Products
2

Fix available

01a0f2de81f7fbdc538fc72d7d74609b79bc83cc034c1741254ff972e8375faf176678a248826fe3a572f0bf536ebc14f6e7da3d21a85cf076de8358e5e9cfffad898bbeaafd0ea608a6d267362f050fc6.6.1366.12.836.18.246.19.147.0.17.1-rc17201a531b9a5ed892bfda5ded9194ef622de8ffaa535a9217ca3f2fccedaafb2fddb4c48f27d36dc
Affected packages
  • Linux / Linux
    < 5e9cfffad898bbeaafd0ea608a6d267362f050fc (from 514ac99c64b22d83b52dfee3b8becaa69a92bc4a) · < 572f0bf536ebc14f6e7da3d21a85cf076de8358e (from 514ac99c64b22d83b52dfee3b8becaa69a92bc4a) · < 1a0f2de81f7fbdc538fc72d7d74609b79bc83cc0 (from 514ac99c64b22d83b52dfee3b8becaa69a92bc4a) · < 7201a531b9a5ed892bfda5ded9194ef622de8ffa (from 514ac99c64b22d83b52dfee3b8becaa69a92bc4a) · < 34c1741254ff972e8375faf176678a248826fe3a (from 514ac99c64b22d83b52dfee3b8becaa69a92bc4a) · < a535a9217ca3f2fccedaafb2fddb4c48f27d36dc (from 514ac99c64b22d83b52dfee3b8becaa69a92bc4a)
  • Linux / Linux
    4.1
    Fixed in 0, 6.6.136, 6.12.83, 6.18.24, 6.19.14, 7.0.1, 7.1-rc1
CVSS Vector
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
CVE-2026-31532: can: raw: fix ro->uniq use-after-free in raw_rcv() | HarborGuard CVE