Home

Description

In the Linux kernel, the following vulnerability has been resolved: tcp: call sk_data_ready() after listener migration When inet_csk_listen_stop() migrates an established child socket from a closing listener to another socket in the same SO_REUSEPORT group, the target listener gets a new accept-queue entry via inet_csk_reqsk_queue_add(), 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 READ_ONCE(nsk->sk_data_ready)(nsk) after a successful migration in inet_csk_listen_stop(). However, after inet_csk_reqsk_queue_add() succeeds, the ref acquired in reuseport_migrate_sock() is effectively transferred to nreq->rsk_listener. Another CPU can then dequeue nreq via accept() or listener shutdown, hit reqsk_put(), and drop that listener ref. Since listeners are SOCK_RCU_FREE, wrap the post-queue_add() dereferences of nsk in rcu_read_lock()/rcu_read_unlock(), which also covers the existing sock_net(nsk) access in that path. The reqsk_timer_handler() path does not need the same changes for two reasons: half-open requests become readable only after the final ACK, where tcp_child_process() already wakes the listener; and once nreq is visible via inet_ehash_insert(), the success path no longer touches nsk directly.

PUBLISHED Reserved 2026-05-13 | Published 2026-05-27 | Updated 2026-06-01 | Assigner Linux




HIGH: 7.8CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

Product status

Default status
unaffected

54b92e84193749c9968aff2dd46e3b0f42643e18 (git) before 7aa7933a5607b1e5b56f322d17265c1d0ea02c51
affected

54b92e84193749c9968aff2dd46e3b0f42643e18 (git) before 14e9bb6eba8f59dcc637702e4744ae5e30660d76
affected

54b92e84193749c9968aff2dd46e3b0f42643e18 (git) before ab5fdcd535645f6dbe6e9e21d96a08d141e88b4b
affected

54b92e84193749c9968aff2dd46e3b0f42643e18 (git) before bebd058ef40c67a81fe6d9ee8beaa4ede90e0704
affected

54b92e84193749c9968aff2dd46e3b0f42643e18 (git) before 83bb57635d7cbafde32f865b577ecfd969f02337
affected

54b92e84193749c9968aff2dd46e3b0f42643e18 (git) before 12625b4da84caf4d84a04988710a7b9bcf702b18
affected

54b92e84193749c9968aff2dd46e3b0f42643e18 (git) before 3864c6ba1e041bc75342353a70fa2a2c6f909923
affected

Default status
affected

5.14
affected

Any version before 5.14
unaffected

5.15.209 (semver)
unaffected

6.1.175 (semver)
unaffected

6.6.140 (semver)
unaffected

6.12.86 (semver)
unaffected

6.18.27 (semver)
unaffected

7.0.4 (semver)
unaffected

7.1-rc1 (original_commit_for_fix)
unaffected

References

git.kernel.org/...c/7aa7933a5607b1e5b56f322d17265c1d0ea02c51

git.kernel.org/...c/14e9bb6eba8f59dcc637702e4744ae5e30660d76

git.kernel.org/...c/ab5fdcd535645f6dbe6e9e21d96a08d141e88b4b

git.kernel.org/...c/bebd058ef40c67a81fe6d9ee8beaa4ede90e0704

git.kernel.org/...c/83bb57635d7cbafde32f865b577ecfd969f02337

git.kernel.org/...c/12625b4da84caf4d84a04988710a7b9bcf702b18

git.kernel.org/...c/3864c6ba1e041bc75342353a70fa2a2c6f909923

cve.org (CVE-2026-46015)

nvd.nist.gov (CVE-2026-46015)

Download JSON