blob: b07f4aa6687836f95e9361e0cabd743a1a12b90a [file] [log] [blame]
David Sterba9888c342018-04-03 19:16:55 +02001/* SPDX-License-Identifier: GPL-2.0 */
Alexander Block31db9f72012-07-25 23:19:24 +02002/*
3 * Copyright (C) 2012 Alexander Block. All rights reserved.
4 * Copyright (C) 2012 STRATO. All rights reserved.
Alexander Block31db9f72012-07-25 23:19:24 +02005 */
6
David Sterba9888c342018-04-03 19:16:55 +02007#ifndef BTRFS_SEND_H
8#define BTRFS_SEND_H
9
David Sterba8234d3f2022-06-02 15:28:41 +020010#include <linux/types.h>
David Sterba602035d2024-01-27 03:19:56 +010011#include <linux/sizes.h>
12#include <linux/align.h>
13
David Sterba24e74592022-01-31 18:49:41 +010014struct btrfs_inode;
David Sterba602035d2024-01-27 03:19:56 +010015struct btrfs_ioctl_send_args;
Alexander Block31db9f72012-07-25 23:19:24 +020016
17#define BTRFS_SEND_STREAM_MAGIC "btrfs-stream"
Boris Burkov9971a742022-09-27 09:30:39 -070018/* Conditional support for the upcoming protocol version. */
19#ifdef CONFIG_BTRFS_DEBUG
20#define BTRFS_SEND_STREAM_VERSION 3
21#else
Omar Sandovald6815592022-03-17 10:25:43 -070022#define BTRFS_SEND_STREAM_VERSION 2
Boris Burkov9971a742022-09-27 09:30:39 -070023#endif
Alexander Block31db9f72012-07-25 23:19:24 +020024
Omar Sandovalb7c14f22022-03-17 10:25:39 -070025/*
Wang Yugui875c6272022-10-19 16:10:01 +080026 * In send stream v1, no command is larger than 64K. In send stream v2, no
27 * limit should be assumed, the buffer size is set to be a header with
28 * compressed extent size.
Omar Sandovalb7c14f22022-03-17 10:25:39 -070029 */
30#define BTRFS_SEND_BUF_SIZE_V1 SZ_64K
Wang Yugui875c6272022-10-19 16:10:01 +080031#define BTRFS_SEND_BUF_SIZE_V2 ALIGN(SZ_16K + BTRFS_MAX_COMPRESSED, PAGE_SIZE)
Alexander Block31db9f72012-07-25 23:19:24 +020032
33enum btrfs_tlv_type {
34 BTRFS_TLV_U8,
35 BTRFS_TLV_U16,
36 BTRFS_TLV_U32,
37 BTRFS_TLV_U64,
38 BTRFS_TLV_BINARY,
39 BTRFS_TLV_STRING,
40 BTRFS_TLV_UUID,
41 BTRFS_TLV_TIMESPEC,
42};
43
44struct btrfs_stream_header {
45 char magic[sizeof(BTRFS_SEND_STREAM_MAGIC)];
46 __le32 version;
47} __attribute__ ((__packed__));
48
49struct btrfs_cmd_header {
50 /* len excluding the header */
51 __le32 len;
52 __le16 cmd;
53 /* crc including the header with zero crc field */
54 __le32 crc;
55} __attribute__ ((__packed__));
56
57struct btrfs_tlv_header {
58 __le16 tlv_type;
59 /* len excluding the header */
60 __le16 tlv_len;
61} __attribute__ ((__packed__));
62
63/* commands */
64enum btrfs_send_cmd {
Omar Sandoval54cab6a2022-03-17 10:25:38 -070065 BTRFS_SEND_C_UNSPEC = 0,
Alexander Block31db9f72012-07-25 23:19:24 +020066
David Sterbae77fbf92021-10-22 16:53:36 +020067 /* Version 1 */
Omar Sandoval54cab6a2022-03-17 10:25:38 -070068 BTRFS_SEND_C_SUBVOL = 1,
69 BTRFS_SEND_C_SNAPSHOT = 2,
Alexander Block31db9f72012-07-25 23:19:24 +020070
Omar Sandoval54cab6a2022-03-17 10:25:38 -070071 BTRFS_SEND_C_MKFILE = 3,
72 BTRFS_SEND_C_MKDIR = 4,
73 BTRFS_SEND_C_MKNOD = 5,
74 BTRFS_SEND_C_MKFIFO = 6,
75 BTRFS_SEND_C_MKSOCK = 7,
76 BTRFS_SEND_C_SYMLINK = 8,
Alexander Block31db9f72012-07-25 23:19:24 +020077
Omar Sandoval54cab6a2022-03-17 10:25:38 -070078 BTRFS_SEND_C_RENAME = 9,
79 BTRFS_SEND_C_LINK = 10,
80 BTRFS_SEND_C_UNLINK = 11,
81 BTRFS_SEND_C_RMDIR = 12,
Alexander Block31db9f72012-07-25 23:19:24 +020082
Omar Sandoval54cab6a2022-03-17 10:25:38 -070083 BTRFS_SEND_C_SET_XATTR = 13,
84 BTRFS_SEND_C_REMOVE_XATTR = 14,
Alexander Block31db9f72012-07-25 23:19:24 +020085
Omar Sandoval54cab6a2022-03-17 10:25:38 -070086 BTRFS_SEND_C_WRITE = 15,
87 BTRFS_SEND_C_CLONE = 16,
Alexander Block31db9f72012-07-25 23:19:24 +020088
Omar Sandoval54cab6a2022-03-17 10:25:38 -070089 BTRFS_SEND_C_TRUNCATE = 17,
90 BTRFS_SEND_C_CHMOD = 18,
91 BTRFS_SEND_C_CHOWN = 19,
92 BTRFS_SEND_C_UTIMES = 20,
Alexander Block31db9f72012-07-25 23:19:24 +020093
Omar Sandoval54cab6a2022-03-17 10:25:38 -070094 BTRFS_SEND_C_END = 21,
95 BTRFS_SEND_C_UPDATE_EXTENT = 22,
96 BTRFS_SEND_C_MAX_V1 = 22,
David Sterbae77fbf92021-10-22 16:53:36 +020097
98 /* Version 2 */
Omar Sandovalb7c14f22022-03-17 10:25:39 -070099 BTRFS_SEND_C_FALLOCATE = 23,
David Sterba48247352022-05-18 18:02:55 +0200100 BTRFS_SEND_C_FILEATTR = 24,
Omar Sandovalb7c14f22022-03-17 10:25:39 -0700101 BTRFS_SEND_C_ENCODED_WRITE = 25,
102 BTRFS_SEND_C_MAX_V2 = 25,
David Sterbae77fbf92021-10-22 16:53:36 +0200103
Boris Burkov38622012022-08-15 13:54:28 -0700104 /* Version 3 */
105 BTRFS_SEND_C_ENABLE_VERITY = 26,
106 BTRFS_SEND_C_MAX_V3 = 26,
David Sterbae77fbf92021-10-22 16:53:36 +0200107 /* End */
Boris Burkov38622012022-08-15 13:54:28 -0700108 BTRFS_SEND_C_MAX = 26,
Alexander Block31db9f72012-07-25 23:19:24 +0200109};
Alexander Block31db9f72012-07-25 23:19:24 +0200110
111/* attributes in send stream */
112enum {
Omar Sandoval54cab6a2022-03-17 10:25:38 -0700113 BTRFS_SEND_A_UNSPEC = 0,
Alexander Block31db9f72012-07-25 23:19:24 +0200114
Omar Sandovalb7c14f22022-03-17 10:25:39 -0700115 /* Version 1 */
Omar Sandoval54cab6a2022-03-17 10:25:38 -0700116 BTRFS_SEND_A_UUID = 1,
117 BTRFS_SEND_A_CTRANSID = 2,
Alexander Block31db9f72012-07-25 23:19:24 +0200118
Omar Sandoval54cab6a2022-03-17 10:25:38 -0700119 BTRFS_SEND_A_INO = 3,
120 BTRFS_SEND_A_SIZE = 4,
121 BTRFS_SEND_A_MODE = 5,
122 BTRFS_SEND_A_UID = 6,
123 BTRFS_SEND_A_GID = 7,
124 BTRFS_SEND_A_RDEV = 8,
125 BTRFS_SEND_A_CTIME = 9,
126 BTRFS_SEND_A_MTIME = 10,
127 BTRFS_SEND_A_ATIME = 11,
128 BTRFS_SEND_A_OTIME = 12,
Alexander Block31db9f72012-07-25 23:19:24 +0200129
Omar Sandoval54cab6a2022-03-17 10:25:38 -0700130 BTRFS_SEND_A_XATTR_NAME = 13,
131 BTRFS_SEND_A_XATTR_DATA = 14,
Alexander Block31db9f72012-07-25 23:19:24 +0200132
Omar Sandoval54cab6a2022-03-17 10:25:38 -0700133 BTRFS_SEND_A_PATH = 15,
134 BTRFS_SEND_A_PATH_TO = 16,
135 BTRFS_SEND_A_PATH_LINK = 17,
Alexander Block31db9f72012-07-25 23:19:24 +0200136
Omar Sandoval54cab6a2022-03-17 10:25:38 -0700137 BTRFS_SEND_A_FILE_OFFSET = 18,
Omar Sandovalb7c14f22022-03-17 10:25:39 -0700138 /*
139 * As of send stream v2, this attribute is special: it must be the last
140 * attribute in a command, its header contains only the type, and its
141 * length is implicitly the remaining length of the command.
142 */
Omar Sandoval54cab6a2022-03-17 10:25:38 -0700143 BTRFS_SEND_A_DATA = 19,
Alexander Block31db9f72012-07-25 23:19:24 +0200144
Omar Sandoval54cab6a2022-03-17 10:25:38 -0700145 BTRFS_SEND_A_CLONE_UUID = 20,
146 BTRFS_SEND_A_CLONE_CTRANSID = 21,
147 BTRFS_SEND_A_CLONE_PATH = 22,
148 BTRFS_SEND_A_CLONE_OFFSET = 23,
149 BTRFS_SEND_A_CLONE_LEN = 24,
Alexander Block31db9f72012-07-25 23:19:24 +0200150
Omar Sandovalb7c14f22022-03-17 10:25:39 -0700151 BTRFS_SEND_A_MAX_V1 = 24,
152
153 /* Version 2 */
154 BTRFS_SEND_A_FALLOCATE_MODE = 25,
155
David Sterba48247352022-05-18 18:02:55 +0200156 /*
157 * File attributes from the FS_*_FL namespace (i_flags, xflags),
158 * translated to BTRFS_INODE_* bits (BTRFS_INODE_FLAG_MASK) and stored
159 * in btrfs_inode_item::flags (represented by btrfs_inode::flags and
160 * btrfs_inode::ro_flags).
161 */
162 BTRFS_SEND_A_FILEATTR = 26,
Omar Sandovalb7c14f22022-03-17 10:25:39 -0700163
164 BTRFS_SEND_A_UNENCODED_FILE_LEN = 27,
165 BTRFS_SEND_A_UNENCODED_LEN = 28,
166 BTRFS_SEND_A_UNENCODED_OFFSET = 29,
167 /*
168 * COMPRESSION and ENCRYPTION default to NONE (0) if omitted from
169 * BTRFS_SEND_C_ENCODED_WRITE.
170 */
171 BTRFS_SEND_A_COMPRESSION = 30,
172 BTRFS_SEND_A_ENCRYPTION = 31,
173 BTRFS_SEND_A_MAX_V2 = 31,
174
Boris Burkov38622012022-08-15 13:54:28 -0700175 /* Version 3 */
176 BTRFS_SEND_A_VERITY_ALGORITHM = 32,
177 BTRFS_SEND_A_VERITY_BLOCK_SIZE = 33,
178 BTRFS_SEND_A_VERITY_SALT_DATA = 34,
179 BTRFS_SEND_A_VERITY_SIG_DATA = 35,
180 BTRFS_SEND_A_MAX_V3 = 35,
181
182 __BTRFS_SEND_A_MAX = 35,
Alexander Block31db9f72012-07-25 23:19:24 +0200183};
Alexander Block31db9f72012-07-25 23:19:24 +0200184
David Sterba24e74592022-01-31 18:49:41 +0100185long btrfs_ioctl_send(struct btrfs_inode *inode, const struct btrfs_ioctl_send_args *arg);
David Sterba9888c342018-04-03 19:16:55 +0200186
187#endif