summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2019-10-25 06:03:11 +0200
committerAl Viro <viro@zeniv.linux.org.uk>2019-10-25 06:03:11 +0200
commit03ad0d703df75c43f78bd72e16124b5b94a95188 (patch)
treed3915a4d9c614df558bbdd073544786e09595b5e /fs
parentaio: Fix io_pgetevents() struct __compat_aio_sigset layout (diff)
downloadlinux-03ad0d703df75c43f78bd72e16124b5b94a95188.tar.xz
linux-03ad0d703df75c43f78bd72e16124b5b94a95188.zip
autofs: fix a leak in autofs_expire_indirect()
if the second call of should_expire() in there ends up grabbing and returning a new reference to dentry, we need to drop it before continuing. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs')
-rw-r--r--fs/autofs/expire.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/fs/autofs/expire.c b/fs/autofs/expire.c
index 2866fabf497f..91f5787dae7c 100644
--- a/fs/autofs/expire.c
+++ b/fs/autofs/expire.c
@@ -459,9 +459,10 @@ static struct dentry *autofs_expire_indirect(struct super_block *sb,
*/
how &= ~AUTOFS_EXP_LEAVES;
found = should_expire(expired, mnt, timeout, how);
- if (!found || found != expired)
- /* Something has changed, continue */
+ if (found != expired) { // something has changed, continue
+ dput(found);
goto next;
+ }
if (expired != dentry)
dput(dentry);