[FFmpeg-devel] [PATCH 4/4] avformat/argo_brp: Check num_frames before using it to compute the duration
Zane van Iperen
zane at zanevaniperen.com
Mon Nov 2 13:56:42 EET 2020
On 26/10/20 9:00 am, Michael Niedermayer wrote:
>
> Fixes: Assertion failure
> Fixes: 26572/clusterfuzz-testcase-minimized-ffmpeg_dem_ARGO_BRP_fuzzer-5166735591997440
>
> Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/projects/ffmpeg
> Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
> ---
> libavformat/argo_brp.c | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
>
> diff --git a/libavformat/argo_brp.c b/libavformat/argo_brp.c
> index fdc552af14..48e0cd6aa4 100644
> --- a/libavformat/argo_brp.c
> +++ b/libavformat/argo_brp.c
> @@ -403,7 +403,8 @@ static int argo_brp_read_packet(AVFormatContext *s, AVPacket *pkt)
> pkt->duration = ckhdr.num_samples * ckhdr.num_blocks;
> pkt->pts = av_rescale_rnd(blk.start_ms, ckhdr.sample_rate, 1000, AV_ROUND_UP);
> } else if (shdr->codec_id == BRP_CODEC_ID_BVID) {
> - pkt->duration = av_rescale_rnd(1, st->duration, shdr->extradata.bvid.num_frames, AV_ROUND_UP);
> + if (shdr->extradata.bvid.num_frames)
> + pkt->duration = av_rescale_rnd(1, st->duration, shdr->extradata.bvid.num_frames, AV_ROUND_UP);
> pkt->pts = blk.start_ms;
> } else {
> pkt->pts = blk.start_ms;
> --
> 2.17.1
num_frames should never be 0. Will send fix shortly.
More information about the ffmpeg-devel
mailing list