[FFmpeg-devel] [PATCH] avcodec/speexdec: fix decoding regressions

shenleban tongying shenlebantongying at gmail.com
Fri Nov 8 01:59:36 EET 2024


fix ticket #11054 and #11078

* reduce false decoding errors
* fix wrong frame_size

Co-authored-by: Paul B Mahol <onemda at gmail.com>
Signed-off-by: shenleban tongying <shenlebantongying at gmail.com>
---
libavcodec/speexdec.c | 10 ++++++----
1 file changed, 6 insertions(+), 4 deletions(-)

diff --git a/libavcodec/speexdec.c b/libavcodec/speexdec.c
index d25823ef6e..d48bfca803 100644
--- a/libavcodec/speexdec.c
+++ b/libavcodec/speexdec.c
@@ -1425,7 +1425,8 @@ static int parse_speex_extradata(AVCodecContext *avctx,
    if (s->frame_size < NB_FRAME_SIZE << (s->mode > 0) ||
        s->frame_size >     INT32_MAX >> (s->mode > 0))
        return AVERROR_INVALIDDATA;
-    s->frame_size <<= (s->mode > 0);
+    s->frame_size <<= (s->mode > 1);
+    s->frame_size = FFMIN(640, s->frame_size);
    s->vbr = bytestream_get_le32(&buf);
    s->frames_per_packet = bytestream_get_le32(&buf);
    if (s->frames_per_packet <= 0 ||
@@ -1563,10 +1564,11 @@ static int speex_decode_frame(AVCodecContext *avctx, AVFrame *frame,
            return ret;
        if (avctx->ch_layout.nb_channels == 2)
            speex_decode_stereo(dst + i * s->frame_size, s->frame_size, &s->stereo);
-        if (get_bits_left(&s->gb) < 5 ||
-            show_bits(&s->gb, 5) == 15) {
-            frames_per_packet = i + 1;
+        if (get_bits_left(&s->gb) < 5)
            break;
+        if (show_bits(&s->gb, 5) == 15) {
+            frames_per_packet = i + 1;
+            skip_bits(&s->gb, 5);
        }
    }

-- 
2.47.0



More information about the ffmpeg-devel mailing list