2018-04-03 17:16:55 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2012-07-25 21:19:24 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2012 Alexander Block. All rights reserved.
|
|
|
|
* Copyright (C) 2012 STRATO. All rights reserved.
|
|
|
|
*/
|
|
|
|
|
2018-04-03 17:16:55 +00:00
|
|
|
#ifndef BTRFS_SEND_H
|
|
|
|
#define BTRFS_SEND_H
|
|
|
|
|
2022-06-02 13:28:41 +00:00
|
|
|
#include <linux/types.h>
|
2012-07-25 21:19:24 +00:00
|
|
|
|
|
|
|
#define BTRFS_SEND_STREAM_MAGIC "btrfs-stream"
|
2022-09-27 16:30:39 +00:00
|
|
|
/* Conditional support for the upcoming protocol version. */
|
|
|
|
#ifdef CONFIG_BTRFS_DEBUG
|
|
|
|
#define BTRFS_SEND_STREAM_VERSION 3
|
|
|
|
#else
|
2022-03-17 17:25:43 +00:00
|
|
|
#define BTRFS_SEND_STREAM_VERSION 2
|
2022-09-27 16:30:39 +00:00
|
|
|
#endif
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2022-03-17 17:25:39 +00:00
|
|
|
/*
|
2022-10-19 08:10:01 +00:00
|
|
|
* In send stream v1, no command is larger than 64K. In send stream v2, no
|
|
|
|
* limit should be assumed, the buffer size is set to be a header with
|
|
|
|
* compressed extent size.
|
2022-03-17 17:25:39 +00:00
|
|
|
*/
|
|
|
|
#define BTRFS_SEND_BUF_SIZE_V1 SZ_64K
|
2022-10-19 08:10:01 +00:00
|
|
|
#define BTRFS_SEND_BUF_SIZE_V2 ALIGN(SZ_16K + BTRFS_MAX_COMPRESSED, PAGE_SIZE)
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2022-06-02 13:28:41 +00:00
|
|
|
struct inode;
|
|
|
|
struct btrfs_ioctl_send_args;
|
|
|
|
|
2012-07-25 21:19:24 +00:00
|
|
|
enum btrfs_tlv_type {
|
|
|
|
BTRFS_TLV_U8,
|
|
|
|
BTRFS_TLV_U16,
|
|
|
|
BTRFS_TLV_U32,
|
|
|
|
BTRFS_TLV_U64,
|
|
|
|
BTRFS_TLV_BINARY,
|
|
|
|
BTRFS_TLV_STRING,
|
|
|
|
BTRFS_TLV_UUID,
|
|
|
|
BTRFS_TLV_TIMESPEC,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct btrfs_stream_header {
|
|
|
|
char magic[sizeof(BTRFS_SEND_STREAM_MAGIC)];
|
|
|
|
__le32 version;
|
|
|
|
} __attribute__ ((__packed__));
|
|
|
|
|
|
|
|
struct btrfs_cmd_header {
|
|
|
|
/* len excluding the header */
|
|
|
|
__le32 len;
|
|
|
|
__le16 cmd;
|
|
|
|
/* crc including the header with zero crc field */
|
|
|
|
__le32 crc;
|
|
|
|
} __attribute__ ((__packed__));
|
|
|
|
|
|
|
|
struct btrfs_tlv_header {
|
|
|
|
__le16 tlv_type;
|
|
|
|
/* len excluding the header */
|
|
|
|
__le16 tlv_len;
|
|
|
|
} __attribute__ ((__packed__));
|
|
|
|
|
|
|
|
/* commands */
|
|
|
|
enum btrfs_send_cmd {
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_C_UNSPEC = 0,
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2021-10-22 14:53:36 +00:00
|
|
|
/* Version 1 */
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_C_SUBVOL = 1,
|
|
|
|
BTRFS_SEND_C_SNAPSHOT = 2,
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_C_MKFILE = 3,
|
|
|
|
BTRFS_SEND_C_MKDIR = 4,
|
|
|
|
BTRFS_SEND_C_MKNOD = 5,
|
|
|
|
BTRFS_SEND_C_MKFIFO = 6,
|
|
|
|
BTRFS_SEND_C_MKSOCK = 7,
|
|
|
|
BTRFS_SEND_C_SYMLINK = 8,
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_C_RENAME = 9,
|
|
|
|
BTRFS_SEND_C_LINK = 10,
|
|
|
|
BTRFS_SEND_C_UNLINK = 11,
|
|
|
|
BTRFS_SEND_C_RMDIR = 12,
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_C_SET_XATTR = 13,
|
|
|
|
BTRFS_SEND_C_REMOVE_XATTR = 14,
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_C_WRITE = 15,
|
|
|
|
BTRFS_SEND_C_CLONE = 16,
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_C_TRUNCATE = 17,
|
|
|
|
BTRFS_SEND_C_CHMOD = 18,
|
|
|
|
BTRFS_SEND_C_CHOWN = 19,
|
|
|
|
BTRFS_SEND_C_UTIMES = 20,
|
2012-07-25 21:19:24 +00:00
|
|
|
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_C_END = 21,
|
|
|
|
BTRFS_SEND_C_UPDATE_EXTENT = 22,
|
|
|
|
BTRFS_SEND_C_MAX_V1 = 22,
|
2021-10-22 14:53:36 +00:00
|
|
|
|
|
|
|
/* Version 2 */
|
2022-03-17 17:25:39 +00:00
|
|
|
BTRFS_SEND_C_FALLOCATE = 23,
|
2022-05-18 16:02:55 +00:00
|
|
|
BTRFS_SEND_C_FILEATTR = 24,
|
2022-03-17 17:25:39 +00:00
|
|
|
BTRFS_SEND_C_ENCODED_WRITE = 25,
|
|
|
|
BTRFS_SEND_C_MAX_V2 = 25,
|
2021-10-22 14:53:36 +00:00
|
|
|
|
2022-08-15 20:54:28 +00:00
|
|
|
/* Version 3 */
|
|
|
|
BTRFS_SEND_C_ENABLE_VERITY = 26,
|
|
|
|
BTRFS_SEND_C_MAX_V3 = 26,
|
2021-10-22 14:53:36 +00:00
|
|
|
/* End */
|
2022-08-15 20:54:28 +00:00
|
|
|
BTRFS_SEND_C_MAX = 26,
|
2012-07-25 21:19:24 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* attributes in send stream */
|
|
|
|
enum {
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_A_UNSPEC = 0,
|
|
|
|
|
2022-03-17 17:25:39 +00:00
|
|
|
/* Version 1 */
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_A_UUID = 1,
|
|
|
|
BTRFS_SEND_A_CTRANSID = 2,
|
|
|
|
|
|
|
|
BTRFS_SEND_A_INO = 3,
|
|
|
|
BTRFS_SEND_A_SIZE = 4,
|
|
|
|
BTRFS_SEND_A_MODE = 5,
|
|
|
|
BTRFS_SEND_A_UID = 6,
|
|
|
|
BTRFS_SEND_A_GID = 7,
|
|
|
|
BTRFS_SEND_A_RDEV = 8,
|
|
|
|
BTRFS_SEND_A_CTIME = 9,
|
|
|
|
BTRFS_SEND_A_MTIME = 10,
|
|
|
|
BTRFS_SEND_A_ATIME = 11,
|
|
|
|
BTRFS_SEND_A_OTIME = 12,
|
|
|
|
|
|
|
|
BTRFS_SEND_A_XATTR_NAME = 13,
|
|
|
|
BTRFS_SEND_A_XATTR_DATA = 14,
|
|
|
|
|
|
|
|
BTRFS_SEND_A_PATH = 15,
|
|
|
|
BTRFS_SEND_A_PATH_TO = 16,
|
|
|
|
BTRFS_SEND_A_PATH_LINK = 17,
|
|
|
|
|
|
|
|
BTRFS_SEND_A_FILE_OFFSET = 18,
|
2022-03-17 17:25:39 +00:00
|
|
|
/*
|
|
|
|
* As of send stream v2, this attribute is special: it must be the last
|
|
|
|
* attribute in a command, its header contains only the type, and its
|
|
|
|
* length is implicitly the remaining length of the command.
|
|
|
|
*/
|
2022-03-17 17:25:38 +00:00
|
|
|
BTRFS_SEND_A_DATA = 19,
|
|
|
|
|
|
|
|
BTRFS_SEND_A_CLONE_UUID = 20,
|
|
|
|
BTRFS_SEND_A_CLONE_CTRANSID = 21,
|
|
|
|
BTRFS_SEND_A_CLONE_PATH = 22,
|
|
|
|
BTRFS_SEND_A_CLONE_OFFSET = 23,
|
|
|
|
BTRFS_SEND_A_CLONE_LEN = 24,
|
|
|
|
|
2022-03-17 17:25:39 +00:00
|
|
|
BTRFS_SEND_A_MAX_V1 = 24,
|
|
|
|
|
|
|
|
/* Version 2 */
|
|
|
|
BTRFS_SEND_A_FALLOCATE_MODE = 25,
|
|
|
|
|
2022-05-18 16:02:55 +00:00
|
|
|
/*
|
|
|
|
* File attributes from the FS_*_FL namespace (i_flags, xflags),
|
|
|
|
* translated to BTRFS_INODE_* bits (BTRFS_INODE_FLAG_MASK) and stored
|
|
|
|
* in btrfs_inode_item::flags (represented by btrfs_inode::flags and
|
|
|
|
* btrfs_inode::ro_flags).
|
|
|
|
*/
|
|
|
|
BTRFS_SEND_A_FILEATTR = 26,
|
2022-03-17 17:25:39 +00:00
|
|
|
|
|
|
|
BTRFS_SEND_A_UNENCODED_FILE_LEN = 27,
|
|
|
|
BTRFS_SEND_A_UNENCODED_LEN = 28,
|
|
|
|
BTRFS_SEND_A_UNENCODED_OFFSET = 29,
|
|
|
|
/*
|
|
|
|
* COMPRESSION and ENCRYPTION default to NONE (0) if omitted from
|
|
|
|
* BTRFS_SEND_C_ENCODED_WRITE.
|
|
|
|
*/
|
|
|
|
BTRFS_SEND_A_COMPRESSION = 30,
|
|
|
|
BTRFS_SEND_A_ENCRYPTION = 31,
|
|
|
|
BTRFS_SEND_A_MAX_V2 = 31,
|
|
|
|
|
2022-08-15 20:54:28 +00:00
|
|
|
/* Version 3 */
|
|
|
|
BTRFS_SEND_A_VERITY_ALGORITHM = 32,
|
|
|
|
BTRFS_SEND_A_VERITY_BLOCK_SIZE = 33,
|
|
|
|
BTRFS_SEND_A_VERITY_SALT_DATA = 34,
|
|
|
|
BTRFS_SEND_A_VERITY_SIG_DATA = 35,
|
|
|
|
BTRFS_SEND_A_MAX_V3 = 35,
|
|
|
|
|
|
|
|
__BTRFS_SEND_A_MAX = 35,
|
2012-07-25 21:19:24 +00:00
|
|
|
};
|
|
|
|
|
2022-01-16 02:48:47 +00:00
|
|
|
long btrfs_ioctl_send(struct inode *inode, struct btrfs_ioctl_send_args *arg);
|
2018-04-03 17:16:55 +00:00
|
|
|
|
|
|
|
#endif
|