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

Marton Balint cus at passwd.hu
Tue Dec 31 12:27:45 EET 2024



On Tue, 31 Dec 2024, Michael Niedermayer wrote:

> Suggested-by: Marton Balint <cus at passwd.hu>
> Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
> ---
> libavformat/vqf.c | 16 ++++++++++------
> 1 file changed, 10 insertions(+), 6 deletions(-)
>
> diff --git a/libavformat/vqf.c b/libavformat/vqf.c
> index 79deb33744b..5094724240e 100644
> --- a/libavformat/vqf.c
> +++ b/libavformat/vqf.c
> @@ -51,23 +51,24 @@ 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};
>
>     if (len == UINT_MAX)
> -        return;
> +        return AVERROR(ENOMEM);

AVERROR_INVALIDDATA. Although this check seems redundant because 
you check lengths values earlier more strictly.

>
>     buf = av_malloc(len+1);
>     if (!buf)
> -        return;
> +        return AVERROR(ENOMEM);
>     if (len != avio_read(s->pb, buf, len))
> -        return;
> +        return len < 0 ? len : AVERROR_INVALIDDATA;
>     buf[len] = 0;
>     AV_WL32(key, tag);
>     av_dict_set(&s->metadata, key, buf, AV_DICT_DONT_STRDUP_VAL);

Why not simply return av_dict_set()?

> +    return 0;
> }
>
> static const AVMetadataConv vqf_metadata_conv[] = {
> @@ -164,10 +165,13 @@ static int vqf_read_header(AVFormatContext *s)
>         case MKTAG('_','I','D','3'): // reserved for ID3 tags
>             avio_skip(s->pb, FFMIN(len, header_size));
>             break;
> -        default:
> -            add_metadata(s, chunk_tag, len, header_size);
> +        default: {

New block seems unnecessary.

> +            ret = add_metadata(s, chunk_tag, len, header_size);
> +            if (ret < 0)
> +                return ret;
>             break;
>         }
> +        }

Thanks,
Marton


More information about the ffmpeg-devel mailing list