提交 afec570c 编写于 作者: I Ian Kent 提交者: Linus Torvalds

autofs4: fix sparse warning in waitq.c:autofs4_expire_indirect()

Re-order some code in expire.c:autofs4_expire_indirect() to avoid compile
warning, reported by Harvey Harrison:

 CHECK   fs/autofs4/expire.c
fs/autofs4/expire.c:383:2: warning: context imbalance in
'autofs4_expire_indirect' - unexpected unlock
Signed-off-by: NIan Kent <raven@themaw.net>
Reviewed-by: NHarvey Harrison <harvey.harrison@gmail.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 c32e026e
...@@ -333,7 +333,7 @@ static struct dentry *autofs4_expire_indirect(struct super_block *sb, ...@@ -333,7 +333,7 @@ static struct dentry *autofs4_expire_indirect(struct super_block *sb,
/* Can we expire this guy */ /* Can we expire this guy */
if (autofs4_can_expire(dentry, timeout, do_now)) { if (autofs4_can_expire(dentry, timeout, do_now)) {
expired = dentry; expired = dentry;
break; goto found;
} }
goto next; goto next;
} }
...@@ -352,7 +352,7 @@ static struct dentry *autofs4_expire_indirect(struct super_block *sb, ...@@ -352,7 +352,7 @@ static struct dentry *autofs4_expire_indirect(struct super_block *sb,
inf->flags |= AUTOFS_INF_EXPIRING; inf->flags |= AUTOFS_INF_EXPIRING;
spin_unlock(&sbi->fs_lock); spin_unlock(&sbi->fs_lock);
expired = dentry; expired = dentry;
break; goto found;
} }
spin_unlock(&sbi->fs_lock); spin_unlock(&sbi->fs_lock);
/* /*
...@@ -363,7 +363,7 @@ static struct dentry *autofs4_expire_indirect(struct super_block *sb, ...@@ -363,7 +363,7 @@ static struct dentry *autofs4_expire_indirect(struct super_block *sb,
expired = autofs4_check_leaves(mnt, dentry, timeout, do_now); expired = autofs4_check_leaves(mnt, dentry, timeout, do_now);
if (expired) { if (expired) {
dput(dentry); dput(dentry);
break; goto found;
} }
} }
next: next:
...@@ -371,18 +371,16 @@ static struct dentry *autofs4_expire_indirect(struct super_block *sb, ...@@ -371,18 +371,16 @@ static struct dentry *autofs4_expire_indirect(struct super_block *sb,
spin_lock(&dcache_lock); spin_lock(&dcache_lock);
next = next->next; next = next->next;
} }
if (expired) {
DPRINTK("returning %p %.*s",
expired, (int)expired->d_name.len, expired->d_name.name);
spin_lock(&dcache_lock);
list_move(&expired->d_parent->d_subdirs, &expired->d_u.d_child);
spin_unlock(&dcache_lock);
return expired;
}
spin_unlock(&dcache_lock); spin_unlock(&dcache_lock);
return NULL; return NULL;
found:
DPRINTK("returning %p %.*s",
expired, (int)expired->d_name.len, expired->d_name.name);
spin_lock(&dcache_lock);
list_move(&expired->d_parent->d_subdirs, &expired->d_u.d_child);
spin_unlock(&dcache_lock);
return expired;
} }
/* Perform an expiry operation */ /* Perform an expiry operation */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册