mirror of
https://github.com/kdave/btrfs-progs
synced 2025-01-13 01:01:13 +00:00
btrfs-progs: move btrfs_tree_search2_ioctl_supported to fsfeatures.c
The helper detects a feature support, so put it to the right file. Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
9be1b1c442
commit
45d034d774
@ -16,6 +16,7 @@
|
||||
|
||||
#include "kerncompat.h"
|
||||
#include <sys/utsname.h>
|
||||
#include <sys/ioctl.h>
|
||||
#include <linux/version.h>
|
||||
#include <unistd.h>
|
||||
#include "common/fsfeatures.h"
|
||||
@ -425,3 +426,41 @@ int btrfs_check_nodesize(u32 nodesize, u32 sectorsize, u64 features)
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* Check if the BTRFS_IOC_TREE_SEARCH_V2 ioctl is supported on a given
|
||||
* filesystem, opened at fd
|
||||
*/
|
||||
int btrfs_tree_search2_ioctl_supported(int fd)
|
||||
{
|
||||
struct btrfs_ioctl_search_args_v2 *args2;
|
||||
struct btrfs_ioctl_search_key *sk;
|
||||
int args2_size = 1024;
|
||||
char args2_buf[args2_size];
|
||||
int ret;
|
||||
|
||||
args2 = (struct btrfs_ioctl_search_args_v2 *)args2_buf;
|
||||
sk = &(args2->key);
|
||||
|
||||
/*
|
||||
* Search for the extent tree item in the root tree.
|
||||
*/
|
||||
sk->tree_id = BTRFS_ROOT_TREE_OBJECTID;
|
||||
sk->min_objectid = BTRFS_EXTENT_TREE_OBJECTID;
|
||||
sk->max_objectid = BTRFS_EXTENT_TREE_OBJECTID;
|
||||
sk->min_type = BTRFS_ROOT_ITEM_KEY;
|
||||
sk->max_type = BTRFS_ROOT_ITEM_KEY;
|
||||
sk->min_offset = 0;
|
||||
sk->max_offset = (u64)-1;
|
||||
sk->min_transid = 0;
|
||||
sk->max_transid = (u64)-1;
|
||||
sk->nr_items = 1;
|
||||
args2->buf_size = args2_size - sizeof(struct btrfs_ioctl_search_args_v2);
|
||||
ret = ioctl(fd, BTRFS_IOC_TREE_SEARCH_V2, args2);
|
||||
if (ret == -EOPNOTSUPP)
|
||||
return 0;
|
||||
else if (ret == 0)
|
||||
return 1;
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -55,5 +55,6 @@ void print_kernel_version(FILE *stream, u32 version);
|
||||
u32 get_running_kernel_version(void);
|
||||
int btrfs_check_nodesize(u32 nodesize, u32 sectorsize, u64 features);
|
||||
int btrfs_check_sectorsize(u32 sectorsize);
|
||||
int btrfs_tree_search2_ioctl_supported(int fd);
|
||||
|
||||
#endif
|
||||
|
@ -1108,42 +1108,6 @@ const char* btrfs_group_profile_str(u64 flag)
|
||||
return "unknown";
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Check if the BTRFS_IOC_TREE_SEARCH_V2 ioctl is supported on a given
|
||||
* filesystem, opened at fd
|
||||
*/
|
||||
int btrfs_tree_search2_ioctl_supported(int fd)
|
||||
{
|
||||
struct btrfs_ioctl_search_args_v2 *args2;
|
||||
struct btrfs_ioctl_search_key *sk;
|
||||
int args2_size = 1024;
|
||||
char args2_buf[args2_size];
|
||||
int ret;
|
||||
|
||||
args2 = (struct btrfs_ioctl_search_args_v2 *)args2_buf;
|
||||
sk = &(args2->key);
|
||||
|
||||
/*
|
||||
* Search for the extent tree item in the root tree.
|
||||
*/
|
||||
sk->tree_id = BTRFS_ROOT_TREE_OBJECTID;
|
||||
sk->min_objectid = BTRFS_EXTENT_TREE_OBJECTID;
|
||||
sk->max_objectid = BTRFS_EXTENT_TREE_OBJECTID;
|
||||
sk->min_type = BTRFS_ROOT_ITEM_KEY;
|
||||
sk->max_type = BTRFS_ROOT_ITEM_KEY;
|
||||
sk->min_offset = 0;
|
||||
sk->max_offset = (u64)-1;
|
||||
sk->min_transid = 0;
|
||||
sk->max_transid = (u64)-1;
|
||||
sk->nr_items = 1;
|
||||
args2->buf_size = args2_size - sizeof(struct btrfs_ioctl_search_args_v2);
|
||||
ret = ioctl(fd, BTRFS_IOC_TREE_SEARCH_V2, args2);
|
||||
if (ret == -EOPNOTSUPP)
|
||||
return 0;
|
||||
else if (ret == 0)
|
||||
return 1;
|
||||
return ret;
|
||||
}
|
||||
|
||||
u64 div_factor(u64 num, int factor)
|
||||
{
|
||||
|
@ -81,8 +81,6 @@ const char* btrfs_group_profile_str(u64 flag);
|
||||
int count_digits(u64 num);
|
||||
u64 div_factor(u64 num, int factor);
|
||||
|
||||
int btrfs_tree_search2_ioctl_supported(int fd);
|
||||
|
||||
int string_is_numerical(const char *str);
|
||||
int prefixcmp(const char *str, const char *prefix);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user