|
@@ -4623,12 +4623,12 @@ int btrfs_add_link(struct btrfs_trans_handle *trans,
|
|
|
}
|
|
|
|
|
|
static int btrfs_add_nondir(struct btrfs_trans_handle *trans,
|
|
|
- struct dentry *dentry, struct inode *inode,
|
|
|
- int backref, u64 index)
|
|
|
+ struct inode *dir, struct dentry *dentry,
|
|
|
+ struct inode *inode, int backref, u64 index)
|
|
|
{
|
|
|
- int err = btrfs_add_link(trans, dentry->d_parent->d_inode,
|
|
|
- inode, dentry->d_name.name,
|
|
|
- dentry->d_name.len, backref, index);
|
|
|
+ int err = btrfs_add_link(trans, dir, inode,
|
|
|
+ dentry->d_name.name, dentry->d_name.len,
|
|
|
+ backref, index);
|
|
|
if (!err) {
|
|
|
d_instantiate(dentry, inode);
|
|
|
return 0;
|
|
@@ -4669,8 +4669,7 @@ static int btrfs_mknod(struct inode *dir, struct dentry *dentry,
|
|
|
btrfs_set_trans_block_group(trans, dir);
|
|
|
|
|
|
inode = btrfs_new_inode(trans, root, dir, dentry->d_name.name,
|
|
|
- dentry->d_name.len,
|
|
|
- dentry->d_parent->d_inode->i_ino, objectid,
|
|
|
+ dentry->d_name.len, dir->i_ino, objectid,
|
|
|
BTRFS_I(dir)->block_group, mode, &index);
|
|
|
err = PTR_ERR(inode);
|
|
|
if (IS_ERR(inode))
|
|
@@ -4683,7 +4682,7 @@ static int btrfs_mknod(struct inode *dir, struct dentry *dentry,
|
|
|
}
|
|
|
|
|
|
btrfs_set_trans_block_group(trans, inode);
|
|
|
- err = btrfs_add_nondir(trans, dentry, inode, 0, index);
|
|
|
+ err = btrfs_add_nondir(trans, dir, dentry, inode, 0, index);
|
|
|
if (err)
|
|
|
drop_inode = 1;
|
|
|
else {
|
|
@@ -4731,10 +4730,8 @@ static int btrfs_create(struct inode *dir, struct dentry *dentry,
|
|
|
btrfs_set_trans_block_group(trans, dir);
|
|
|
|
|
|
inode = btrfs_new_inode(trans, root, dir, dentry->d_name.name,
|
|
|
- dentry->d_name.len,
|
|
|
- dentry->d_parent->d_inode->i_ino,
|
|
|
- objectid, BTRFS_I(dir)->block_group, mode,
|
|
|
- &index);
|
|
|
+ dentry->d_name.len, dir->i_ino, objectid,
|
|
|
+ BTRFS_I(dir)->block_group, mode, &index);
|
|
|
err = PTR_ERR(inode);
|
|
|
if (IS_ERR(inode))
|
|
|
goto out_unlock;
|
|
@@ -4746,7 +4743,7 @@ static int btrfs_create(struct inode *dir, struct dentry *dentry,
|
|
|
}
|
|
|
|
|
|
btrfs_set_trans_block_group(trans, inode);
|
|
|
- err = btrfs_add_nondir(trans, dentry, inode, 0, index);
|
|
|
+ err = btrfs_add_nondir(trans, dir, dentry, inode, 0, index);
|
|
|
if (err)
|
|
|
drop_inode = 1;
|
|
|
else {
|
|
@@ -4806,7 +4803,7 @@ static int btrfs_link(struct dentry *old_dentry, struct inode *dir,
|
|
|
btrfs_set_trans_block_group(trans, dir);
|
|
|
atomic_inc(&inode->i_count);
|
|
|
|
|
|
- err = btrfs_add_nondir(trans, dentry, inode, 1, index);
|
|
|
+ err = btrfs_add_nondir(trans, dir, dentry, inode, 1, index);
|
|
|
|
|
|
if (err) {
|
|
|
drop_inode = 1;
|
|
@@ -4856,8 +4853,7 @@ static int btrfs_mkdir(struct inode *dir, struct dentry *dentry, int mode)
|
|
|
btrfs_set_trans_block_group(trans, dir);
|
|
|
|
|
|
inode = btrfs_new_inode(trans, root, dir, dentry->d_name.name,
|
|
|
- dentry->d_name.len,
|
|
|
- dentry->d_parent->d_inode->i_ino, objectid,
|
|
|
+ dentry->d_name.len, dir->i_ino, objectid,
|
|
|
BTRFS_I(dir)->block_group, S_IFDIR | mode,
|
|
|
&index);
|
|
|
if (IS_ERR(inode)) {
|
|
@@ -4880,9 +4876,8 @@ static int btrfs_mkdir(struct inode *dir, struct dentry *dentry, int mode)
|
|
|
if (err)
|
|
|
goto out_fail;
|
|
|
|
|
|
- err = btrfs_add_link(trans, dentry->d_parent->d_inode,
|
|
|
- inode, dentry->d_name.name,
|
|
|
- dentry->d_name.len, 0, index);
|
|
|
+ err = btrfs_add_link(trans, dir, inode, dentry->d_name.name,
|
|
|
+ dentry->d_name.len, 0, index);
|
|
|
if (err)
|
|
|
goto out_fail;
|
|
|
|
|
@@ -6922,8 +6917,7 @@ static int btrfs_symlink(struct inode *dir, struct dentry *dentry,
|
|
|
btrfs_set_trans_block_group(trans, dir);
|
|
|
|
|
|
inode = btrfs_new_inode(trans, root, dir, dentry->d_name.name,
|
|
|
- dentry->d_name.len,
|
|
|
- dentry->d_parent->d_inode->i_ino, objectid,
|
|
|
+ dentry->d_name.len, dir->i_ino, objectid,
|
|
|
BTRFS_I(dir)->block_group, S_IFLNK|S_IRWXUGO,
|
|
|
&index);
|
|
|
err = PTR_ERR(inode);
|
|
@@ -6937,7 +6931,7 @@ static int btrfs_symlink(struct inode *dir, struct dentry *dentry,
|
|
|
}
|
|
|
|
|
|
btrfs_set_trans_block_group(trans, inode);
|
|
|
- err = btrfs_add_nondir(trans, dentry, inode, 0, index);
|
|
|
+ err = btrfs_add_nondir(trans, dir, dentry, inode, 0, index);
|
|
|
if (err)
|
|
|
drop_inode = 1;
|
|
|
else {
|