xref: /aosp_15_r20/system/update_engine/lz4diff/lz4diff_compress.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_COMPRESS_H_
18*5a923131SAndroid Build Coastguard Worker #define UPDATE_ENGINE_LZ4DIFF_LZ4DIFF_COMPRESS_H_
19*5a923131SAndroid Build Coastguard Worker 
20*5a923131SAndroid Build Coastguard Worker #include "lz4diff_format.h"
21*5a923131SAndroid Build Coastguard Worker #include <string_view>
22*5a923131SAndroid Build Coastguard Worker 
23*5a923131SAndroid Build Coastguard Worker namespace chromeos_update_engine {
24*5a923131SAndroid Build Coastguard Worker 
25*5a923131SAndroid Build Coastguard Worker using SinkFunc = std::function<size_t(const uint8_t*, size_t)>;
26*5a923131SAndroid Build Coastguard Worker 
27*5a923131SAndroid Build Coastguard Worker // |TryCompressBlob| and |TryDecompressBlob| are inverse function of each other.
28*5a923131SAndroid Build Coastguard Worker // One compresses data into fixed size output chunks, one decompresses fixed
29*5a923131SAndroid Build Coastguard Worker // size blocks.
30*5a923131SAndroid Build Coastguard Worker // The |TryCompressBlob| routine is supposed to mimic how EROFS compresses input
31*5a923131SAndroid Build Coastguard Worker // files when creating an EROFS image. After calling |TryCompressBlob|, LZ4DIFF
32*5a923131SAndroid Build Coastguard Worker // will compare the re-compressed blob and EROFS's ground truth blob, and
33*5a923131SAndroid Build Coastguard Worker // generate a BSDIFF patch between them if there's mismatch. Therefore, it is OK
34*5a923131SAndroid Build Coastguard Worker // that |TryCompressBlob| produces slightly different output than mkfs.erofs, so
35*5a923131SAndroid Build Coastguard Worker // as long as |TryCompressBlob| exhibits consistne bebavior across platforms.
36*5a923131SAndroid Build Coastguard Worker Blob TryCompressBlob(std::string_view blob,
37*5a923131SAndroid Build Coastguard Worker                      const std::vector<CompressedBlock>& block_info,
38*5a923131SAndroid Build Coastguard Worker                      const bool zero_padding_enabled,
39*5a923131SAndroid Build Coastguard Worker                      const CompressionAlgorithm compression_algo);
40*5a923131SAndroid Build Coastguard Worker bool TryCompressBlob(std::string_view blob,
41*5a923131SAndroid Build Coastguard Worker                      const std::vector<CompressedBlock>& block_info,
42*5a923131SAndroid Build Coastguard Worker                      const bool zero_padding_enabled,
43*5a923131SAndroid Build Coastguard Worker                      const CompressionAlgorithm compression_algo,
44*5a923131SAndroid Build Coastguard Worker                      const SinkFunc& sink);
45*5a923131SAndroid Build Coastguard Worker 
46*5a923131SAndroid Build Coastguard Worker Blob TryDecompressBlob(std::string_view blob,
47*5a923131SAndroid Build Coastguard Worker                        const std::vector<CompressedBlock>& block_info,
48*5a923131SAndroid Build Coastguard Worker                        const bool zero_padding_enabled);
49*5a923131SAndroid Build Coastguard Worker Blob TryDecompressBlob(const Blob& blob,
50*5a923131SAndroid Build Coastguard Worker                        const std::vector<CompressedBlock>& block_info,
51*5a923131SAndroid Build Coastguard Worker                        const bool zero_padding_enabled);
52*5a923131SAndroid Build Coastguard Worker 
53*5a923131SAndroid Build Coastguard Worker std::ostream& operator<<(std::ostream& out, const CompressedBlockInfo& info);
54*5a923131SAndroid Build Coastguard Worker 
55*5a923131SAndroid Build Coastguard Worker std::ostream& operator<<(std::ostream& out, const CompressedBlock& block);
56*5a923131SAndroid Build Coastguard Worker 
57*5a923131SAndroid Build Coastguard Worker }  // namespace chromeos_update_engine
58*5a923131SAndroid Build Coastguard Worker 
59*5a923131SAndroid Build Coastguard Worker #endif
60