[FFmpeg-devel] [PATCH] avcodec/avcodec: Limit the number of side data elements per packet
wm4
nfxjfg at googlemail.com
Thu May 11 19:54:16 EEST 2017
On Thu, 11 May 2017 13:01:36 +0200
Michael Niedermayer <michael at niedermayer.cc> wrote:
> Fixes: 1293/clusterfuzz-testcase-minimized-6054752074858496
>
> Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/targets/ffmpeg
> Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
> ---
> libavcodec/avcodec.h | 8 ++++++++
> libavcodec/avpacket.c | 5 ++++-
> 2 files changed, 12 insertions(+), 1 deletion(-)
>
> diff --git a/libavcodec/avcodec.h b/libavcodec/avcodec.h
> index df6d2bc748..173c083a86 100644
> --- a/libavcodec/avcodec.h
> +++ b/libavcodec/avcodec.h
> @@ -1593,6 +1593,14 @@ enum AVPacketSideDataType {
> * AVContentLightMetadata struct.
> */
> AV_PKT_DATA_CONTENT_LIGHT_LEVEL,
> +
> + /**
> + * The number of side data elements (in fact a bit more than it).
> + * This is not part of the public API/ABI in the sense that it may
> + * change when new side data types are added.
> + * This must stay the last enum value.
> + */
> + AV_PKT_DATA_NB,
> };
OK I guess.
> #define AV_PKT_DATA_QUALITY_FACTOR AV_PKT_DATA_QUALITY_STATS //DEPRECATED
> diff --git a/libavcodec/avpacket.c b/libavcodec/avpacket.c
> index 369dd78208..200ba99f34 100644
> --- a/libavcodec/avpacket.c
> +++ b/libavcodec/avpacket.c
> @@ -298,7 +298,7 @@ int av_packet_add_side_data(AVPacket *pkt, enum AVPacketSideDataType type,
> AVPacketSideData *tmp;
> int elems = pkt->side_data_elems;
>
> - if ((unsigned)elems + 1 > INT_MAX / sizeof(*pkt->side_data))
> + if ((unsigned)elems + 1 > FFMIN(INT_MAX / sizeof(*pkt->side_data), AV_PKT_DATA_NB))
Does the FFMIN and the old expression on the right side still have any
function?
> return AVERROR(ERANGE);
>
> tmp = av_realloc(pkt->side_data, (elems + 1) * sizeof(*tmp));
> @@ -437,6 +437,9 @@ int av_packet_split_side_data(AVPacket *pkt){
> p-= size+5;
> }
>
> + if (i > AV_PKT_DATA_NB)
> + return AVERROR(ERANGE);
> +
> pkt->side_data = av_malloc_array(i, sizeof(*pkt->side_data));
> if (!pkt->side_data)
> return AVERROR(ENOMEM);
More information about the ffmpeg-devel
mailing list