aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs
diff options
context:
space:
mode:
Diffstat (limited to 'fs/btrfs')
-rw-r--r--fs/btrfs/ctree.h8
-rw-r--r--fs/btrfs/extent-tree.c2
-rw-r--r--fs/btrfs/file-item.c5
-rw-r--r--fs/btrfs/volumes.c3
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