blob: dc2463e4cfe3c9a78a73d83f7aa05b2953531ccf [file] [log] [blame]
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00001/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Copyright (C) 2015 Facebook. All rights reserved.
4 */
5
6#ifndef BTRFS_FREE_SPACE_TREE_H
7#define BTRFS_FREE_SPACE_TREE_H
8
David Brazdil0f672f62019-12-10 10:32:29 +00009struct btrfs_caching_control;
10
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000011/*
12 * The default size for new free space bitmap items. The last bitmap in a block
13 * group may be truncated, and none of the free space tree code assumes that
14 * existing bitmaps are this size.
15 */
16#define BTRFS_FREE_SPACE_BITMAP_SIZE 256
17#define BTRFS_FREE_SPACE_BITMAP_BITS (BTRFS_FREE_SPACE_BITMAP_SIZE * BITS_PER_BYTE)
18
Olivier Deprez157378f2022-04-04 15:47:50 +020019void set_free_space_tree_thresholds(struct btrfs_block_group *block_group);
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000020int btrfs_create_free_space_tree(struct btrfs_fs_info *fs_info);
21int btrfs_clear_free_space_tree(struct btrfs_fs_info *fs_info);
22int load_free_space_tree(struct btrfs_caching_control *caching_ctl);
23int add_block_group_free_space(struct btrfs_trans_handle *trans,
Olivier Deprez157378f2022-04-04 15:47:50 +020024 struct btrfs_block_group *block_group);
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000025int remove_block_group_free_space(struct btrfs_trans_handle *trans,
Olivier Deprez157378f2022-04-04 15:47:50 +020026 struct btrfs_block_group *block_group);
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000027int add_to_free_space_tree(struct btrfs_trans_handle *trans,
28 u64 start, u64 size);
29int remove_from_free_space_tree(struct btrfs_trans_handle *trans,
30 u64 start, u64 size);
31
32#ifdef CONFIG_BTRFS_FS_RUN_SANITY_TESTS
33struct btrfs_free_space_info *
34search_free_space_info(struct btrfs_trans_handle *trans,
Olivier Deprez157378f2022-04-04 15:47:50 +020035 struct btrfs_block_group *block_group,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000036 struct btrfs_path *path, int cow);
37int __add_to_free_space_tree(struct btrfs_trans_handle *trans,
Olivier Deprez157378f2022-04-04 15:47:50 +020038 struct btrfs_block_group *block_group,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000039 struct btrfs_path *path, u64 start, u64 size);
40int __remove_from_free_space_tree(struct btrfs_trans_handle *trans,
Olivier Deprez157378f2022-04-04 15:47:50 +020041 struct btrfs_block_group *block_group,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000042 struct btrfs_path *path, u64 start, u64 size);
43int convert_free_space_to_bitmaps(struct btrfs_trans_handle *trans,
Olivier Deprez157378f2022-04-04 15:47:50 +020044 struct btrfs_block_group *block_group,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000045 struct btrfs_path *path);
46int convert_free_space_to_extents(struct btrfs_trans_handle *trans,
Olivier Deprez157378f2022-04-04 15:47:50 +020047 struct btrfs_block_group *block_group,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000048 struct btrfs_path *path);
Olivier Deprez157378f2022-04-04 15:47:50 +020049int free_space_test_bit(struct btrfs_block_group *block_group,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000050 struct btrfs_path *path, u64 offset);
51#endif
52
53#endif