diff options
author | Miao Xie <miaox@cn.fujitsu.com> | 2013-05-15 07:48:24 +0000 |
---|---|---|
committer | Josef Bacik <jbacik@fusionio.com> | 2013-06-14 11:29:42 -0400 |
commit | 6a03843df4d29593912e558c72a2ce39274d2366 (patch) | |
tree | 90f049cfcebd10dde5b32446a4d5d7c3a243a0b1 /fs/btrfs/ioctl.c | |
parent | 199c2a9c3d1389db7f7a211e64f6809d352ce5f6 (diff) | |
download | linux-6a03843df4d29593912e558c72a2ce39274d2366.tar.gz linux-6a03843df4d29593912e558c72a2ce39274d2366.tar.bz2 linux-6a03843df4d29593912e558c72a2ce39274d2366.zip |
Btrfs: just flush the delalloc inodes in the source tree before snapshot creation
Before applying this patch, we need flush all the delalloc inodes in
the fs when we want to create a snapshot, it wastes time, and make
the transaction commit be blocked for a long time. It means some other
user operation would also be blocked for a long time.
This patch improves this problem, we just flush the delalloc inodes that
in the source trees before snapshot creation, so the transaction commit
will complete quickly.
Signed-off-by: Miao Xie <miaox@cn.fujitsu.com>
Signed-off-by: Josef Bacik <jbacik@fusionio.com>
Diffstat (limited to 'fs/btrfs/ioctl.c')
-rw-r--r-- | fs/btrfs/ioctl.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/btrfs/ioctl.c b/fs/btrfs/ioctl.c index 10484f4bb2cc..1f50fe2e62c7 100644 --- a/fs/btrfs/ioctl.c +++ b/fs/btrfs/ioctl.c @@ -555,6 +555,12 @@ static int create_snapshot(struct btrfs_root *root, struct inode *dir, if (!root->ref_cows) return -EINVAL; + ret = btrfs_start_delalloc_inodes(root, 0); + if (ret) + return ret; + + btrfs_wait_ordered_extents(root, 0); + pending_snapshot = kzalloc(sizeof(*pending_snapshot), GFP_NOFS); if (!pending_snapshot) return -ENOMEM; |