2017-01-26 00:09:10 +08:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Defines and function declarations for users of the mkfs API, no internal
|
2020-03-28 04:36:52 +08:00
|
|
|
* definitions.
|
2017-01-26 00:09:10 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __BTRFS_CONVERT_COMMON_H__
|
|
|
|
#define __BTRFS_CONVERT_COMMON_H__
|
|
|
|
|
|
|
|
#include "kerncompat.h"
|
2020-08-18 17:12:28 +08:00
|
|
|
#include "common/extent-cache.h"
|
2017-01-26 00:09:10 +08:00
|
|
|
|
|
|
|
struct btrfs_mkfs_config;
|
|
|
|
|
2022-09-15 19:53:43 +08:00
|
|
|
#define SOURCE_FS_UUID_SIZE (16)
|
|
|
|
|
2017-01-26 00:09:10 +08:00
|
|
|
struct btrfs_convert_context {
|
|
|
|
u32 blocksize;
|
2017-06-26 20:43:31 +08:00
|
|
|
u64 first_data_block;
|
|
|
|
u64 block_count;
|
|
|
|
u64 inodes_count;
|
|
|
|
u64 free_inodes_count;
|
2017-01-26 00:09:10 +08:00
|
|
|
u64 total_bytes;
|
2020-07-29 16:40:38 +08:00
|
|
|
u64 free_bytes_initial;
|
2021-08-18 04:39:33 +08:00
|
|
|
char *label;
|
2021-08-17 22:47:18 +08:00
|
|
|
u8 fs_uuid[SOURCE_FS_UUID_SIZE];
|
2017-01-26 00:09:10 +08:00
|
|
|
const struct btrfs_convert_operations *convert_ops;
|
|
|
|
|
|
|
|
/* The accurate used space of old filesystem */
|
2017-02-01 22:06:04 +08:00
|
|
|
struct cache_tree used_space;
|
2017-01-26 00:09:10 +08:00
|
|
|
|
|
|
|
/* Batched ranges which must be covered by data chunks */
|
|
|
|
struct cache_tree data_chunks;
|
|
|
|
|
|
|
|
/* Free space which is not covered by data_chunks */
|
2017-02-01 22:06:04 +08:00
|
|
|
struct cache_tree free_space;
|
2017-01-26 00:09:10 +08:00
|
|
|
|
2020-07-29 16:40:38 +08:00
|
|
|
/*
|
|
|
|
* Free space reserved for ENOSPC report, it's just a copy free_space.
|
|
|
|
* But after initial calculation, free_space_initial is no longer
|
|
|
|
* updated, so we have a good idea on how much free space we really
|
|
|
|
* have for btrfs.
|
|
|
|
*/
|
|
|
|
struct cache_tree free_space_initial;
|
2017-01-26 00:09:10 +08:00
|
|
|
void *fs_data;
|
|
|
|
};
|
|
|
|
|
|
|
|
int make_convert_btrfs(int fd, struct btrfs_mkfs_config *cfg,
|
|
|
|
struct btrfs_convert_context *cctx);
|
|
|
|
|
2022-06-27 07:52:42 +08:00
|
|
|
/*
|
|
|
|
* Represents a simple contiguous range.
|
|
|
|
*
|
|
|
|
* For multiple or non-contiguous ranges, use extent_cache_tree from
|
|
|
|
* extent-cache.c
|
|
|
|
*/
|
|
|
|
struct simple_range {
|
|
|
|
u64 start;
|
|
|
|
u64 len;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Simple range functions
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Get range end (exclusive) */
|
|
|
|
static inline u64 range_end(const struct simple_range *range)
|
|
|
|
{
|
|
|
|
return (range->start + range->len);
|
|
|
|
}
|
|
|
|
|
2017-01-26 00:09:10 +08:00
|
|
|
#endif
|