diff options
author | Daniel Friesel <derf@finalrewind.org> | 2021-01-20 21:13:24 +0100 |
---|---|---|
committer | Daniel Friesel <derf@finalrewind.org> | 2021-01-20 21:13:24 +0100 |
commit | 252524c281387d9c661b8e5c544228b434364258 (patch) | |
tree | d68578423b90754327b58a7330681803cb1c4642 | |
parent | 1a8998393fea87e1ba8f672f0f1fbd540448e54f (diff) |
udeflate: add support for uncompressed blocks
-rw-r--r-- | include/lib/udeflate.h | 1 | ||||
-rw-r--r-- | src/lib/udeflate.cc | 33 |
2 files changed, 31 insertions, 3 deletions
diff --git a/include/lib/udeflate.h b/include/lib/udeflate.h index 5e07422..8926cfa 100644 --- a/include/lib/udeflate.h +++ b/include/lib/udeflate.h @@ -13,6 +13,7 @@ #define UDEFLATE_ERR_CHECKSUM (-5) #define UDEFLATE_ERR_OUTPUT_LENGTH (-6) #define UDEFLATE_ERR_FCHECK (-7) +#define UDEFLATE_ERR_NLEN (-8) int8_t udeflate(unsigned char *input_buf, uint16_t input_len, unsigned char *output_buf, uint16_t output_len); diff --git a/src/lib/udeflate.cc b/src/lib/udeflate.cc index 5cd7973..51be964 100644 --- a/src/lib/udeflate.cc +++ b/src/lib/udeflate.cc @@ -279,6 +279,29 @@ static int8_t udeflate_huffman(uint8_t * ll_lengths, uint16_t ll_size, } } +static int8_t udeflate_uncompressed() +{ + udeflate_input_now++; + uint16_t len = + ((uint16_t) udeflate_input_now[1] << 8) + udeflate_input_now[0]; + uint16_t nlen = + ((uint16_t) udeflate_input_now[3] << 8) + udeflate_input_now[2]; + if (len & nlen) { + return UDEFLATE_ERR_NLEN; + } + udeflate_input_now += 4; + if (udeflate_input_now + len > udeflate_input_end) { + return UDEFLATE_ERR_INPUT_LENGTH; + } + if (udeflate_output_now + len > udeflate_output_end) { + return UDEFLATE_ERR_OUTPUT_LENGTH; + } + for (uint16_t i = 0; i < len; i++) { + *(udeflate_output_now++) = *(udeflate_input_now++); + } + return 0; +} + static int8_t udeflate_static_huffman() { uint16_t i; @@ -389,6 +412,9 @@ int8_t udeflate(unsigned char *input_buf, uint16_t input_len, udeflate_output_now = output_buf; udeflate_output_end = output_buf + output_len; + if (block_type == 0) { + return udeflate_uncompressed(); + } if (block_type == 1) { return udeflate_static_huffman(); } @@ -406,12 +432,13 @@ int8_t udeflate_zlib(unsigned char *input_buf, uint16_t input_len, return UDEFLATE_ERR_INPUT_LENGTH; } uint8_t zlib_method = input_buf[0] & 0x0f; - uint16_t zlib_window_size = 1 << (8 + ((input_buf[0] & 0xf0) >> 4)); uint8_t zlib_flags = input_buf[1]; #ifdef UDEFLATE_DEBUG kout << "zlib_method=" << zlib_method << endl; - kout << "zlib_window_size=" << zlib_window_size << endl; + kout << "zlib_window_size=" << ((uint16_t) 1 << + (8 + + ((input_buf[0] & 0xf0) >> 4))) << endl; #endif if (zlib_method != 8) { @@ -422,7 +449,7 @@ int8_t udeflate_zlib(unsigned char *input_buf, uint16_t input_len, return UDEFLATE_ERR_FDICT; } - if ((((uint16_t)input_buf[0] << 8) | input_buf[1]) % 31) { + if ((((uint16_t) input_buf[0] << 8) | input_buf[1]) % 31) { return UDEFLATE_ERR_FCHECK; } |