File: btrfsutil_internal.h

package info (click to toggle)
btrfs-progs 6.14-1~bpo12%2B1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-backports
  • size: 18,244 kB
  • sloc: ansic: 125,283; sh: 7,567; python: 1,386; makefile: 899; asm: 296
file content (94 lines) | stat: -rw-r--r-- 2,971 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/*
 * Copyright (C) 2018 Facebook
 *
 * This file is part of libbtrfsutil.
 *
 * libbtrfsutil is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 2.1 of the License, or
 * (at your option) any later version.
 *
 * libbtrfsutil 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 Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with libbtrfsutil.  If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef _LIBBTRFSUTIL_BTRFSUTIL_INTERNAL_H_
#define _LIBBTRFSUTIL_BTRFSUTIL_INTERNAL_H_

#include <asm/byteorder.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>

#include "btrfsutil.h"
#include "btrfs.h"
#include "btrfs_tree.h"

#define PUBLIC __attribute__((visibility("default")))
#define LIBBTRFSUTIL_ALIAS(orig)	__attribute__((alias(#orig)))

#define le16_to_cpu __le16_to_cpu
#define le32_to_cpu __le32_to_cpu
#define le64_to_cpu __le64_to_cpu

#define SAVE_ERRNO_AND_CLOSE(fd) do {	\
	int saved_errno = errno;	\
					\
	close(fd);			\
	errno = saved_errno;		\
} while (0)

struct __unagligned_u16 { __le16 x; } __attribute__((__packed__));
struct __unagligned_u32 { __le32 x; } __attribute__((__packed__));
struct __unagligned_u64 { __le64 x; } __attribute__((__packed__));

static inline __u16 get_unaligned_le16(const void *ptr)
{
	return le16_to_cpu(((const struct __unagligned_u16 *)(ptr))->x);
}

static inline __u32 get_unaligned_le32(const void *ptr)
{
	return le32_to_cpu(((const struct __unagligned_u32 *)(ptr))->x);
}

static inline __u64 get_unaligned_le64(const void *ptr)
{
	return le64_to_cpu(((const struct __unagligned_u64 *)(ptr))->x);
}

/*
 * Accessors of search header that is commonly mapped to a byte buffer so the
 * alignment is not guaranteed. This is always CPU order.
 */
static inline __u64 btrfs_search_header_transid(const struct btrfs_ioctl_search_header *sh)
{
	return ((const struct __unagligned_u64 *)(const void *)(&sh->transid))->x;
}

static inline __u64 btrfs_search_header_objectid(const struct btrfs_ioctl_search_header *sh)
{
	return ((const struct __unagligned_u64 *)(const void *)(&sh->objectid))->x;
}

static inline __u64 btrfs_search_header_offset(const struct btrfs_ioctl_search_header *sh)
{
	return ((const struct __unagligned_u64 *)(const void *)(&sh->offset))->x;
}

static inline __u32 btrfs_search_header_type(const struct btrfs_ioctl_search_header *sh)
{
	return ((const struct __unagligned_u32 *)(const void *)(&sh->type))->x;
}

static inline __u32 btrfs_search_header_len(const struct btrfs_ioctl_search_header *sh)
{
	return ((const struct __unagligned_u32 *)(const void *)(&sh->len))->x;
}

#endif /* _LIBBTRFSUTIL_BTRFSUTIL_INTERNAL_H_ */