diff options
author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2019-05-21 00:52:45 +0200 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2019-05-21 23:32:16 +0200 |
commit | f5ee6093d4bfb9026c61e29e5182c1227158a33d (patch) | |
tree | 42fd800f103c59019b17c123268d28f91784da16 /lib/comp/lz4.c | |
parent | 2dc348d592c7b8bc46abab1a0a3c64fa04d13a76 (diff) |
Add options for lz4 compressor
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'lib/comp/lz4.c')
-rw-r--r-- | lib/comp/lz4.c | 35 |
1 files changed, 31 insertions, 4 deletions
diff --git a/lib/comp/lz4.c b/lib/comp/lz4.c index 63ed528..e0bba9c 100644 --- a/lib/comp/lz4.c +++ b/lib/comp/lz4.c @@ -11,6 +11,7 @@ typedef struct { compressor_t base; + bool high_compression; } lz4_compressor_t; typedef struct { @@ -19,14 +20,15 @@ typedef struct { } lz4_options; #define LZ4LEGACY 1 +#define LZ4_FLAG_HC 0x01 static int lz4_write_options(compressor_t *base, int fd) { + lz4_compressor_t *lz4 = (lz4_compressor_t *)base; lz4_options opt = { .version = htole32(LZ4LEGACY), - .flags = htole32(0), + .flags = htole32(lz4->high_compression ? LZ4_FLAG_HC : 0), }; - (void)base; return generic_write_options(fd, &opt, sizeof(opt)); } @@ -53,10 +55,16 @@ static int lz4_read_options(compressor_t *base, int fd) static ssize_t lz4_comp_block(compressor_t *base, const uint8_t *in, size_t size, uint8_t *out, size_t outsize) { + lz4_compressor_t *lz4 = (lz4_compressor_t *)base; int ret; - (void)base; - ret = LZ4_compress_default((void *)in, (void *)out, size, outsize); + if (lz4->high_compression) { + ret = LZ4_compress_HC((void *)in, (void *)out, + size, outsize, LZ4HC_CLEVEL_MAX); + } else { + ret = LZ4_compress_default((void *)in, (void *)out, + size, outsize); + } if (ret < 0) { fputs("internal error in lz4 compressor\n", stderr); @@ -99,6 +107,19 @@ compressor_t *create_lz4_compressor(bool compress, size_t block_size, return NULL; } + lz4->high_compression = false; + + if (options != NULL) { + if (strcmp(options, "hc") == 0) { + lz4->high_compression = true; + } else { + fputs("Unsupported extra options for lz4 " + "compressor.\n", stderr); + free(lz4); + return NULL; + } + } + base->destroy = lz4_destroy; base->do_block = compress ? lz4_comp_block : lz4_uncomp_block; base->write_options = lz4_write_options; @@ -108,4 +129,10 @@ compressor_t *create_lz4_compressor(bool compress, size_t block_size, void compressor_lz4_print_help(void) { + fputs("Available options for lz4 compressor:\n" + "\n" + " hc If present, use slower but better compressing\n" + " variant of lz4.\n" + "\n", + stdout); } |