jfs: fix error path in ialloc
If insert_inode_locked() fails, we shouldn't be calling unlock_new_inode(). Signed-off-by: Dave Kleikamp <dave.kleikamp@oracle.com> Tested-by: Michael L. Semon <mlsemon35@gmail.com> Cc: stable@vger.kernel.org
This commit is contained in:
parent
44598f98b9
commit
8660998608
|
@ -95,7 +95,7 @@ struct inode *ialloc(struct inode *parent, umode_t mode)
|
||||||
|
|
||||||
if (insert_inode_locked(inode) < 0) {
|
if (insert_inode_locked(inode) < 0) {
|
||||||
rc = -EINVAL;
|
rc = -EINVAL;
|
||||||
goto fail_unlock;
|
goto fail_put;
|
||||||
}
|
}
|
||||||
|
|
||||||
inode_init_owner(inode, parent, mode);
|
inode_init_owner(inode, parent, mode);
|
||||||
|
@ -156,7 +156,6 @@ struct inode *ialloc(struct inode *parent, umode_t mode)
|
||||||
fail_drop:
|
fail_drop:
|
||||||
dquot_drop(inode);
|
dquot_drop(inode);
|
||||||
inode->i_flags |= S_NOQUOTA;
|
inode->i_flags |= S_NOQUOTA;
|
||||||
fail_unlock:
|
|
||||||
clear_nlink(inode);
|
clear_nlink(inode);
|
||||||
unlock_new_inode(inode);
|
unlock_new_inode(inode);
|
||||||
fail_put:
|
fail_put:
|
||||||
|
|
Loading…
Reference in New Issue