xref: /aosp_15_r20/system/update_engine/lz4diff/lz4diff_format.h (revision 5a9231315b4521097b8dc3750bc806fcafe0c72f)
1*5a923131SAndroid Build Coastguard Worker //
2*5a923131SAndroid Build Coastguard Worker // Copyright (C) 2021 The Android Open Source Project
3*5a923131SAndroid Build Coastguard Worker //
4*5a923131SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
5*5a923131SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
6*5a923131SAndroid Build Coastguard Worker // You may obtain a copy of the License at
7*5a923131SAndroid Build Coastguard Worker //
8*5a923131SAndroid Build Coastguard Worker //      http://www.apache.org/licenses/LICENSE-2.0
9*5a923131SAndroid Build Coastguard Worker //
10*5a923131SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
11*5a923131SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
12*5a923131SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*5a923131SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
14*5a923131SAndroid Build Coastguard Worker // limitations under the License.
15*5a923131SAndroid Build Coastguard Worker //
16*5a923131SAndroid Build Coastguard Worker 
17*5a923131SAndroid Build Coastguard Worker #ifndef UPDATE_ENGINE_LZ4DIFF_LZ4DIFF_FORMAT_H_
18*5a923131SAndroid Build Coastguard Worker #define UPDATE_ENGINE_LZ4DIFF_LZ4DIFF_FORMAT_H_
19*5a923131SAndroid Build Coastguard Worker 
20*5a923131SAndroid Build Coastguard Worker #include <string_view>
21*5a923131SAndroid Build Coastguard Worker #include <vector>
22*5a923131SAndroid Build Coastguard Worker 
23*5a923131SAndroid Build Coastguard Worker #include <lz4diff/lz4diff.pb.h>
24*5a923131SAndroid Build Coastguard Worker 
25*5a923131SAndroid Build Coastguard Worker namespace chromeos_update_engine {
26*5a923131SAndroid Build Coastguard Worker 
27*5a923131SAndroid Build Coastguard Worker using Blob = std::vector<unsigned char>;
28*5a923131SAndroid Build Coastguard Worker 
29*5a923131SAndroid Build Coastguard Worker // Format of LZ4diff patch:
30*5a923131SAndroid Build Coastguard Worker // struct lz4diff_header {
31*5a923131SAndroid Build Coastguard Worker //     char magic[8] = kLz4diffMagic;
32*5a923131SAndroid Build Coastguard Worker //     uint32_t version;
33*5a923131SAndroid Build Coastguard Worker //     uint32_t pb_header_size;         // size of protobuf message
34*5a923131SAndroid Build Coastguard Worker //     char pf_header[pb_header_size];
35*5a923131SAndroid Build Coastguard Worker // }
36*5a923131SAndroid Build Coastguard Worker 
37*5a923131SAndroid Build Coastguard Worker constexpr std::string_view kLz4diffMagic = "LZ4DIFF";
38*5a923131SAndroid Build Coastguard Worker 
39*5a923131SAndroid Build Coastguard Worker // 8 bytes magic + 4 bytes version + 4 bytes pb_header_size
40*5a923131SAndroid Build Coastguard Worker constexpr size_t kLz4diffHeaderSize = 8 + 4 + 4;
41*5a923131SAndroid Build Coastguard Worker 
42*5a923131SAndroid Build Coastguard Worker constexpr uint32_t kLz4diffVersion = 1;
43*5a923131SAndroid Build Coastguard Worker 
44*5a923131SAndroid Build Coastguard Worker struct CompressedBlock {
CompressedBlockCompressedBlock45*5a923131SAndroid Build Coastguard Worker   constexpr CompressedBlock() : CompressedBlock(0, 0, 0) {}
CompressedBlockCompressedBlock46*5a923131SAndroid Build Coastguard Worker   constexpr CompressedBlock(uint64_t offset,
47*5a923131SAndroid Build Coastguard Worker                             uint64_t length,
48*5a923131SAndroid Build Coastguard Worker                             uint64_t uncompressed_length)
49*5a923131SAndroid Build Coastguard Worker       : uncompressed_offset(offset),
50*5a923131SAndroid Build Coastguard Worker         compressed_length(length),
51*5a923131SAndroid Build Coastguard Worker         uncompressed_length(uncompressed_length) {}
IsCompressedCompressedBlock52*5a923131SAndroid Build Coastguard Worker   constexpr bool IsCompressed() const noexcept {
53*5a923131SAndroid Build Coastguard Worker     return compressed_length < uncompressed_length;
54*5a923131SAndroid Build Coastguard Worker   }
55*5a923131SAndroid Build Coastguard Worker   uint64_t uncompressed_offset;
56*5a923131SAndroid Build Coastguard Worker   uint64_t compressed_length;
57*5a923131SAndroid Build Coastguard Worker   uint64_t uncompressed_length;
58*5a923131SAndroid Build Coastguard Worker };
59*5a923131SAndroid Build Coastguard Worker 
60*5a923131SAndroid Build Coastguard Worker struct CompressedFile {
61*5a923131SAndroid Build Coastguard Worker   // Extents in this array should be in range [0, file_size]. It represents
62*5a923131SAndroid Build Coastguard Worker   // which bytes inside this file are compressed. Useful for compressed file
63*5a923131SAndroid Build Coastguard Worker   // systems like EROFS.
64*5a923131SAndroid Build Coastguard Worker   std::vector<CompressedBlock> blocks;
65*5a923131SAndroid Build Coastguard Worker   CompressionAlgorithm algo;
66*5a923131SAndroid Build Coastguard Worker   // Whether the EROFS zero padding feature is enabled
67*5a923131SAndroid Build Coastguard Worker   bool zero_padding_enabled{};
68*5a923131SAndroid Build Coastguard Worker };
69*5a923131SAndroid Build Coastguard Worker 
70*5a923131SAndroid Build Coastguard Worker }  // namespace chromeos_update_engine
71*5a923131SAndroid Build Coastguard Worker 
72*5a923131SAndroid Build Coastguard Worker #endif
73