opus_silk: fix typo causing overflow in silk_stabilize_lsf

Due to this typo max_center can be too large, causing nlsf to be set to
too large values, which in turn can cause nlsf[i - 1] + min_delta[i] to
overflow to a negative value, which is not allowed for nlsf and can
cause an out of bounds read in silk_lsf2lpc.

Reviewed-by: Michael Niedermayer <michael@niedermayer.cc>
Signed-off-by: Andreas Cadhalpun <Andreas.Cadhalpun@googlemail.com>
This commit is contained in:
Andreas Cadhalpun
2015-12-15 22:00:31 +01:00
parent 91c2a33d01
commit f61d44b74a

View File

@@ -824,7 +824,7 @@ static inline void silk_stabilize_lsf(int16_t nlsf[16], int order, const uint16_
/* upper extent */ /* upper extent */
for (i = order; i > k; i--) for (i = order; i > k; i--)
max_center -= min_delta[k]; max_center -= min_delta[i];
max_center -= min_delta[k] >> 1; max_center -= min_delta[k] >> 1;
/* move apart */ /* move apart */