Description
In the Linux kernel, the following vulnerability has been resolved: net/rds: handle zerocopy send cleanup before the message is queued A zerocopy send can fail after user pages have been pinned but before the message is attached to the sending socket. The purge path currently infers zerocopy state from rm->m_rs, so an unqueued message can be cleaned up as if it owned normal payload pages. However, zerocopy ownership is really determined by the presence of op_mmp_znotifier, regardless of whether the message has reached the socket queue. Capture op_mmp_znotifier up front in rds_message_purge() and use it as the cleanup discriminator. If the message is already associated with a socket, keep the existing completion path. Otherwise, drop the pinned page accounting directly and release the notifier before putting the payload pages. This keeps early send failure cleanup consistent with the zerocopy lifetime rules without changing the normal queued completion path.
Product status
0cebaccef3acbdfbc2d85880a2efb765d2f4e2e3 (git) before e9aefdc5c53fe9aed108c14e3d155710a1bb14c9
0cebaccef3acbdfbc2d85880a2efb765d2f4e2e3 (git) before 46662f7dc59475995609bf3e9d27eb36f4acf26f
0cebaccef3acbdfbc2d85880a2efb765d2f4e2e3 (git) before 1e262db7675e27f42c3f3f47d6011855f4454f24
0cebaccef3acbdfbc2d85880a2efb765d2f4e2e3 (git) before 21d70744e6d3bbf9293aa1ee6fba7c53ad75275e
0cebaccef3acbdfbc2d85880a2efb765d2f4e2e3 (git) before 3abc8983b2bae3f487f77d9da5527d7d6b210d46
0cebaccef3acbdfbc2d85880a2efb765d2f4e2e3 (git) before 14ef6fd18db2494098b21e0471bf27a1d8e9993e
0cebaccef3acbdfbc2d85880a2efb765d2f4e2e3 (git) before 0f5c185fc79a59ee9991234dd6d2a3e5afa6e75b
0cebaccef3acbdfbc2d85880a2efb765d2f4e2e3 (git) before 44b550d88b267320459d518c0743a241ab2108fa
4.17
Any version before 4.17
5.10.258 (semver)
5.15.209 (semver)
6.1.175 (semver)
6.6.140 (semver)
6.12.88 (semver)
6.18.30 (semver)
7.0.7 (semver)
7.1-rc3 (original_commit_for_fix)
References
git.kernel.org/...c/e9aefdc5c53fe9aed108c14e3d155710a1bb14c9
git.kernel.org/...c/46662f7dc59475995609bf3e9d27eb36f4acf26f
git.kernel.org/...c/1e262db7675e27f42c3f3f47d6011855f4454f24
git.kernel.org/...c/21d70744e6d3bbf9293aa1ee6fba7c53ad75275e
git.kernel.org/...c/3abc8983b2bae3f487f77d9da5527d7d6b210d46
git.kernel.org/...c/14ef6fd18db2494098b21e0471bf27a1d8e9993e
git.kernel.org/...c/0f5c185fc79a59ee9991234dd6d2a3e5afa6e75b
git.kernel.org/...c/44b550d88b267320459d518c0743a241ab2108fa