CVE-2026-45536
Netty: Unix-socket fd receive leaks descriptors when peer sends two at once
描述
Netty is a network application framework for development of protocol servers and clients. Prior to versions 4.1.135.Final and 4.2.15.Final, netty_unix_socket_recvFd sets msg_control to `char control[CMSG_SPACE(sizeof(int))]` (line 940) — 24 bytes on 64-bit Linux. A peer-sent SCM_RIGHTS cmsg carrying two ints has cmsg_len = CMSG_LEN(8) = 24, which fits exactly with no MSG_CTRUNC, so the kernel installs both fds in the receiving process. The subsequent check `cmsg->cmsg_len == CMSG_LEN(sizeof(int))` (line 972, expected 20) fails, the branch that would read the fd is skipped, and neither installed fd is closed. The for(;;) loop calls recvmsg again (non-blocking → EAGAIN → Java maps to 0 → read loop exits normally), leaving two leaked fds per message. There is no MSG_CTRUNC handling. Reachable via Epoll/KQueue DomainSocketChannel when the application opts into DomainSocketReadMode.FILE_DESCRIPTORS (non-default). Versions 4.1.135.Final and 4.2.15.Final patch the issue.
如何修補 CVE-2026-45536
要修補 CVE-2026-45536,請將受影響套件升級到下列已修補版本。
- —未列出修補版本
- —升級至 4.2.15.Final 或更新版本
- —升級至 4.2.15.Final 或更新版本
CVE-2026-45536 正在被利用嗎?
目前沒有被利用訊號。CVE-2026-45536 既不在 CISA KEV 也沒有最新的 EPSS 分數。
受影響套件(3)
- from 0
- >= 4.2.0.Final, < 4.2.15.Final
- >= 4.2.0.Final, < 4.2.15.Final
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|---|---|---|
| osv | CVSS 3.1 | MEDIUM4.0 | CVSS:3.1/AV:L/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L |