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:
parent
97eba80fcc
commit
03ad0d703d
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue