diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2019-08-03 18:51:18 +0300 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2019-11-12 21:18:18 +0300 |
commit | e49b85dd3c7f2bb13f5bd8dd4869e30a82acbba7 (patch) | |
tree | 7d6ef88340964361fad5259ff180022266d7f463 /Documentation/devicetree/bindings/usb/dwc3.txt | |
parent | 09e21253d17f53bdb5aac0e0dbd057a29fcbe8d1 (diff) | |
download | linux-e49b85dd3c7f2bb13f5bd8dd4869e30a82acbba7.tar.xz |
configfs: fix a deadlock in configfs_symlink()
commit 351e5d869e5ac10cb40c78b5f2d7dfc816ad4587 upstream.
Configfs abuses symlink(2). Unlike the normal filesystems, it
wants the target resolved at symlink(2) time, like link(2) would've
done. The problem is that ->symlink() is called with the parent
directory locked exclusive, so resolving the target inside the
->symlink() is easily deadlocked.
Short of really ugly games in sys_symlink() itself, all we can
do is to unlock the parent before resolving the target and
relock it after. However, that invalidates the checks done
by the caller of ->symlink(), so we have to
* check that dentry is still where it used to be
(it couldn't have been moved, but it could've been unhashed)
* recheck that it's still negative (somebody else
might've successfully created a symlink with the same name
while we were looking the target up)
* recheck the permissions on the parent directory.
Cc: stable@vger.kernel.org
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'Documentation/devicetree/bindings/usb/dwc3.txt')
0 files changed, 0 insertions, 0 deletions