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>
This commit is contained in:
Al Viro 2019-10-25 00:03:11 -04:00
parent 97eba80fcc
commit 03ad0d703d
1 changed files with 3 additions and 2 deletions

View File

@ -459,9 +459,10 @@ static struct dentry *autofs_expire_indirect(struct super_block *sb,
*/ */
how &= ~AUTOFS_EXP_LEAVES; how &= ~AUTOFS_EXP_LEAVES;
found = should_expire(expired, mnt, timeout, how); found = should_expire(expired, mnt, timeout, how);
if (!found || found != expired) if (found != expired) { // something has changed, continue
/* Something has changed, continue */ dput(found);
goto next; goto next;
}
if (expired != dentry) if (expired != dentry)
dput(dentry); dput(dentry);