gfs2: Minor gfs2_alloc_inode cleanup
In gfs2_alloc_inode, when kmem_cache_alloc cannot allocate a new object, return NULL immediately. The code currently relies on the fact that i_inode is the first member in struct gfs2_inode and so ip and &ip->i_inode evaluate to the same address, but that isn't immediately obvious. Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com> Reviewed-by: Bob Peterson <rpeterso@redhat.com>
This commit is contained in:
parent
2257e468a6
commit
d40312598d
@ -1722,13 +1722,13 @@ static struct inode *gfs2_alloc_inode(struct super_block *sb)
|
|||||||
struct gfs2_inode *ip;
|
struct gfs2_inode *ip;
|
||||||
|
|
||||||
ip = kmem_cache_alloc(gfs2_inode_cachep, GFP_KERNEL);
|
ip = kmem_cache_alloc(gfs2_inode_cachep, GFP_KERNEL);
|
||||||
if (ip) {
|
if (!ip)
|
||||||
ip->i_flags = 0;
|
return NULL;
|
||||||
ip->i_gl = NULL;
|
ip->i_flags = 0;
|
||||||
memset(&ip->i_res, 0, sizeof(ip->i_res));
|
ip->i_gl = NULL;
|
||||||
RB_CLEAR_NODE(&ip->i_res.rs_node);
|
memset(&ip->i_res, 0, sizeof(ip->i_res));
|
||||||
ip->i_rahead = 0;
|
RB_CLEAR_NODE(&ip->i_res.rs_node);
|
||||||
}
|
ip->i_rahead = 0;
|
||||||
return &ip->i_inode;
|
return &ip->i_inode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user