summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAl Viro <viro@ZenIV.linux.org.uk>2014-11-20 05:19:47 +0000
committerSteven Whitehouse <swhiteho@redhat.com>2014-11-20 10:29:44 +0000
commit9265f1d0c7593e3e7e1e94a4a83a6dea34230a35 (patch)
tree5971e03e7b48769dd708d8fa7d11fb7334854a35
parent3cdcf63ed2d169c82d70a506f3569e484cd9e7a0 (diff)
downloadop-kernel-dev-9265f1d0c7593e3e7e1e94a4a83a6dea34230a35.zip
op-kernel-dev-9265f1d0c7593e3e7e1e94a4a83a6dea34230a35.tar.gz
GFS2: gfs2_dir_get_hash_table(): avoiding deferred vfree() is easy here...
vfree() is allowed under spinlock these days, but it's cheaper when it doesn't step into deferred case and here it's very easy to avoid. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
-rw-r--r--fs/gfs2/dir.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/fs/gfs2/dir.c b/fs/gfs2/dir.c
index c247fed..c5a34f0 100644
--- a/fs/gfs2/dir.c
+++ b/fs/gfs2/dir.c
@@ -370,11 +370,12 @@ static __be64 *gfs2_dir_get_hash_table(struct gfs2_inode *ip)
}
spin_lock(&inode->i_lock);
- if (ip->i_hash_cache)
- kvfree(hc);
- else
+ if (likely(!ip->i_hash_cache)) {
ip->i_hash_cache = hc;
+ hc = NULL;
+ }
spin_unlock(&inode->i_lock);
+ kvfree(hc);
return ip->i_hash_cache;
}
OpenPOWER on IntegriCloud