ref: ee44943c9552ae27b7f59d22c51655e2fe2918cd
parent: d0e7a7af0c926d32c1c6f11c83fbc383dac721e6
author: Jean-Marc Valin <jmvalin@amazon.com>
date: Wed Dec 21 12:40:25 EST 2022
Making sure we don't bust the DRED buffer
--- a/silk/dred_encoder.c
+++ b/silk/dred_encoder.c
@@ -92,6 +92,9 @@
for (i = 0; i < IMIN(2*max_chunks, enc->latents_buffer_fill-1); i += 2)
{
+ ec_enc ec_bak;
+ ec_bak = ec_encoder;
+
q_level = (int) floor(0.5f + DRED_ENC_Q0 + 1.f * (DRED_ENC_Q1 - DRED_ENC_Q0) * i / (DRED_NUM_REDUNDANCY_FRAMES - 2));
offset = q_level * DRED_LATENT_DIM;
@@ -103,6 +106,10 @@
r + offset,
p0 + offset
);
+ if (ec_tell(&ec_encoder) > 8*max_bytes) {
+ ec_encoder = ec_bak;
+ break;
+ }
}
ec_buffer_fill = (ec_tell(&ec_encoder)+7)/8;
--
⑨