diff options
author | Jeff Mahoney <jeffm@suse.com> | 2016-06-15 10:25:38 -0400 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2016-07-26 07:54:24 -0400 |
commit | 14a1e067b45614d6236e3c82b36f62caef44ac62 (patch) | |
tree | 2efadf6e036988c7b3f9d3d8e120b76db51b29e8 | |
parent | 0c83b62e2222a8872f0b65d50540fdfa53b675ff (diff) |
btrfs: introduce BTRFS_MAX_ITEM_SIZE
We use BTRFS_LEAF_DATA_SIZE - sizeof(struct btrfs_item) in
several places. This introduces a BTRFS_MAX_ITEM_SIZE macro to do the
same.
Signed-off-by: Jeff Mahoney <jeffm@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
-rw-r--r-- | fs/btrfs/ctree.h | 8 | ||||
-rw-r--r-- | fs/btrfs/extent-tree.c | 2 | ||||
-rw-r--r-- | fs/btrfs/file-item.c | 5 | ||||
-rw-r--r-- | fs/btrfs/volumes.c | 3 |
4 files changed, 8 insertions, 10 deletions
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h index 950e4ee6b66e..1d46ceec1fc0 100644 --- a/fs/btrfs/ctree.h +++ b/fs/btrfs/ctree.h | |||
@@ -150,13 +150,13 @@ struct btrfs_header { | |||
150 | sizeof(struct btrfs_key_ptr)) | 150 | sizeof(struct btrfs_key_ptr)) |
151 | #define __BTRFS_LEAF_DATA_SIZE(bs) ((bs) - sizeof(struct btrfs_header)) | 151 | #define __BTRFS_LEAF_DATA_SIZE(bs) ((bs) - sizeof(struct btrfs_header)) |
152 | #define BTRFS_LEAF_DATA_SIZE(r) (__BTRFS_LEAF_DATA_SIZE(r->nodesize)) | 152 | #define BTRFS_LEAF_DATA_SIZE(r) (__BTRFS_LEAF_DATA_SIZE(r->nodesize)) |
153 | #define BTRFS_MAX_ITEM_SIZE(r) \ | ||
154 | (BTRFS_LEAF_DATA_SIZE(r) - sizeof(struct btrfs_item)) | ||
153 | #define BTRFS_FILE_EXTENT_INLINE_DATA_START \ | 155 | #define BTRFS_FILE_EXTENT_INLINE_DATA_START \ |
154 | (offsetof(struct btrfs_file_extent_item, disk_bytenr)) | 156 | (offsetof(struct btrfs_file_extent_item, disk_bytenr)) |
155 | #define BTRFS_MAX_INLINE_DATA_SIZE(r) (BTRFS_LEAF_DATA_SIZE(r) - \ | 157 | #define BTRFS_MAX_INLINE_DATA_SIZE(r) (BTRFS_MAX_ITEM_SIZE(r) - \ |
156 | sizeof(struct btrfs_item) - \ | ||
157 | BTRFS_FILE_EXTENT_INLINE_DATA_START) | 158 | BTRFS_FILE_EXTENT_INLINE_DATA_START) |
158 | #define BTRFS_MAX_XATTR_SIZE(r) (BTRFS_LEAF_DATA_SIZE(r) - \ | 159 | #define BTRFS_MAX_XATTR_SIZE(r) (BTRFS_MAX_ITEM_SIZE(r) - \ |
159 | sizeof(struct btrfs_item) -\ | ||
160 | sizeof(struct btrfs_dir_item)) | 160 | sizeof(struct btrfs_dir_item)) |
161 | 161 | ||
162 | 162 | ||
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index c4487e177234..44549d706dcd 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
@@ -2779,7 +2779,7 @@ u64 btrfs_csum_bytes_to_leaves(struct btrfs_root *root, u64 csum_bytes) | |||
2779 | u64 num_csums_per_leaf; | 2779 | u64 num_csums_per_leaf; |
2780 | u64 num_csums; | 2780 | u64 num_csums; |
2781 | 2781 | ||
2782 | csum_size = BTRFS_LEAF_DATA_SIZE(root) - sizeof(struct btrfs_item); | 2782 | csum_size = BTRFS_MAX_ITEM_SIZE(root); |
2783 | num_csums_per_leaf = div64_u64(csum_size, | 2783 | num_csums_per_leaf = div64_u64(csum_size, |
2784 | (u64)btrfs_super_csum_size(root->fs_info->super_copy)); | 2784 | (u64)btrfs_super_csum_size(root->fs_info->super_copy)); |
2785 | num_csums = div64_u64(csum_bytes, root->sectorsize); | 2785 | num_csums = div64_u64(csum_bytes, root->sectorsize); |
diff --git a/fs/btrfs/file-item.c b/fs/btrfs/file-item.c index 6b58d0620e2f..cdbbf85a269b 100644 --- a/fs/btrfs/file-item.c +++ b/fs/btrfs/file-item.c | |||
@@ -27,9 +27,8 @@ | |||
27 | #include "print-tree.h" | 27 | #include "print-tree.h" |
28 | #include "compression.h" | 28 | #include "compression.h" |
29 | 29 | ||
30 | #define __MAX_CSUM_ITEMS(r, size) ((unsigned long)(((BTRFS_LEAF_DATA_SIZE(r) - \ | 30 | #define __MAX_CSUM_ITEMS(r, size) \ |
31 | sizeof(struct btrfs_item) * 2) / \ | 31 | ((unsigned long)(((BTRFS_MAX_ITEM_SIZE(r) * 2) / size) - 1)) |
32 | size) - 1)) | ||
33 | 32 | ||
34 | #define MAX_CSUM_ITEMS(r, size) (min_t(u32, __MAX_CSUM_ITEMS(r, size), \ | 33 | #define MAX_CSUM_ITEMS(r, size) (min_t(u32, __MAX_CSUM_ITEMS(r, size), \ |
35 | PAGE_SIZE)) | 34 | PAGE_SIZE)) |
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c index 5e409e28a5c0..104a2e42ed71 100644 --- a/fs/btrfs/volumes.c +++ b/fs/btrfs/volumes.c | |||
@@ -4573,8 +4573,7 @@ static void check_raid56_incompat_flag(struct btrfs_fs_info *info, u64 type) | |||
4573 | btrfs_set_fs_incompat(info, RAID56); | 4573 | btrfs_set_fs_incompat(info, RAID56); |
4574 | } | 4574 | } |
4575 | 4575 | ||
4576 | #define BTRFS_MAX_DEVS(r) ((BTRFS_LEAF_DATA_SIZE(r) \ | 4576 | #define BTRFS_MAX_DEVS(r) ((BTRFS_MAX_ITEM_SIZE(r) \ |
4577 | - sizeof(struct btrfs_item) \ | ||
4578 | - sizeof(struct btrfs_chunk)) \ | 4577 | - sizeof(struct btrfs_chunk)) \ |
4579 | / sizeof(struct btrfs_stripe) + 1) | 4578 | / sizeof(struct btrfs_stripe) + 1) |
4580 | 4579 | ||