1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Fix a benign buffer overrun in sshzlib.c.

The structure field 'lengths' in 'struct zlib_decompress_ctx' was the
right length for the amount of data you might _sensibly_ want to put
in it, but two bytes shorter than the amount that the compressed block
header allows someone to _physically_ try to put into it. Now it has
the full maximum length.

The previous overrun could only reach two bytes beyond the end of the
array, and in every target architecture I know of, those two bytes
would have been structure padding, so it wasn't causing any real trouble.
This commit is contained in:
Simon Tatham 2019-04-28 09:59:28 +01:00
parent eecefcb23c
commit 77aff29e18

View File

@ -850,7 +850,51 @@ struct zlib_decompress_ctx {
lenrep; lenrep;
int uncomplen; int uncomplen;
unsigned char lenlen[19]; unsigned char lenlen[19];
unsigned char lengths[286 + 32];
/*
* Array that accumulates the code lengths sent in the header of a
* dynamic-Huffman-tree block.
*
* There are 286 actual symbols in the literal/length alphabet
* (256 literals plus 20 length categories), and 30 symbols in the
* distance alphabet. However, the block header transmits the
* number of code lengths for the former alphabet as a 5-bit value
* HLIT to be added to 257, and the latter as a 5-bit value HDIST
* to be added to 1. This means that the number of _code lengths_
* can go as high as 288 for the symbol alphabet and 32 for the
* distance alphabet - each of those values being 2 more than the
* maximum number of actual symbols.
*
* It's tempting to rule that sending out-of-range HLIT or HDIST
* is therefore just illegal, and to fault it when we initially
* receive that header. But instead I've chosen to permit the
* Huffman-code definition to include code length entries for
* those unused symbols; if a header of that form is transmitted,
* then the effect will be that in the main body of the block,
* some bit sequence(s) will generate an illegal symbol number,
* and _that_ will be faulted as a decoding error.
*
* Rationale: this can already happen! The standard Huffman code
* used in a _static_ block for the literal/length alphabet is
* defined in such a way that it includes codes for symbols 287
* and 288, which are then never actually sent in the body of the
* block. And I think that if the standard static tree definition
* is willing to include Huffman codes that don't correspond to a
* symbol, then it's an excessive restriction on dynamic tables
* not to permit them to do the same. In particular, it would be
* strange for a dynamic block not to be able to exactly mimic
* either or both of the Huffman codes used by a static block for
* the corresponding alphabet.
*
* So we place no constraint on HLIT or HDIST during code
* construction, and we make this array large enough to include
* the maximum number of code lengths that can possibly arise as a
* result. It's only trying to _use_ the junk Huffman codes after
* table construction is completed that will provoke a decode
* error.
*/
unsigned char lengths[288 + 32];
unsigned long bits; unsigned long bits;
int nbits; int nbits;
unsigned char window[WINSIZE]; unsigned char window[WINSIZE];