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>
This commit is contained in:
Al Viro 2014-11-20 05:19:47 +00:00 committed by Steven Whitehouse
parent 3cdcf63ed2
commit 9265f1d0c7

View File

@ -370,11 +370,12 @@ static __be64 *gfs2_dir_get_hash_table(struct gfs2_inode *ip)
} }
spin_lock(&inode->i_lock); spin_lock(&inode->i_lock);
if (ip->i_hash_cache) if (likely(!ip->i_hash_cache)) {
kvfree(hc);
else
ip->i_hash_cache = hc; ip->i_hash_cache = hc;
hc = NULL;
}
spin_unlock(&inode->i_lock); spin_unlock(&inode->i_lock);
kvfree(hc);
return ip->i_hash_cache; return ip->i_hash_cache;
} }