David Sterba | 9888c34 | 2018-04-03 19:16:55 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 2 | /* |
| 3 | * Copyright (C) 2012 Alexander Block. All rights reserved. |
| 4 | * Copyright (C) 2012 STRATO. All rights reserved. |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 5 | */ |
| 6 | |
David Sterba | 9888c34 | 2018-04-03 19:16:55 +0200 | [diff] [blame] | 7 | #ifndef BTRFS_SEND_H |
| 8 | #define BTRFS_SEND_H |
| 9 | |
David Sterba | 8234d3f | 2022-06-02 15:28:41 +0200 | [diff] [blame] | 10 | #include <linux/types.h> |
David Sterba | 602035d | 2024-01-27 03:19:56 +0100 | [diff] [blame] | 11 | #include <linux/sizes.h> |
| 12 | #include <linux/align.h> |
| 13 | |
David Sterba | 24e7459 | 2022-01-31 18:49:41 +0100 | [diff] [blame] | 14 | struct btrfs_inode; |
David Sterba | 602035d | 2024-01-27 03:19:56 +0100 | [diff] [blame] | 15 | struct btrfs_ioctl_send_args; |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 16 | |
| 17 | #define BTRFS_SEND_STREAM_MAGIC "btrfs-stream" |
Boris Burkov | 9971a74 | 2022-09-27 09:30:39 -0700 | [diff] [blame] | 18 | /* Conditional support for the upcoming protocol version. */ |
| 19 | #ifdef CONFIG_BTRFS_DEBUG |
| 20 | #define BTRFS_SEND_STREAM_VERSION 3 |
| 21 | #else |
Omar Sandoval | d681559 | 2022-03-17 10:25:43 -0700 | [diff] [blame] | 22 | #define BTRFS_SEND_STREAM_VERSION 2 |
Boris Burkov | 9971a74 | 2022-09-27 09:30:39 -0700 | [diff] [blame] | 23 | #endif |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 24 | |
Omar Sandoval | b7c14f2 | 2022-03-17 10:25:39 -0700 | [diff] [blame] | 25 | /* |
Wang Yugui | 875c627 | 2022-10-19 16:10:01 +0800 | [diff] [blame] | 26 | * 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 Sandoval | b7c14f2 | 2022-03-17 10:25:39 -0700 | [diff] [blame] | 29 | */ |
| 30 | #define BTRFS_SEND_BUF_SIZE_V1 SZ_64K |
Wang Yugui | 875c627 | 2022-10-19 16:10:01 +0800 | [diff] [blame] | 31 | #define BTRFS_SEND_BUF_SIZE_V2 ALIGN(SZ_16K + BTRFS_MAX_COMPRESSED, PAGE_SIZE) |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 32 | |
| 33 | enum 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 | |
| 44 | struct btrfs_stream_header { |
| 45 | char magic[sizeof(BTRFS_SEND_STREAM_MAGIC)]; |
| 46 | __le32 version; |
| 47 | } __attribute__ ((__packed__)); |
| 48 | |
| 49 | struct 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 | |
| 57 | struct btrfs_tlv_header { |
| 58 | __le16 tlv_type; |
| 59 | /* len excluding the header */ |
| 60 | __le16 tlv_len; |
| 61 | } __attribute__ ((__packed__)); |
| 62 | |
| 63 | /* commands */ |
| 64 | enum btrfs_send_cmd { |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 65 | BTRFS_SEND_C_UNSPEC = 0, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 66 | |
David Sterba | e77fbf9 | 2021-10-22 16:53:36 +0200 | [diff] [blame] | 67 | /* Version 1 */ |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 68 | BTRFS_SEND_C_SUBVOL = 1, |
| 69 | BTRFS_SEND_C_SNAPSHOT = 2, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 70 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 71 | 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 Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 77 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 78 | BTRFS_SEND_C_RENAME = 9, |
| 79 | BTRFS_SEND_C_LINK = 10, |
| 80 | BTRFS_SEND_C_UNLINK = 11, |
| 81 | BTRFS_SEND_C_RMDIR = 12, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 82 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 83 | BTRFS_SEND_C_SET_XATTR = 13, |
| 84 | BTRFS_SEND_C_REMOVE_XATTR = 14, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 85 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 86 | BTRFS_SEND_C_WRITE = 15, |
| 87 | BTRFS_SEND_C_CLONE = 16, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 88 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 89 | BTRFS_SEND_C_TRUNCATE = 17, |
| 90 | BTRFS_SEND_C_CHMOD = 18, |
| 91 | BTRFS_SEND_C_CHOWN = 19, |
| 92 | BTRFS_SEND_C_UTIMES = 20, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 93 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 94 | BTRFS_SEND_C_END = 21, |
| 95 | BTRFS_SEND_C_UPDATE_EXTENT = 22, |
| 96 | BTRFS_SEND_C_MAX_V1 = 22, |
David Sterba | e77fbf9 | 2021-10-22 16:53:36 +0200 | [diff] [blame] | 97 | |
| 98 | /* Version 2 */ |
Omar Sandoval | b7c14f2 | 2022-03-17 10:25:39 -0700 | [diff] [blame] | 99 | BTRFS_SEND_C_FALLOCATE = 23, |
David Sterba | 4824735 | 2022-05-18 18:02:55 +0200 | [diff] [blame] | 100 | BTRFS_SEND_C_FILEATTR = 24, |
Omar Sandoval | b7c14f2 | 2022-03-17 10:25:39 -0700 | [diff] [blame] | 101 | BTRFS_SEND_C_ENCODED_WRITE = 25, |
| 102 | BTRFS_SEND_C_MAX_V2 = 25, |
David Sterba | e77fbf9 | 2021-10-22 16:53:36 +0200 | [diff] [blame] | 103 | |
Boris Burkov | 3862201 | 2022-08-15 13:54:28 -0700 | [diff] [blame] | 104 | /* Version 3 */ |
| 105 | BTRFS_SEND_C_ENABLE_VERITY = 26, |
| 106 | BTRFS_SEND_C_MAX_V3 = 26, |
David Sterba | e77fbf9 | 2021-10-22 16:53:36 +0200 | [diff] [blame] | 107 | /* End */ |
Boris Burkov | 3862201 | 2022-08-15 13:54:28 -0700 | [diff] [blame] | 108 | BTRFS_SEND_C_MAX = 26, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 109 | }; |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 110 | |
| 111 | /* attributes in send stream */ |
| 112 | enum { |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 113 | BTRFS_SEND_A_UNSPEC = 0, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 114 | |
Omar Sandoval | b7c14f2 | 2022-03-17 10:25:39 -0700 | [diff] [blame] | 115 | /* Version 1 */ |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 116 | BTRFS_SEND_A_UUID = 1, |
| 117 | BTRFS_SEND_A_CTRANSID = 2, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 118 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 119 | 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 Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 129 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 130 | BTRFS_SEND_A_XATTR_NAME = 13, |
| 131 | BTRFS_SEND_A_XATTR_DATA = 14, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 132 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 133 | BTRFS_SEND_A_PATH = 15, |
| 134 | BTRFS_SEND_A_PATH_TO = 16, |
| 135 | BTRFS_SEND_A_PATH_LINK = 17, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 136 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 137 | BTRFS_SEND_A_FILE_OFFSET = 18, |
Omar Sandoval | b7c14f2 | 2022-03-17 10:25:39 -0700 | [diff] [blame] | 138 | /* |
| 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 Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 143 | BTRFS_SEND_A_DATA = 19, |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 144 | |
Omar Sandoval | 54cab6a | 2022-03-17 10:25:38 -0700 | [diff] [blame] | 145 | 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 Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 150 | |
Omar Sandoval | b7c14f2 | 2022-03-17 10:25:39 -0700 | [diff] [blame] | 151 | BTRFS_SEND_A_MAX_V1 = 24, |
| 152 | |
| 153 | /* Version 2 */ |
| 154 | BTRFS_SEND_A_FALLOCATE_MODE = 25, |
| 155 | |
David Sterba | 4824735 | 2022-05-18 18:02:55 +0200 | [diff] [blame] | 156 | /* |
| 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 Sandoval | b7c14f2 | 2022-03-17 10:25:39 -0700 | [diff] [blame] | 163 | |
| 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 Burkov | 3862201 | 2022-08-15 13:54:28 -0700 | [diff] [blame] | 175 | /* 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 Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 183 | }; |
Alexander Block | 31db9f7 | 2012-07-25 23:19:24 +0200 | [diff] [blame] | 184 | |
David Sterba | 24e7459 | 2022-01-31 18:49:41 +0100 | [diff] [blame] | 185 | long btrfs_ioctl_send(struct btrfs_inode *inode, const struct btrfs_ioctl_send_args *arg); |
David Sterba | 9888c34 | 2018-04-03 19:16:55 +0200 | [diff] [blame] | 186 | |
| 187 | #endif |