From caf24dd70915cb95c94e18562674f4dec158dd8c Mon Sep 17 00:00:00 2001 From: des Date: Thu, 23 Mar 2006 14:02:36 +0000 Subject: Vendor import of ZLib 1.2.3. --- lib/libz/inffast.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'lib/libz/inffast.c') diff --git a/lib/libz/inffast.c b/lib/libz/inffast.c index 8c02a17..bbee92e 100644 --- a/lib/libz/inffast.c +++ b/lib/libz/inffast.c @@ -74,6 +74,9 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ unsigned char FAR *out; /* local strm->next_out */ unsigned char FAR *beg; /* inflate()'s initial strm->next_out */ unsigned char FAR *end; /* while out < end, enough space available */ +#ifdef INFLATE_STRICT + unsigned dmax; /* maximum distance from zlib header */ +#endif unsigned wsize; /* window size or zero if not using window */ unsigned whave; /* valid bytes in the window */ unsigned write; /* window write index */ @@ -98,6 +101,9 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ out = strm->next_out - OFF; beg = out - (start - strm->avail_out); end = out + (strm->avail_out - 257); +#ifdef INFLATE_STRICT + dmax = state->dmax; +#endif wsize = state->wsize; whave = state->whave; write = state->write; @@ -167,6 +173,13 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ } } dist += (unsigned)hold & ((1U << op) - 1); +#ifdef INFLATE_STRICT + if (dist > dmax) { + strm->msg = (char *)"invalid distance too far back"; + state->mode = BAD; + break; + } +#endif hold >>= op; bits -= op; Tracevv((stderr, "inflate: distance %u\n", dist)); -- cgit v1.1