CVE-2026-46015

Source
https://cve.org/CVERecord?id=CVE-2026-46015
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-46015.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2026-46015
Downstream
Related
Published
2026-05-27T12:56:17.249Z
Modified
2026-06-18T03:56:49.726133356Z
Severity
  • 7.8 (High) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H CVSS Calculator
Summary
tcp: call sk_data_ready() after listener migration
Details

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

tcp: call skdataready() after listener migration

When inetcsklistenstop() migrates an established child socket from a closing listener to another socket in the same SOREUSEPORT group, the target listener gets a new accept-queue entry via inetcskreqskqueueadd(), but that path never notifies the target listener's waiters. A nonblocking accept() still works because it checks the queue directly, but poll()/epoll_wait() waiters and blocking accept() callers can also remain asleep indefinitely.

Call READONCE(nsk->skdataready)(nsk) after a successful migration in inetcsklistenstop().

However, after inetcskreqskqueueadd() succeeds, the ref acquired in reuseportmigratesock() is effectively transferred to nreq->rsklistener. Another CPU can then dequeue nreq via accept() or listener shutdown, hit reqskput(), and drop that listener ref. Since listeners are SOCKRCUFREE, wrap the post-queueadd() dereferences of nsk in rcureadlock()/rcureadunlock(), which also covers the existing socknet(nsk) access in that path.

The reqsktimerhandler() path does not need the same changes for two reasons: half-open requests become readable only after the final ACK, where tcpchildprocess() already wakes the listener; and once nreq is visible via inetehashinsert(), the success path no longer touches nsk directly.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2026/46xxx/CVE-2026-46015.json"
}
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
54b92e84193749c9968aff2dd46e3b0f42643e18
Fixed
7aa7933a5607b1e5b56f322d17265c1d0ea02c51
Fixed
14e9bb6eba8f59dcc637702e4744ae5e30660d76
Fixed
ab5fdcd535645f6dbe6e9e21d96a08d141e88b4b
Fixed
bebd058ef40c67a81fe6d9ee8beaa4ede90e0704
Fixed
83bb57635d7cbafde32f865b577ecfd969f02337
Fixed
12625b4da84caf4d84a04988710a7b9bcf702b18
Fixed
3864c6ba1e041bc75342353a70fa2a2c6f909923

Database specific

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

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
5.14.0
Fixed
5.15.209
Type
ECOSYSTEM
Events
Introduced
5.16.0
Fixed
6.1.175
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.140
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.86
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.18.27
Type
ECOSYSTEM
Events
Introduced
6.19.0
Fixed
7.0.4

Database specific

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