Description
In the Linux kernel, the following vulnerability has been resolved: nbd: defer config unlock in nbd_genl_connect There is one use-after-free warning when running NBD_CMD_CONNECT and NBD_CLEAR_SOCK: nbd_genl_connect nbd_alloc_and_init_config // config_refs=1 nbd_start_device // config_refs=2 set NBD_RT_HAS_CONFIG_REF open nbd // config_refs=3 recv_work done // config_refs=2 NBD_CLEAR_SOCK // config_refs=1 close nbd // config_refs=0 refcount_inc -> uaf ------------[ cut here ]------------ refcount_t: addition on 0; use-after-free. WARNING: CPU: 24 PID: 1014 at lib/refcount.c:25 refcount_warn_saturate+0x12e/0x290 nbd_genl_connect+0x16d0/0x1ab0 genl_family_rcv_msg_doit+0x1f3/0x310 genl_rcv_msg+0x44a/0x790 The issue can be easily reproduced by adding a small delay before refcount_inc(&nbd->config_refs) in nbd_genl_connect(): mutex_unlock(&nbd->config_lock); if (!ret) { set_bit(NBD_RT_HAS_CONFIG_REF, &config->runtime_flags); + printk("before sleep\n"); + mdelay(5 * 1000); + printk("after sleep\n"); refcount_inc(&nbd->config_refs); nbd_connect_reply(info, nbd->index); }
Product status
e46c7287b1c27683a8e30ca825fb98e2b97f1099 (git) before c9b99c948b4fb014812afe7b5ccf2db121d22e46
e46c7287b1c27683a8e30ca825fb98e2b97f1099 (git) before 9a38306643874566d20f7aba7dff9e6f657b51a9
e46c7287b1c27683a8e30ca825fb98e2b97f1099 (git) before c9e805f6a35d1dd189a9345595a5c20e87611942
e46c7287b1c27683a8e30ca825fb98e2b97f1099 (git) before 1649714b930f9ea6233ce0810ba885999da3b5d4
4.12
Any version before 4.12
6.12.63 (semver)
6.17.13 (semver)
6.18.2 (semver)
6.19-rc1 (original_commit_for_fix)
References
git.kernel.org/...c/c9b99c948b4fb014812afe7b5ccf2db121d22e46
git.kernel.org/...c/9a38306643874566d20f7aba7dff9e6f657b51a9
git.kernel.org/...c/c9e805f6a35d1dd189a9345595a5c20e87611942
git.kernel.org/...c/1649714b930f9ea6233ce0810ba885999da3b5d4
Data based on CVE®. Copyright © 1999-2025, The MITRE Corporation. All rights reserved.