[FFmpeg-devel] [PATCH 2/2] avformat/mxfdec: Use 64bit in remainder

James Almer jamrial at gmail.com
Mon Dec 26 16:11:46 EET 2022


On 12/25/2022 7:03 PM, Michael Niedermayer wrote:
> Fixes: signed integer overflow: 48000 * 223587 cannot be represented in type 'int'
> Fixes: 54513/clusterfuzz-testcase-minimized-ffmpeg_DEMUXER_fuzzer-5817594836025344
> 
> 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/mxfdec.c | 4 ++--
>   1 file changed, 2 insertions(+), 2 deletions(-)
> 
> diff --git a/libavformat/mxfdec.c b/libavformat/mxfdec.c
> index e6118e141d..6150c131ec 100644
> --- a/libavformat/mxfdec.c
> +++ b/libavformat/mxfdec.c
> @@ -3857,8 +3857,8 @@ static int64_t mxf_compute_sample_count(MXFContext *mxf, AVStream *st,
>       if ((sample_rate.num / sample_rate.den) == 48000) {
>           return av_rescale_q(edit_unit, sample_rate, track->edit_rate);
>       } else {
> -        int remainder = (sample_rate.num * time_base.num) %
> -                        (time_base.den * sample_rate.den);
> +        int64_t remainder = (sample_rate.num * (int64_t)time_base.num) %
> +                        (time_base.den * (int64_t)sample_rate.den);

Don't undo the vertical alignment, please.

>           if (remainder)
>               av_log(mxf->fc, AV_LOG_WARNING,
>                      "seeking detected on stream #%d with time base (%d/%d) and "


More information about the ffmpeg-devel mailing list