aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLi Zefan <lizefan@huawei.com>2012-07-09 22:21:07 -0400
committerChris Mason <chris.mason@fusionio.com>2012-07-23 16:28:05 -0400
commitb4d7c3c9456a311a45bc1ef8944b5ba5b176244f (patch)
tree217aeddfbcd502d8b61400cc0d87603f03c836f6
parentd5b025d510664382f9a197f7e7fb9fc60fe209bc (diff)
Btrfs: kill free_space pointer from inode structure
Inodes always allocate free space with BTRFS_BLOCK_GROUP_DATA type, which means every inode has the same BTRFS_I(inode)->free_space pointer. This shrinks struct btrfs_inode by 4 bytes (or 8 bytes on 64 bits). Signed-off-by: Li Zefan <lizefan@huawei.com>
-rw-r--r--fs/btrfs/btrfs_inode.h3
-rw-r--r--fs/btrfs/ctree.h3
-rw-r--r--fs/btrfs/extent-tree.c20
-rw-r--r--fs/btrfs/inode.c3
4 files changed, 10 insertions, 19 deletions
diff --git a/fs/btrfs/btrfs_inode.h b/fs/btrfs/btrfs_inode.h
index 21b8cfe08e95..5b2ad6bc4fe7 100644
--- a/fs/btrfs/btrfs_inode.h
+++ b/fs/btrfs/btrfs_inode.h
@@ -87,9 +87,6 @@ struct btrfs_inode {
87 /* node for the red-black tree that links inodes in subvolume root */ 87 /* node for the red-black tree that links inodes in subvolume root */
88 struct rb_node rb_node; 88 struct rb_node rb_node;
89 89
90 /* the space_info for where this inode's data allocations are done */
91 struct btrfs_space_info *space_info;
92
93 unsigned long runtime_flags; 90 unsigned long runtime_flags;
94 91
95 /* full 64 bit generation number, struct vfs_inode doesn't have a big 92 /* full 64 bit generation number, struct vfs_inode doesn't have a big
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h
index fa5c45b39075..6761490b91cd 100644
--- a/fs/btrfs/ctree.h
+++ b/fs/btrfs/ctree.h
@@ -1240,6 +1240,8 @@ struct btrfs_fs_info {
1240 */ 1240 */
1241 struct list_head space_info; 1241 struct list_head space_info;
1242 1242
1243 struct btrfs_space_info *data_sinfo;
1244
1243 struct reloc_control *reloc_ctl; 1245 struct reloc_control *reloc_ctl;
1244 1246
1245 spinlock_t delalloc_lock; 1247 spinlock_t delalloc_lock;
@@ -2607,7 +2609,6 @@ int btrfs_remove_block_group(struct btrfs_trans_handle *trans,
2607 struct btrfs_root *root, u64 group_start); 2609 struct btrfs_root *root, u64 group_start);
2608u64 btrfs_reduce_alloc_profile(struct btrfs_root *root, u64 flags); 2610u64 btrfs_reduce_alloc_profile(struct btrfs_root *root, u64 flags);
2609u64 btrfs_get_alloc_profile(struct btrfs_root *root, int data); 2611u64 btrfs_get_alloc_profile(struct btrfs_root *root, int data);
2610void btrfs_set_inode_space_info(struct btrfs_root *root, struct inode *ionde);
2611void btrfs_clear_space_info_full(struct btrfs_fs_info *info); 2612void btrfs_clear_space_info_full(struct btrfs_fs_info *info);
2612int btrfs_check_data_free_space(struct inode *inode, u64 bytes); 2613int btrfs_check_data_free_space(struct inode *inode, u64 bytes);
2613void btrfs_free_reserved_data_space(struct inode *inode, u64 bytes); 2614void btrfs_free_reserved_data_space(struct inode *inode, u64 bytes);
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c
index 7843542484c9..6621ed72f3c3 100644
--- a/fs/btrfs/extent-tree.c
+++ b/fs/btrfs/extent-tree.c
@@ -3139,6 +3139,8 @@ static int update_space_info(struct btrfs_fs_info *info, u64 flags,
3139 init_waitqueue_head(&found->wait); 3139 init_waitqueue_head(&found->wait);
3140 *space_info = found; 3140 *space_info = found;
3141 list_add_rcu(&found->list, &info->space_info); 3141 list_add_rcu(&found->list, &info->space_info);
3142 if (flags & BTRFS_BLOCK_GROUP_DATA)
3143 info->data_sinfo = found;
3142 return 0; 3144 return 0;
3143} 3145}
3144 3146
@@ -3268,12 +3270,6 @@ u64 btrfs_get_alloc_profile(struct btrfs_root *root, int data)
3268 return get_alloc_profile(root, flags); 3270 return get_alloc_profile(root, flags);
3269} 3271}
3270 3272
3271void btrfs_set_inode_space_info(struct btrfs_root *root, struct inode *inode)
3272{
3273 BTRFS_I(inode)->space_info = __find_space_info(root->fs_info,
3274 BTRFS_BLOCK_GROUP_DATA);
3275}
3276
3277/* 3273/*
3278 * This will check the space that the inode allocates from to make sure we have 3274 * This will check the space that the inode allocates from to make sure we have
3279 * enough space for bytes. 3275 * enough space for bytes.
@@ -3282,6 +3278,7 @@ int btrfs_check_data_free_space(struct inode *inode, u64 bytes)
3282{ 3278{
3283 struct btrfs_space_info *data_sinfo; 3279 struct btrfs_space_info *data_sinfo;
3284 struct btrfs_root *root = BTRFS_I(inode)->root; 3280 struct btrfs_root *root = BTRFS_I(inode)->root;
3281 struct btrfs_fs_info *fs_info = root->fs_info;
3285 u64 used; 3282 u64 used;
3286 int ret = 0, committed = 0, alloc_chunk = 1; 3283 int ret = 0, committed = 0, alloc_chunk = 1;
3287 3284
@@ -3294,7 +3291,7 @@ int btrfs_check_data_free_space(struct inode *inode, u64 bytes)
3294 committed = 1; 3291 committed = 1;
3295 } 3292 }
3296 3293
3297 data_sinfo = BTRFS_I(inode)->space_info; 3294 data_sinfo = fs_info->data_sinfo;
3298 if (!data_sinfo) 3295 if (!data_sinfo)
3299 goto alloc; 3296 goto alloc;
3300 3297
@@ -3335,10 +3332,9 @@ alloc:
3335 goto commit_trans; 3332 goto commit_trans;
3336 } 3333 }
3337 3334
3338 if (!data_sinfo) { 3335 if (!data_sinfo)
3339 btrfs_set_inode_space_info(root, inode); 3336 data_sinfo = fs_info->data_sinfo;
3340 data_sinfo = BTRFS_I(inode)->space_info; 3337
3341 }
3342 goto again; 3338 goto again;
3343 } 3339 }
3344 3340
@@ -3385,7 +3381,7 @@ void btrfs_free_reserved_data_space(struct inode *inode, u64 bytes)
3385 /* make sure bytes are sectorsize aligned */ 3381 /* make sure bytes are sectorsize aligned */
3386 bytes = (bytes + root->sectorsize - 1) & ~((u64)root->sectorsize - 1); 3382 bytes = (bytes + root->sectorsize - 1) & ~((u64)root->sectorsize - 1);
3387 3383
3388 data_sinfo = BTRFS_I(inode)->space_info; 3384 data_sinfo = root->fs_info->data_sinfo;
3389 spin_lock(&data_sinfo->lock); 3385 spin_lock(&data_sinfo->lock);
3390 data_sinfo->bytes_may_use -= bytes; 3386 data_sinfo->bytes_may_use -= bytes;
3391 trace_btrfs_space_reservation(root->fs_info, "space_info", 3387 trace_btrfs_space_reservation(root->fs_info, "space_info",
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index 321c415dea7f..ee45ebf42192 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -4082,7 +4082,6 @@ static int btrfs_init_locked_inode(struct inode *inode, void *p)
4082 struct btrfs_iget_args *args = p; 4082 struct btrfs_iget_args *args = p;
4083 inode->i_ino = args->ino; 4083 inode->i_ino = args->ino;
4084 BTRFS_I(inode)->root = args->root; 4084 BTRFS_I(inode)->root = args->root;
4085 btrfs_set_inode_space_info(args->root, inode);
4086 return 0; 4085 return 0;
4087} 4086}
4088 4087
@@ -4667,7 +4666,6 @@ static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
4667 BTRFS_I(inode)->root = root; 4666 BTRFS_I(inode)->root = root;
4668 BTRFS_I(inode)->generation = trans->transid; 4667 BTRFS_I(inode)->generation = trans->transid;
4669 inode->i_generation = BTRFS_I(inode)->generation; 4668 inode->i_generation = BTRFS_I(inode)->generation;
4670 btrfs_set_inode_space_info(root, inode);
4671 4669
4672 if (S_ISDIR(mode)) 4670 if (S_ISDIR(mode))
4673 owner = 0; 4671 owner = 0;
@@ -6944,7 +6942,6 @@ struct inode *btrfs_alloc_inode(struct super_block *sb)
6944 return NULL; 6942 return NULL;
6945 6943
6946 ei->root = NULL; 6944 ei->root = NULL;
6947 ei->space_info = NULL;
6948 ei->generation = 0; 6945 ei->generation = 0;
6949 ei->last_trans = 0; 6946 ei->last_trans = 0;
6950 ei->last_sub_trans = 0; 6947 ei->last_sub_trans = 0;