/* * Copyright (C) 2007 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #pragma once #include #define MKID(a, b, c, d) ((a) | ((b) << 8) | ((c) << 16) | ((d) << 24)) #define ID_LSTAT_V1 MKID('S', 'T', 'A', 'T') #define ID_STAT_V2 MKID('S', 'T', 'A', '2') #define ID_LSTAT_V2 MKID('L', 'S', 'T', '2') #define ID_LIST_V1 MKID('L', 'I', 'S', 'T') #define ID_LIST_V2 MKID('L', 'I', 'S', '2') #define ID_DENT_V1 MKID('D', 'E', 'N', 'T') #define ID_DENT_V2 MKID('D', 'N', 'T', '2') #define ID_SEND_V1 MKID('S', 'E', 'N', 'D') #define ID_SEND_V2 MKID('S', 'N', 'D', '2') #define ID_RECV_V1 MKID('R', 'E', 'C', 'V') #define ID_RECV_V2 MKID('R', 'C', 'V', '2') #define ID_DONE MKID('D', 'O', 'N', 'E') #define ID_DATA MKID('D', 'A', 'T', 'A') #define ID_OKAY MKID('O', 'K', 'A', 'Y') #define ID_FAIL MKID('F', 'A', 'I', 'L') #define ID_QUIT MKID('Q', 'U', 'I', 'T') struct SyncRequest { uint32_t id; // ID_STAT, et cetera. uint32_t path_length; // <= 1024 // Followed by 'path_length' bytes of path (not NUL-terminated). } __attribute__((packed)); struct __attribute__((packed)) sync_stat_v1 { uint32_t id; uint32_t mode; uint32_t size; uint32_t mtime; }; struct __attribute__((packed)) sync_stat_v2 { uint32_t id; uint32_t error; uint64_t dev; uint64_t ino; uint32_t mode; uint32_t nlink; uint32_t uid; uint32_t gid; uint64_t size; int64_t atime; int64_t mtime; int64_t ctime; }; struct __attribute__((packed)) sync_dent_v1 { uint32_t id; uint32_t mode; uint32_t size; uint32_t mtime; uint32_t namelen; }; // followed by `namelen` bytes of the name. struct __attribute__((packed)) sync_dent_v2 { uint32_t id; uint32_t error; uint64_t dev; uint64_t ino; uint32_t mode; uint32_t nlink; uint32_t uid; uint32_t gid; uint64_t size; int64_t atime; int64_t mtime; int64_t ctime; uint32_t namelen; }; // followed by `namelen` bytes of the name. enum SyncFlag : uint32_t { kSyncFlagNone = 0, kSyncFlagBrotli = 1, kSyncFlagLZ4 = 2, kSyncFlagZstd = 4, kSyncFlagDryRun = 0x8000'0000U, }; enum class CompressionType { None, Any, Brotli, LZ4, Zstd, }; // send_v1 sent the path in a buffer, followed by a comma and the mode as a string. // send_v2 sends just the path in the first request, and then sends another syncmsg (with the // same ID!) with details. struct __attribute__((packed)) sync_send_v2 { uint32_t id; uint32_t mode; uint32_t flags; }; // Likewise, recv_v1 just sent the path without any accompanying data. struct __attribute__((packed)) sync_recv_v2 { uint32_t id; uint32_t flags; }; struct __attribute__((packed)) sync_data { uint32_t id; uint32_t size; }; // followed by `size` bytes of data. struct __attribute__((packed)) sync_status { uint32_t id; uint32_t msglen; }; // followed by `msglen` bytes of error message, if id == ID_FAIL. union syncmsg { sync_stat_v1 stat_v1; sync_stat_v2 stat_v2; sync_dent_v1 dent_v1; sync_dent_v2 dent_v2; sync_data data; sync_status status; sync_send_v2 send_v2_setup; sync_recv_v2 recv_v2_setup; }; #define SYNC_DATA_MAX (64 * 1024)