diff options
author | Lasse Collin <lasse.collin@tukaani.org> | 2014-07-25 21:15:07 +0300 |
---|---|---|
committer | Lasse Collin <lasse.collin@tukaani.org> | 2014-07-25 21:15:07 +0300 |
commit | 5db75054e900fa06ef5ade5f2c21dffdd5d16141 (patch) | |
tree | 345cb89f729c6bb52eadf01cb8387cdc738dbfd3 /src/liblzma/lz/lz_encoder.c | |
parent | liblzma: Add lzma_memcmplen() for fast memory comparison. (diff) | |
download | xz-5db75054e900fa06ef5ade5f2c21dffdd5d16141.tar.xz |
liblzma: Use lzma_memcmplen() in the match finders.
This doesn't change the match finder output.
Diffstat (limited to '')
-rw-r--r-- | src/liblzma/lz/lz_encoder.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/src/liblzma/lz/lz_encoder.c b/src/liblzma/lz/lz_encoder.c index 76954e4d..2033844f 100644 --- a/src/liblzma/lz/lz_encoder.c +++ b/src/liblzma/lz/lz_encoder.c @@ -20,6 +20,8 @@ # include "lz_encoder_hash_table.h" #endif +#include "memcmplen.h" + struct lzma_coder_s { /// LZ-based encoder e.g. LZMA @@ -363,9 +365,18 @@ lz_encoder_init(lzma_mf *mf, const lzma_allocator *allocator, { // Allocate the history buffer. if (mf->buffer == NULL) { - mf->buffer = lzma_alloc(mf->size, allocator); + // lzma_memcmplen() is used for the dictionary buffer + // so we need to allocate a few extra bytes to prevent + // it from reading past the end of the buffer. + mf->buffer = lzma_alloc(mf->size + LZMA_MEMCMPLEN_EXTRA, + allocator); if (mf->buffer == NULL) return true; + + // Keep Valgrind happy with lzma_memcmplen() and initialize + // the extra bytes whose value may get read but which will + // effectively get ignored. + memzero(mf->buffer + mf->size, LZMA_MEMCMPLEN_EXTRA); } // Use cyclic_size as initial mf->offset. This allows |