145 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
| /*
 | |
|  * 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
 | |
| 
 | |
| #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)
 |