commit 00881f1886a18a7d203778e342e80037c32257b5
parent c9dceca281a0c6107dc73073c091c263adbdcb84
Author: David Goulet <dgoulet@torproject.org>
Date: Tue, 15 Aug 2023 12:39:33 -0400
Merge branch 'maint-0.4.7'
Diffstat:
2 files changed, 13 insertions(+), 7 deletions(-)
diff --git a/changes/ticket40739 b/changes/ticket40739
@@ -0,0 +1,6 @@
+ o Minor bugfixes (compression):
+ - Right after compression/decompression work is done, check for errors.
+ Before this, we would consider compression bomb before that and then
+ looking for errors leading to false positive on that log warning. Fixes
+ bug 40739; bugfix on 0.3.5.1-alpha. Patch by "cypherpunks".
+
diff --git a/src/lib/compress/compress_zstd.c b/src/lib/compress/compress_zstd.c
@@ -368,6 +368,13 @@ tor_zstd_compress_process(tor_zstd_compress_state_t *state,
&output, &input);
}
+ if (ZSTD_isError(retval)) {
+ log_warn(LD_GENERAL, "Zstandard %s didn't finish: %s.",
+ state->compress ? "compression" : "decompression",
+ ZSTD_getErrorName(retval));
+ return TOR_COMPRESS_ERROR;
+ }
+
state->input_so_far += input.pos;
state->output_so_far += output.pos;
@@ -383,13 +390,6 @@ tor_zstd_compress_process(tor_zstd_compress_state_t *state,
return TOR_COMPRESS_ERROR;
}
- if (ZSTD_isError(retval)) {
- log_warn(LD_GENERAL, "Zstandard %s didn't finish: %s.",
- state->compress ? "compression" : "decompression",
- ZSTD_getErrorName(retval));
- return TOR_COMPRESS_ERROR;
- }
-
if (state->compress && !state->have_called_end) {
retval = ZSTD_flushStream(state->u.compress_stream, &output);