mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-18 12:56:18 +07:00
Btrfs: Use btrfs_update_inode_fallback when creating a snapshot
On a really full file system I was getting ENOSPC back from btrfs_update_inode when trying to update the parent inode when creating a snapshot. Just use the fallback method so we can update the inode and not have to worry about having a delayed ref. Thanks, Signed-off-by: Josef Bacik <jbacik@fusionio.com>
This commit is contained in:
parent
e2d044fe77
commit
be6aef6049
@ -3338,6 +3338,8 @@ struct extent_map *btrfs_get_extent(struct inode *inode, struct page *page,
|
|||||||
int btrfs_update_inode(struct btrfs_trans_handle *trans,
|
int btrfs_update_inode(struct btrfs_trans_handle *trans,
|
||||||
struct btrfs_root *root,
|
struct btrfs_root *root,
|
||||||
struct inode *inode);
|
struct inode *inode);
|
||||||
|
int btrfs_update_inode_fallback(struct btrfs_trans_handle *trans,
|
||||||
|
struct btrfs_root *root, struct inode *inode);
|
||||||
int btrfs_orphan_add(struct btrfs_trans_handle *trans, struct inode *inode);
|
int btrfs_orphan_add(struct btrfs_trans_handle *trans, struct inode *inode);
|
||||||
int btrfs_orphan_del(struct btrfs_trans_handle *trans, struct inode *inode);
|
int btrfs_orphan_del(struct btrfs_trans_handle *trans, struct inode *inode);
|
||||||
int btrfs_orphan_cleanup(struct btrfs_root *root);
|
int btrfs_orphan_cleanup(struct btrfs_root *root);
|
||||||
|
@ -94,8 +94,6 @@ static noinline int cow_file_range(struct inode *inode,
|
|||||||
struct page *locked_page,
|
struct page *locked_page,
|
||||||
u64 start, u64 end, int *page_started,
|
u64 start, u64 end, int *page_started,
|
||||||
unsigned long *nr_written, int unlock);
|
unsigned long *nr_written, int unlock);
|
||||||
static noinline int btrfs_update_inode_fallback(struct btrfs_trans_handle *trans,
|
|
||||||
struct btrfs_root *root, struct inode *inode);
|
|
||||||
|
|
||||||
static int btrfs_init_inode_security(struct btrfs_trans_handle *trans,
|
static int btrfs_init_inode_security(struct btrfs_trans_handle *trans,
|
||||||
struct inode *inode, struct inode *dir,
|
struct inode *inode, struct inode *dir,
|
||||||
@ -2746,8 +2744,9 @@ noinline int btrfs_update_inode(struct btrfs_trans_handle *trans,
|
|||||||
return btrfs_update_inode_item(trans, root, inode);
|
return btrfs_update_inode_item(trans, root, inode);
|
||||||
}
|
}
|
||||||
|
|
||||||
static noinline int btrfs_update_inode_fallback(struct btrfs_trans_handle *trans,
|
noinline int btrfs_update_inode_fallback(struct btrfs_trans_handle *trans,
|
||||||
struct btrfs_root *root, struct inode *inode)
|
struct btrfs_root *root,
|
||||||
|
struct inode *inode)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -1200,7 +1200,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
|||||||
btrfs_i_size_write(parent_inode, parent_inode->i_size +
|
btrfs_i_size_write(parent_inode, parent_inode->i_size +
|
||||||
dentry->d_name.len * 2);
|
dentry->d_name.len * 2);
|
||||||
parent_inode->i_mtime = parent_inode->i_ctime = CURRENT_TIME;
|
parent_inode->i_mtime = parent_inode->i_ctime = CURRENT_TIME;
|
||||||
ret = btrfs_update_inode(trans, parent_root, parent_inode);
|
ret = btrfs_update_inode_fallback(trans, parent_root, parent_inode);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, root, ret);
|
||||||
fail:
|
fail:
|
||||||
|
Loading…
Reference in New Issue
Block a user