2015-09-30 03:51:45 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Facebook. All rights reserved.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public
|
|
|
|
* License v2 as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public
|
|
|
|
* License along with this program; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 021110-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __BTRFS_FREE_SPACE_TREE_H__
|
|
|
|
#define __BTRFS_FREE_SPACE_TREE_H__
|
|
|
|
|
2023-08-28 20:12:13 +00:00
|
|
|
#include "kerncompat.h"
|
|
|
|
#include "kernel-lib/bitops.h"
|
|
|
|
|
|
|
|
struct btrfs_block_group;
|
|
|
|
struct btrfs_fs_info;
|
|
|
|
struct btrfs_trans_handle;
|
|
|
|
|
2024-03-12 19:40:05 +00:00
|
|
|
/*
|
|
|
|
* The default size for new free space bitmap items. The last bitmap in a block
|
|
|
|
* group may be truncated, and none of the free space tree code assumes that
|
|
|
|
* existing bitmaps are this size.
|
|
|
|
*/
|
2018-10-01 14:46:16 +00:00
|
|
|
#define BTRFS_FREE_SPACE_BITMAP_SIZE 256
|
|
|
|
#define BTRFS_FREE_SPACE_BITMAP_BITS (BTRFS_FREE_SPACE_BITMAP_SIZE * BITS_PER_BYTE)
|
|
|
|
|
2022-05-20 01:31:50 +00:00
|
|
|
void set_free_space_tree_thresholds(struct btrfs_fs_info *fs_info,
|
|
|
|
struct btrfs_block_group *cache);
|
2016-11-14 18:43:21 +00:00
|
|
|
int btrfs_clear_free_space_tree(struct btrfs_fs_info *fs_info);
|
2015-09-30 03:51:45 +00:00
|
|
|
int load_free_space_tree(struct btrfs_fs_info *fs_info,
|
2020-05-01 06:52:19 +00:00
|
|
|
struct btrfs_block_group *block_group);
|
2018-10-01 14:46:16 +00:00
|
|
|
int populate_free_space_tree(struct btrfs_trans_handle *trans,
|
2020-05-01 06:52:19 +00:00
|
|
|
struct btrfs_block_group *block_group);
|
2018-10-01 14:46:16 +00:00
|
|
|
int remove_block_group_free_space(struct btrfs_trans_handle *trans,
|
2020-05-01 06:52:19 +00:00
|
|
|
struct btrfs_block_group *block_group);
|
2018-10-01 14:46:16 +00:00
|
|
|
int add_to_free_space_tree(struct btrfs_trans_handle *trans, u64 start,
|
|
|
|
u64 size);
|
|
|
|
int remove_from_free_space_tree(struct btrfs_trans_handle *trans, u64 start,
|
|
|
|
u64 size);
|
|
|
|
int btrfs_create_free_space_tree(struct btrfs_fs_info *info);
|
2021-08-23 20:14:53 +00:00
|
|
|
int add_block_group_free_space(struct btrfs_trans_handle *trans,
|
|
|
|
struct btrfs_block_group *block_group);
|
2015-09-30 03:51:45 +00:00
|
|
|
|
|
|
|
#endif
|