CVE-2025-38711
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
04/09/2025
Last modified:
05/09/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
smb/server: avoid deadlock when linking with ReplaceIfExists<br />
<br />
If smb2_create_link() is called with ReplaceIfExists set and the name<br />
does exist then a deadlock will happen.<br />
<br />
ksmbd_vfs_kern_path_locked() will return with success and the parent<br />
directory will be locked. ksmbd_vfs_remove_file() will then remove the<br />
file. ksmbd_vfs_link() will then be called while the parent is still<br />
locked. It will try to lock the same parent and will deadlock.<br />
<br />
This patch moves the ksmbd_vfs_kern_path_unlock() call to *before*<br />
ksmbd_vfs_link() and then simplifies the code, removing the file_present<br />
flag variable.
Impact
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/1e858a7a51c7b8b009d8f246de7ceb7743b44a71
- https://git.kernel.org/stable/c/814cfdb6358d9b84fcbec9918c8f938cc096a43a
- https://git.kernel.org/stable/c/9d5012ffe14120f978ee34aef4df3d6cb026b7c4
- https://git.kernel.org/stable/c/a726fef6d7d4cfc365d3434e3916dbfe78991a33
- https://git.kernel.org/stable/c/a7dddd62578c2eb6cb28b8835556a121b5157323
- https://git.kernel.org/stable/c/ac98d54630d5b52e3f684d872f0d82c06c418ea9
- https://git.kernel.org/stable/c/d5fc1400a34b4ea5e8f2ce296ea12bf8c8421694