[FFmpeg-devel] [PATCH v2] avformat/vqf: Propagate errors from add_metadata()

Alexander Strasser eclipse7 at gmx.net
Wed Jan 1 20:53:27 EET 2025


On 2025-01-01 06:15 +0100, Michael Niedermayer wrote:
> Suggested-by: Marton Balint <cus at passwd.hu>
> Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
> ---
>  libavformat/vqf.c | 21 ++++++++++++++-------
>  1 file changed, 14 insertions(+), 7 deletions(-)
>
> diff --git a/libavformat/vqf.c b/libavformat/vqf.c
> index 79deb33744b..58b1546f531 100644
> --- a/libavformat/vqf.c
> +++ b/libavformat/vqf.c
> @@ -51,23 +51,28 @@ static int vqf_probe(const AVProbeData *probe_packet)
>      return AVPROBE_SCORE_EXTENSION;
>  }
>
> -static void add_metadata(AVFormatContext *s, uint32_t tag,
> +static int add_metadata(AVFormatContext *s, uint32_t tag,
>                           unsigned int tag_len, unsigned int remaining)
>  {
>      int len = FFMIN(tag_len, remaining);
>      char *buf, key[5] = {0};
> +    int ret;
>
>      if (len == UINT_MAX)
> -        return;
> +        return AVERROR_INVALIDDATA;
>
>      buf = av_malloc(len+1);
>      if (!buf)
> -        return;
> -    if (len != avio_read(s->pb, buf, len))
> -        return;
> +        return AVERROR(ENOMEM);
> +
> +    ret = avio_read(s->pb, buf, len);
> +    if (ret < 0)
> +        return ret;
> +    if (len != ret)
> +        return AVERROR_INVALIDDATA;
>      buf[len] = 0;
>      AV_WL32(key, tag);
> -    av_dict_set(&s->metadata, key, buf, AV_DICT_DONT_STRDUP_VAL);
> +    return av_dict_set(&s->metadata, key, buf, AV_DICT_DONT_STRDUP_VAL);
>  }
>
>  static const AVMetadataConv vqf_metadata_conv[] = {
> @@ -165,7 +170,9 @@ static int vqf_read_header(AVFormatContext *s)
>              avio_skip(s->pb, FFMIN(len, header_size));
>              break;
>          default:
> -            add_metadata(s, chunk_tag, len, header_size);
> +            ret = add_metadata(s, chunk_tag, len, header_size);
> +            if (ret < 0)
> +                return ret;
>              break;
>          }
>
> --

LGTM regarding my review comments.


  Alexander


More information about the ffmpeg-devel mailing list