summaryrefslogtreecommitdiff
path: root/compress.c
diff options
context:
space:
mode:
authormouring <mouring>2001-04-05 23:20:46 +0000
committermouring <mouring>2001-04-05 23:20:46 +0000
commitae2f5c715236b83cf24f0a48877153f7ac128eb3 (patch)
tree635fe1ea68dc3aa2a91522e84c68a0b59abcdc99 /compress.c
parent5fda734b3a14edd4819f1411218706554b41a671 (diff)
downloadopenssh-ae2f5c715236b83cf24f0a48877153f7ac128eb3.tar.gz
- markus@cvs.openbsd.org 2001/04/05 10:39:03
[compress.c compress.h packet.c] reset compress state per direction when rekeying.
Diffstat (limited to 'compress.c')
-rw-r--r--compress.c24
1 files changed, 19 insertions, 5 deletions
diff --git a/compress.c b/compress.c
index e8539baf..3e41b3d8 100644
--- a/compress.c
+++ b/compress.c
@@ -12,7 +12,7 @@
*/
#include "includes.h"
-RCSID("$OpenBSD: compress.c,v 1.13 2001/02/08 19:30:51 itojun Exp $");
+RCSID("$OpenBSD: compress.c,v 1.14 2001/04/05 10:39:01 markus Exp $");
#include "log.h"
#include "buffer.h"
@@ -21,6 +21,8 @@ RCSID("$OpenBSD: compress.c,v 1.13 2001/02/08 19:30:51 itojun Exp $");
static z_stream incoming_stream;
static z_stream outgoing_stream;
+static int compress_init_send_called = 0;
+static int compress_init_recv_called = 0;
/*
* Initializes compression; level is compression level from 1 to 9
@@ -28,14 +30,24 @@ static z_stream outgoing_stream;
*/
void
-buffer_compress_init(int level)
+buffer_compress_init_send(int level)
{
+ if (compress_init_send_called == 1)
+ deflateEnd(&incoming_stream);
+ compress_init_send_called = 1;
debug("Enabling compression at level %d.", level);
if (level < 1 || level > 9)
fatal("Bad compression level %d.", level);
- inflateInit(&incoming_stream);
deflateInit(&outgoing_stream, level);
}
+void
+buffer_compress_init_recv(void)
+{
+ if (compress_init_recv_called == 1)
+ inflateEnd(&incoming_stream);
+ compress_init_recv_called = 1;
+ inflateInit(&incoming_stream);
+}
/* Frees any data structures allocated for compression. */
@@ -50,8 +62,10 @@ buffer_compress_uninit(void)
incoming_stream.total_out, incoming_stream.total_in,
incoming_stream.total_out == 0 ? 0.0 :
(double) incoming_stream.total_in / incoming_stream.total_out);
- inflateEnd(&incoming_stream);
- deflateEnd(&outgoing_stream);
+ if (compress_init_recv_called == 1)
+ inflateEnd(&incoming_stream);
+ if (compress_init_send_called == 1)
+ deflateEnd(&outgoing_stream);
}
/*