| 
									
										
										
										
											2022-04-23 04:59:50 -04:00
										 |  |  | // SPDX-FileCopyrightText: Copyright 2019 yuzu Emulator Project
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: GPL-2.0-or-later
 | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-15 13:00:04 -04:00
										 |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-24 05:28:45 -04:00
										 |  |  | #include <span>
 | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  | #include <vector>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Common::Compression { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Compresses a source memory region with LZ4 and returns the compressed data in a vector. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-08-15 05:25:28 -04:00
										 |  |  |  * @param source      The uncompressed source memory region. | 
					
						
							|  |  |  |  * @param source_size The size of the uncompressed source memory region. | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @return the compressed data. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-08-15 05:25:28 -04:00
										 |  |  | [[nodiscard]] std::vector<u8> CompressDataLZ4(const u8* source, std::size_t source_size); | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Utilizes the LZ4 subalgorithm LZ4HC with the specified compression level. Higher compression | 
					
						
							|  |  |  |  * levels result in a smaller compressed size, but require more CPU time for compression. The | 
					
						
							|  |  |  |  * compression level has almost no impact on decompression speed. Data compressed with LZ4HC can | 
					
						
							|  |  |  |  * also be decompressed with the default LZ4 decompression. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-08-15 05:25:28 -04:00
										 |  |  |  * @param source            The uncompressed source memory region. | 
					
						
							|  |  |  |  * @param source_size       The size of the uncompressed source memory region. | 
					
						
							|  |  |  |  * @param compression_level The used compression level. Should be between 3 and 12. | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @return the compressed data. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-08-15 05:25:28 -04:00
										 |  |  | [[nodiscard]] std::vector<u8> CompressDataLZ4HC(const u8* source, std::size_t source_size, | 
					
						
							|  |  |  |                                                 s32 compression_level); | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Utilizes the LZ4 subalgorithm LZ4HC with the highest possible compression level. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-08-15 05:25:28 -04:00
										 |  |  |  * @param source      The uncompressed source memory region. | 
					
						
							|  |  |  |  * @param source_size The size of the uncompressed source memory region | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @return the compressed data. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-08-15 05:25:28 -04:00
										 |  |  | [[nodiscard]] std::vector<u8> CompressDataLZ4HCMax(const u8* source, std::size_t source_size); | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Decompresses a source memory region with LZ4 and returns the uncompressed data in a vector. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param compressed the compressed source memory region. | 
					
						
							|  |  |  |  * @param uncompressed_size the size in bytes of the uncompressed data. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return the decompressed data. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2021-05-24 05:28:45 -04:00
										 |  |  | [[nodiscard]] std::vector<u8> DecompressDataLZ4(std::span<const u8> compressed, | 
					
						
							| 
									
										
										
										
											2020-08-14 09:38:45 -04:00
										 |  |  |                                                 std::size_t uncompressed_size); | 
					
						
							| 
									
										
										
										
											2019-02-08 06:45:50 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-24 05:28:45 -04:00
										 |  |  | } // namespace Common::Compression
 |