diff options
author | Nick Mathewson <nickm@torproject.org> | 2017-05-01 14:22:49 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-05-01 14:22:49 -0400 |
commit | 4837421d7cb6bcc52d5ffd09527ac786759b3b0a (patch) | |
tree | 0cadcd1535e1a46d75f9fd11f07e06fed2e9aeea | |
parent | d6dd05f6d8171191cfc2ea331ef6e1a89318decf (diff) | |
parent | 0672b33f1e0ca160563841aaf7af87adbacd95d3 (diff) | |
download | tor-4837421d7cb6bcc52d5ffd09527ac786759b3b0a.tar.gz tor-4837421d7cb6bcc52d5ffd09527ac786759b3b0a.zip |
Merge remote-tracking branch 'ahf/bugs/21665'
-rw-r--r-- | src/common/compress.c | 4 | ||||
-rw-r--r-- | src/common/compress_lzma.c | 13 |
2 files changed, 9 insertions, 8 deletions
diff --git a/src/common/compress.c b/src/common/compress.c index 8502dee25c..738df9f185 100644 --- a/src/common/compress.c +++ b/src/common/compress.c @@ -255,8 +255,8 @@ detect_compression_method(const char *in, size_t in_len) } else if (in_len > 2 && (in[0] & 0x0f) == 8 && (ntohs(get_uint16(in)) % 31) == 0) { return ZLIB_METHOD; - } else if (in_len > 3 && - fast_memeq(in, "\x5d\x00\x00\x00", 4)) { + } else if (in_len > 2 && + fast_memeq(in, "\x5d\x00\x00", 3)) { return LZMA_METHOD; } else if (in_len > 3 && fast_memeq(in, "\x28\xb5\x2f\xfd", 4)) { diff --git a/src/common/compress_lzma.c b/src/common/compress_lzma.c index b721bae8aa..b5393a6ba6 100644 --- a/src/common/compress_lzma.c +++ b/src/common/compress_lzma.c @@ -22,6 +22,9 @@ #include <lzma.h> #endif +/** The maximum amount of memory we allow the LZMA decoder to use, in bytes. */ +#define MEMORY_LIMIT (16 * 1024 * 1024) + /** Total number of bytes allocated for LZMA state. */ static atomic_counter_t total_lzma_allocation; @@ -33,9 +36,9 @@ memory_level(compression_level_t level) switch (level) { default: case BEST_COMPRESSION: - case HIGH_COMPRESSION: return 9; - case MEDIUM_COMPRESSION: return 6; - case LOW_COMPRESSION: return 3; + case HIGH_COMPRESSION: return 6; + case MEDIUM_COMPRESSION: return 4; + case LOW_COMPRESSION: return 2; } } @@ -191,9 +194,7 @@ tor_lzma_compress_new(int compress, goto err; } } else { - // FIXME(ahf): This should be something more sensible than - // UINT64_MAX: See #21665. - retval = lzma_alone_decoder(&result->stream, UINT64_MAX); + retval = lzma_alone_decoder(&result->stream, MEMORY_LIMIT); if (retval != LZMA_OK) { log_warn(LD_GENERAL, "Error from LZMA decoder: %s (%u).", |