diff options
author | Nikolay Borisov <nborisov@suse.com> | 2017-02-20 06:50:42 -0500 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2017-02-28 05:30:07 -0500 |
commit | 691fa059673b3b33c25d7925acb0a58e8204dbd6 (patch) | |
tree | 1862cc21c43a68ede70fba801c908db94d86b68e | |
parent | 9f3db423f98c5c6c53b47f4bb2729901500bc330 (diff) |
btrfs: all btrfs_delalloc_release_metadata take btrfs_inode
Signed-off-by: Nikolay Borisov <nborisov@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
-rw-r--r-- | fs/btrfs/ctree.h | 2 | ||||
-rw-r--r-- | fs/btrfs/extent-tree.c | 18 | ||||
-rw-r--r-- | fs/btrfs/file.c | 5 | ||||
-rw-r--r-- | fs/btrfs/free-space-cache.c | 3 | ||||
-rw-r--r-- | fs/btrfs/inode-map.c | 2 | ||||
-rw-r--r-- | fs/btrfs/inode.c | 7 | ||||
-rw-r--r-- | fs/btrfs/relocation.c | 4 |
7 files changed, 22 insertions, 19 deletions
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h index 23dcc42f479b..7f7f3b60a73d 100644 --- a/fs/btrfs/ctree.h +++ b/fs/btrfs/ctree.h | |||
@@ -2704,7 +2704,7 @@ int btrfs_subvolume_reserve_metadata(struct btrfs_root *root, | |||
2704 | void btrfs_subvolume_release_metadata(struct btrfs_fs_info *fs_info, | 2704 | void btrfs_subvolume_release_metadata(struct btrfs_fs_info *fs_info, |
2705 | struct btrfs_block_rsv *rsv); | 2705 | struct btrfs_block_rsv *rsv); |
2706 | int btrfs_delalloc_reserve_metadata(struct btrfs_inode *inode, u64 num_bytes); | 2706 | int btrfs_delalloc_reserve_metadata(struct btrfs_inode *inode, u64 num_bytes); |
2707 | void btrfs_delalloc_release_metadata(struct inode *inode, u64 num_bytes); | 2707 | void btrfs_delalloc_release_metadata(struct btrfs_inode *inode, u64 num_bytes); |
2708 | int btrfs_delalloc_reserve_space(struct inode *inode, u64 start, u64 len); | 2708 | int btrfs_delalloc_reserve_space(struct inode *inode, u64 start, u64 len); |
2709 | void btrfs_delalloc_release_space(struct inode *inode, u64 start, u64 len); | 2709 | void btrfs_delalloc_release_space(struct inode *inode, u64 start, u64 len); |
2710 | void btrfs_init_block_rsv(struct btrfs_block_rsv *rsv, unsigned short type); | 2710 | void btrfs_init_block_rsv(struct btrfs_block_rsv *rsv, unsigned short type); |
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index 4db3cf4675a1..7b2313a4441e 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
@@ -6081,27 +6081,27 @@ out_fail: | |||
6081 | * once we complete IO for a given set of bytes to release their metadata | 6081 | * once we complete IO for a given set of bytes to release their metadata |
6082 | * reservations. | 6082 | * reservations. |
6083 | */ | 6083 | */ |
6084 | void btrfs_delalloc_release_metadata(struct inode *inode, u64 num_bytes) | 6084 | void btrfs_delalloc_release_metadata(struct btrfs_inode *inode, u64 num_bytes) |
6085 | { | 6085 | { |
6086 | struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb); | 6086 | struct btrfs_fs_info *fs_info = btrfs_sb(inode->vfs_inode.i_sb); |
6087 | u64 to_free = 0; | 6087 | u64 to_free = 0; |
6088 | unsigned dropped; | 6088 | unsigned dropped; |
6089 | 6089 | ||
6090 | num_bytes = ALIGN(num_bytes, fs_info->sectorsize); | 6090 | num_bytes = ALIGN(num_bytes, fs_info->sectorsize); |
6091 | spin_lock(&BTRFS_I(inode)->lock); | 6091 | spin_lock(&inode->lock); |
6092 | dropped = drop_outstanding_extent(BTRFS_I(inode), num_bytes); | 6092 | dropped = drop_outstanding_extent(inode, num_bytes); |
6093 | 6093 | ||
6094 | if (num_bytes) | 6094 | if (num_bytes) |
6095 | to_free = calc_csum_metadata_size(BTRFS_I(inode), num_bytes, 0); | 6095 | to_free = calc_csum_metadata_size(inode, num_bytes, 0); |
6096 | spin_unlock(&BTRFS_I(inode)->lock); | 6096 | spin_unlock(&inode->lock); |
6097 | if (dropped > 0) | 6097 | if (dropped > 0) |
6098 | to_free += btrfs_calc_trans_metadata_size(fs_info, dropped); | 6098 | to_free += btrfs_calc_trans_metadata_size(fs_info, dropped); |
6099 | 6099 | ||
6100 | if (btrfs_is_testing(fs_info)) | 6100 | if (btrfs_is_testing(fs_info)) |
6101 | return; | 6101 | return; |
6102 | 6102 | ||
6103 | trace_btrfs_space_reservation(fs_info, "delalloc", | 6103 | trace_btrfs_space_reservation(fs_info, "delalloc", btrfs_ino(inode), |
6104 | btrfs_ino(BTRFS_I(inode)), to_free, 0); | 6104 | to_free, 0); |
6105 | 6105 | ||
6106 | btrfs_block_rsv_release(fs_info, &fs_info->delalloc_block_rsv, to_free); | 6106 | btrfs_block_rsv_release(fs_info, &fs_info->delalloc_block_rsv, to_free); |
6107 | } | 6107 | } |
@@ -6159,7 +6159,7 @@ int btrfs_delalloc_reserve_space(struct inode *inode, u64 start, u64 len) | |||
6159 | */ | 6159 | */ |
6160 | void btrfs_delalloc_release_space(struct inode *inode, u64 start, u64 len) | 6160 | void btrfs_delalloc_release_space(struct inode *inode, u64 start, u64 len) |
6161 | { | 6161 | { |
6162 | btrfs_delalloc_release_metadata(inode, len); | 6162 | btrfs_delalloc_release_metadata(BTRFS_I(inode), len); |
6163 | btrfs_free_reserved_data_space(inode, start, len); | 6163 | btrfs_free_reserved_data_space(inode, start, len); |
6164 | } | 6164 | } |
6165 | 6165 | ||
diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c index e32a92081547..0e30d14b4916 100644 --- a/fs/btrfs/file.c +++ b/fs/btrfs/file.c | |||
@@ -1678,7 +1678,7 @@ again: | |||
1678 | spin_unlock(&BTRFS_I(inode)->lock); | 1678 | spin_unlock(&BTRFS_I(inode)->lock); |
1679 | } | 1679 | } |
1680 | if (only_release_metadata) { | 1680 | if (only_release_metadata) { |
1681 | btrfs_delalloc_release_metadata(inode, | 1681 | btrfs_delalloc_release_metadata(BTRFS_I(inode), |
1682 | release_bytes); | 1682 | release_bytes); |
1683 | } else { | 1683 | } else { |
1684 | u64 __pos; | 1684 | u64 __pos; |
@@ -1739,7 +1739,8 @@ again: | |||
1739 | if (release_bytes) { | 1739 | if (release_bytes) { |
1740 | if (only_release_metadata) { | 1740 | if (only_release_metadata) { |
1741 | btrfs_end_write_no_snapshoting(root); | 1741 | btrfs_end_write_no_snapshoting(root); |
1742 | btrfs_delalloc_release_metadata(inode, release_bytes); | 1742 | btrfs_delalloc_release_metadata(BTRFS_I(inode), |
1743 | release_bytes); | ||
1743 | } else { | 1744 | } else { |
1744 | btrfs_delalloc_release_space(inode, | 1745 | btrfs_delalloc_release_space(inode, |
1745 | round_down(pos, fs_info->sectorsize), | 1746 | round_down(pos, fs_info->sectorsize), |
diff --git a/fs/btrfs/free-space-cache.c b/fs/btrfs/free-space-cache.c index c0f313cbbbf2..7dcf0b100dcd 100644 --- a/fs/btrfs/free-space-cache.c +++ b/fs/btrfs/free-space-cache.c | |||
@@ -3545,7 +3545,8 @@ int btrfs_write_out_ino_cache(struct btrfs_root *root, | |||
3545 | 3545 | ||
3546 | if (ret) { | 3546 | if (ret) { |
3547 | if (release_metadata) | 3547 | if (release_metadata) |
3548 | btrfs_delalloc_release_metadata(inode, inode->i_size); | 3548 | btrfs_delalloc_release_metadata(BTRFS_I(inode), |
3549 | inode->i_size); | ||
3549 | #ifdef DEBUG | 3550 | #ifdef DEBUG |
3550 | btrfs_err(fs_info, | 3551 | btrfs_err(fs_info, |
3551 | "failed to write free ino cache for root %llu", | 3552 | "failed to write free ino cache for root %llu", |
diff --git a/fs/btrfs/inode-map.c b/fs/btrfs/inode-map.c index 3bbb8f095953..5c6c20ec64d8 100644 --- a/fs/btrfs/inode-map.c +++ b/fs/btrfs/inode-map.c | |||
@@ -499,7 +499,7 @@ again: | |||
499 | ret = btrfs_prealloc_file_range_trans(inode, trans, 0, 0, prealloc, | 499 | ret = btrfs_prealloc_file_range_trans(inode, trans, 0, 0, prealloc, |
500 | prealloc, prealloc, &alloc_hint); | 500 | prealloc, prealloc, &alloc_hint); |
501 | if (ret) { | 501 | if (ret) { |
502 | btrfs_delalloc_release_metadata(inode, prealloc); | 502 | btrfs_delalloc_release_metadata(BTRFS_I(inode), prealloc); |
503 | goto out_put; | 503 | goto out_put; |
504 | } | 504 | } |
505 | 505 | ||
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c index 8a14b47b4dc0..dd0f1abdacd2 100644 --- a/fs/btrfs/inode.c +++ b/fs/btrfs/inode.c | |||
@@ -316,7 +316,7 @@ static noinline int cow_file_range_inline(struct btrfs_root *root, | |||
316 | } | 316 | } |
317 | 317 | ||
318 | set_bit(BTRFS_INODE_NEEDS_FULL_SYNC, &BTRFS_I(inode)->runtime_flags); | 318 | set_bit(BTRFS_INODE_NEEDS_FULL_SYNC, &BTRFS_I(inode)->runtime_flags); |
319 | btrfs_delalloc_release_metadata(inode, end + 1 - start); | 319 | btrfs_delalloc_release_metadata(BTRFS_I(inode), end + 1 - start); |
320 | btrfs_drop_extent_cache(inode, start, aligned_end - 1, 0); | 320 | btrfs_drop_extent_cache(inode, start, aligned_end - 1, 0); |
321 | out: | 321 | out: |
322 | /* | 322 | /* |
@@ -1737,7 +1737,7 @@ static void btrfs_clear_bit_hook(struct inode *inode, | |||
1737 | */ | 1737 | */ |
1738 | if (*bits & EXTENT_DO_ACCOUNTING && | 1738 | if (*bits & EXTENT_DO_ACCOUNTING && |
1739 | root != fs_info->tree_root) | 1739 | root != fs_info->tree_root) |
1740 | btrfs_delalloc_release_metadata(inode, len); | 1740 | btrfs_delalloc_release_metadata(BTRFS_I(inode), len); |
1741 | 1741 | ||
1742 | /* For sanity tests. */ | 1742 | /* For sanity tests. */ |
1743 | if (btrfs_is_testing(fs_info)) | 1743 | if (btrfs_is_testing(fs_info)) |
@@ -2914,7 +2914,8 @@ out_unlock: | |||
2914 | ordered_extent->len - 1, &cached_state, GFP_NOFS); | 2914 | ordered_extent->len - 1, &cached_state, GFP_NOFS); |
2915 | out: | 2915 | out: |
2916 | if (root != fs_info->tree_root) | 2916 | if (root != fs_info->tree_root) |
2917 | btrfs_delalloc_release_metadata(inode, ordered_extent->len); | 2917 | btrfs_delalloc_release_metadata(BTRFS_I(inode), |
2918 | ordered_extent->len); | ||
2918 | if (trans) | 2919 | if (trans) |
2919 | btrfs_end_transaction(trans); | 2920 | btrfs_end_transaction(trans); |
2920 | 2921 | ||
diff --git a/fs/btrfs/relocation.c b/fs/btrfs/relocation.c index 4ee1490f086e..e6470890ce26 100644 --- a/fs/btrfs/relocation.c +++ b/fs/btrfs/relocation.c | |||
@@ -3216,7 +3216,7 @@ static int relocate_file_extent_cluster(struct inode *inode, | |||
3216 | page = find_or_create_page(inode->i_mapping, index, | 3216 | page = find_or_create_page(inode->i_mapping, index, |
3217 | mask); | 3217 | mask); |
3218 | if (!page) { | 3218 | if (!page) { |
3219 | btrfs_delalloc_release_metadata(inode, | 3219 | btrfs_delalloc_release_metadata(BTRFS_I(inode), |
3220 | PAGE_SIZE); | 3220 | PAGE_SIZE); |
3221 | ret = -ENOMEM; | 3221 | ret = -ENOMEM; |
3222 | goto out; | 3222 | goto out; |
@@ -3235,7 +3235,7 @@ static int relocate_file_extent_cluster(struct inode *inode, | |||
3235 | if (!PageUptodate(page)) { | 3235 | if (!PageUptodate(page)) { |
3236 | unlock_page(page); | 3236 | unlock_page(page); |
3237 | put_page(page); | 3237 | put_page(page); |
3238 | btrfs_delalloc_release_metadata(inode, | 3238 | btrfs_delalloc_release_metadata(BTRFS_I(inode), |
3239 | PAGE_SIZE); | 3239 | PAGE_SIZE); |
3240 | ret = -EIO; | 3240 | ret = -EIO; |
3241 | goto out; | 3241 | goto out; |