mirror of
https://github.com/tbsdtv/linux_media.git
synced 2025-07-23 12:43:29 +02:00
btrfs: make btrfs_delayed_update_inode take btrfs_inode
Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Signed-off-by: Nikolay Borisov <nborisov@suse.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
committed by
David Sterba
parent
72e7e6edd3
commit
f3fbcaef59
@@ -1815,27 +1815,29 @@ int btrfs_fill_inode(struct inode *inode, u32 *rdev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int btrfs_delayed_update_inode(struct btrfs_trans_handle *trans,
|
int btrfs_delayed_update_inode(struct btrfs_trans_handle *trans,
|
||||||
struct btrfs_root *root, struct inode *inode)
|
struct btrfs_root *root,
|
||||||
|
struct btrfs_inode *inode)
|
||||||
{
|
{
|
||||||
struct btrfs_delayed_node *delayed_node;
|
struct btrfs_delayed_node *delayed_node;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
delayed_node = btrfs_get_or_create_delayed_node(BTRFS_I(inode));
|
delayed_node = btrfs_get_or_create_delayed_node(inode);
|
||||||
if (IS_ERR(delayed_node))
|
if (IS_ERR(delayed_node))
|
||||||
return PTR_ERR(delayed_node);
|
return PTR_ERR(delayed_node);
|
||||||
|
|
||||||
mutex_lock(&delayed_node->mutex);
|
mutex_lock(&delayed_node->mutex);
|
||||||
if (test_bit(BTRFS_DELAYED_NODE_INODE_DIRTY, &delayed_node->flags)) {
|
if (test_bit(BTRFS_DELAYED_NODE_INODE_DIRTY, &delayed_node->flags)) {
|
||||||
fill_stack_inode_item(trans, &delayed_node->inode_item, inode);
|
fill_stack_inode_item(trans, &delayed_node->inode_item,
|
||||||
|
&inode->vfs_inode);
|
||||||
goto release_node;
|
goto release_node;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = btrfs_delayed_inode_reserve_metadata(trans, root, BTRFS_I(inode),
|
ret = btrfs_delayed_inode_reserve_metadata(trans, root, inode,
|
||||||
delayed_node);
|
delayed_node);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto release_node;
|
goto release_node;
|
||||||
|
|
||||||
fill_stack_inode_item(trans, &delayed_node->inode_item, inode);
|
fill_stack_inode_item(trans, &delayed_node->inode_item, &inode->vfs_inode);
|
||||||
set_bit(BTRFS_DELAYED_NODE_INODE_DIRTY, &delayed_node->flags);
|
set_bit(BTRFS_DELAYED_NODE_INODE_DIRTY, &delayed_node->flags);
|
||||||
delayed_node->count++;
|
delayed_node->count++;
|
||||||
atomic_inc(&root->fs_info->delayed_root->items);
|
atomic_inc(&root->fs_info->delayed_root->items);
|
||||||
|
@@ -110,7 +110,8 @@ int btrfs_commit_inode_delayed_inode(struct btrfs_inode *inode);
|
|||||||
|
|
||||||
|
|
||||||
int btrfs_delayed_update_inode(struct btrfs_trans_handle *trans,
|
int btrfs_delayed_update_inode(struct btrfs_trans_handle *trans,
|
||||||
struct btrfs_root *root, struct inode *inode);
|
struct btrfs_root *root,
|
||||||
|
struct btrfs_inode *inode);
|
||||||
int btrfs_fill_inode(struct inode *inode, u32 *rdev);
|
int btrfs_fill_inode(struct inode *inode, u32 *rdev);
|
||||||
int btrfs_delayed_delete_inode_ref(struct btrfs_inode *inode);
|
int btrfs_delayed_delete_inode_ref(struct btrfs_inode *inode);
|
||||||
|
|
||||||
|
@@ -3674,7 +3674,7 @@ noinline int btrfs_update_inode(struct btrfs_trans_handle *trans,
|
|||||||
&& !test_bit(BTRFS_FS_LOG_RECOVERING, &fs_info->flags)) {
|
&& !test_bit(BTRFS_FS_LOG_RECOVERING, &fs_info->flags)) {
|
||||||
btrfs_update_root_times(trans, root);
|
btrfs_update_root_times(trans, root);
|
||||||
|
|
||||||
ret = btrfs_delayed_update_inode(trans, root, inode);
|
ret = btrfs_delayed_update_inode(trans, root, BTRFS_I(inode));
|
||||||
if (!ret)
|
if (!ret)
|
||||||
btrfs_set_inode_last_trans(trans, BTRFS_I(inode));
|
btrfs_set_inode_last_trans(trans, BTRFS_I(inode));
|
||||||
return ret;
|
return ret;
|
||||||
|
Reference in New Issue
Block a user