diff options
author | Lasse Collin <lasse.collin@tukaani.org> | 2022-07-13 22:24:07 +0300 |
---|---|---|
committer | Lasse Collin <lasse.collin@tukaani.org> | 2022-07-13 22:24:07 +0300 |
commit | 9595a3119b9faf0ce01375329cad8bbf85c35ea2 (patch) | |
tree | ac7d22c82eae07defb892a8230ffa67fb2c44f27 /src/liblzma/common | |
parent | xz: Document the special memlimit case of 2000 MiB on MIPS32. (diff) | |
download | xz-9595a3119b9faf0ce01375329cad8bbf85c35ea2.tar.xz |
liblzma: Add optional autodetection of LZMA end marker.
Turns out that this is needed for .lzma files as the spec in
LZMA SDK says that end marker may be present even if the size
is stored in the header. Such files are rare but exist in the
real world. The code in liblzma is so old that the spec didn't
exist in LZMA SDK back then and I had understood that such
files weren't possible (the lzma tool in LZMA SDK didn't
create such files).
This modifies the internal API so that LZMA decoder can be told
if EOPM is allowed even when the uncompressed size is known.
It's allowed with .lzma and not with other uses.
Thanks to Karl Beldan for reporting the problem.
Diffstat (limited to 'src/liblzma/common')
-rw-r--r-- | src/liblzma/common/alone_decoder.c | 2 | ||||
-rw-r--r-- | src/liblzma/common/microlzma_decoder.c | 2 |
2 files changed, 2 insertions, 2 deletions
diff --git a/src/liblzma/common/alone_decoder.c b/src/liblzma/common/alone_decoder.c index 239b230e..a3ea20a2 100644 --- a/src/liblzma/common/alone_decoder.c +++ b/src/liblzma/common/alone_decoder.c @@ -146,7 +146,7 @@ alone_decode(void *coder_ptr, const lzma_allocator *allocator, // Use a hack to set the uncompressed size. lzma_lz_decoder_uncompressed(coder->next.coder, - coder->uncompressed_size); + coder->uncompressed_size, true); coder->sequence = SEQ_CODE; break; diff --git a/src/liblzma/common/microlzma_decoder.c b/src/liblzma/common/microlzma_decoder.c index 37907109..d6337816 100644 --- a/src/liblzma/common/microlzma_decoder.c +++ b/src/liblzma/common/microlzma_decoder.c @@ -108,7 +108,7 @@ microlzma_decode(void *coder_ptr, const lzma_allocator *allocator, // Use a hack to set the uncompressed size. if (coder->uncomp_size_is_exact) lzma_lz_decoder_uncompressed(coder->lzma.coder, - coder->uncomp_size); + coder->uncomp_size, false); // Pass one dummy 0x00 byte to the LZMA decoder since that // is what it expects the first byte to be. |