[FFmpeg-cvslog] avcodec/speexdec: fix frame_size for mode == 2

James Almer git at videolan.org
Mon Feb 3 18:28:21 EET 2025


ffmpeg | branch: master | James Almer <jamrial at gmail.com> | Thu Jan 30 10:54:42 2025 -0300| [4a0e1cfc6f33d152e007849f6de7028d651de2af] | committer: James Almer

avcodec/speexdec: fix frame_size for mode == 2

Should match the non-extradata path now, and fix ticket #11078.

Signed-off-by: James Almer <jamrial at gmail.com>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=4a0e1cfc6f33d152e007849f6de7028d651de2af
---

 libavcodec/speexdec.c | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/libavcodec/speexdec.c b/libavcodec/speexdec.c
index d25823ef6e..b335e2fbe8 100644
--- a/libavcodec/speexdec.c
+++ b/libavcodec/speexdec.c
@@ -1422,10 +1422,10 @@ static int parse_speex_extradata(AVCodecContext *avctx,
         return AVERROR_INVALIDDATA;
     s->bitrate = bytestream_get_le32(&buf);
     s->frame_size = bytestream_get_le32(&buf);
-    if (s->frame_size < NB_FRAME_SIZE << (s->mode > 0) ||
-        s->frame_size >     INT32_MAX >> (s->mode > 0))
+    if (s->frame_size < NB_FRAME_SIZE << (s->mode > 1) ||
+        s->frame_size >     INT32_MAX >> (s->mode > 1))
         return AVERROR_INVALIDDATA;
-    s->frame_size <<= (s->mode > 0);
+    s->frame_size <<= (s->mode > 1);
     s->vbr = bytestream_get_le32(&buf);
     s->frames_per_packet = bytestream_get_le32(&buf);
     if (s->frames_per_packet <= 0 ||



More information about the ffmpeg-cvslog mailing list