aboutsummaryrefslogtreecommitdiff
path: root/src/liblzma/lz/lz_encoder.c
diff options
context:
space:
mode:
authorLasse Collin <lasse.collin@tukaani.org>2014-07-25 21:15:07 +0300
committerLasse Collin <lasse.collin@tukaani.org>2014-07-25 21:15:07 +0300
commit5db75054e900fa06ef5ade5f2c21dffdd5d16141 (patch)
tree345cb89f729c6bb52eadf01cb8387cdc738dbfd3 /src/liblzma/lz/lz_encoder.c
parentliblzma: Add lzma_memcmplen() for fast memory comparison. (diff)
downloadxz-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.c13
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