On 7/21/2021 1:08 AM, James Almer wrote:
In some extrme cases, like with adpcm_ms samples with an extremely high channel
count, get_audio_frame_duration() may return a negative frame duration value.
Don't propagate it, and instead return 0, signaling that a duration could not
be determined.

Fixes ticket #9312

Signed-off-by: James Almer <jamr...@gmail.com>
---
  libavcodec/utils.c | 6 ++++--
  1 file changed, 4 insertions(+), 2 deletions(-)

diff --git a/libavcodec/utils.c b/libavcodec/utils.c
index 88e88bc958..e0d5b2f536 100644
--- a/libavcodec/utils.c
+++ b/libavcodec/utils.c
@@ -810,20 +810,22 @@ static int get_audio_frame_duration(enum AVCodecID id, 
int sr, int ch, int ba,
int av_get_audio_frame_duration(AVCodecContext *avctx, int frame_bytes)
  {
-    return get_audio_frame_duration(avctx->codec_id, avctx->sample_rate,
+    int duration = get_audio_frame_duration(avctx->codec_id, 
avctx->sample_rate,
                                      avctx->channels, avctx->block_align,
                                      avctx->codec_tag, 
avctx->bits_per_coded_sample,
                                      avctx->bit_rate, avctx->extradata, 
avctx->frame_size,
                                      frame_bytes);
+    return FFMAX(0, duration);
  }
int av_get_audio_frame_duration2(AVCodecParameters *par, int frame_bytes)
  {
-    return get_audio_frame_duration(par->codec_id, par->sample_rate,
+    int duration = get_audio_frame_duration(par->codec_id, par->sample_rate,
                                      par->channels, par->block_align,
                                      par->codec_tag, 
par->bits_per_coded_sample,
                                      par->bit_rate, par->extradata, 
par->frame_size,
                                      frame_bytes);
+    return FFMAX(0, duration);
  }
#if !HAVE_THREADS

Will apply.
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-requ...@ffmpeg.org with subject "unsubscribe".

Reply via email to