Konrad Rzeszutek Wilk 16c0dbf4bc lzma: Make sure we don't dereference past array
The two dimensional array p->posSlotEncoder[4][64] is being dereferenced
using the GetLenToPosState() macro which checks if len is less than 5,
and if so subtracts 2 from it. If len = 0, that is 0 - 2 = 4294967294.
Obviously we don't want to dereference that far out so we check if the
position found is greater or equal kNumLenToPosStates (4) and bail out.

N.B.: Upstream LZMA 18.05 and later has this function completely rewritten
without any history.

Fixes: CID 51526

Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
2020-07-29 16:55:48 +02:00
..
2011-05-13 16:36:05 +02:00
2017-05-08 20:53:28 +02:00
2019-02-25 14:02:05 +01:00
2010-08-30 00:54:15 +02:00
2020-02-11 21:30:30 +01:00
2019-02-25 11:28:44 +01:00
2016-10-27 16:22:06 +02:00
2020-07-29 16:55:47 +02:00
2011-07-05 20:24:20 +02:00
2019-03-25 15:14:52 +01:00
2012-02-26 18:09:07 +01:00
2018-06-23 21:40:55 +02:00
2013-12-18 05:28:05 +01:00
2016-02-12 12:39:38 +01:00
2019-02-25 14:02:05 +01:00