[FFmpeg-devel] [PATCH v6 0/9] Properly decode ogg metadata in ogg/{vorbis, flac, opus} chained bitstreams

Romain Beauxis romain.beauxis at gmail.com
Wed Feb 19 20:57:11 EET 2025


Le mer. 19 févr. 2025 à 12:17, Lynne <dev at lynne.ee> a écrit :
>
> On 19/02/2025 06:24, Romain Beauxis wrote:
> > This is a series of patches to allow proper decoding of ogg metadata in chained
> > `ogg/vorbis, `ogg/flac` and `ogg/opus` streams.
> >
> > ## Changes since last version:
> > * Metadata update is now using a factored out function from the vorbis
> >    decoder which includes update the underlying AVStream metadata and
> >    setting AVSTREAM_EVENT_FLAG_METADATA_UPDATED on it.
> > * New vorbis comment metadata erase existing ones instead of appending
> > * Test utility is updated to include the stream's metadata
> > * A test for chained ogg/vorbis metadata is added.
> >
> > Last version and discussion: https://ffmpeg.org/pipermail/ffmpeg-devel/2025-February/339887.html
> >
> > Romain Beauxis (9):
> >    libavcodec/decode.c: intercept `AV_PKT_DATA_METADATA_UPDATE` packet
> >      extra data, attach them to the next decoded frame.
> >    tests: Add stream dump test API util.
> >    libavformat/oggparsevorbis.c: Don't append new metadata.
> >    tests: Add chained ogg/vorbis stream dump test.
> >    libavformat/oggdec.h, libavformat/oggparsevorbis.c: Factor out vorbis
> >      metadata update mechanism.
> >    libavformat/oggparseflac.c: Parse ogg/flac comments in new ogg
> >      packets, add them to ogg stream new_metadata.
> >    tests: Add chained ogg/flac stream dump test.
> >    libavformat/oggparseopus.c: Parse comments from secondary chained
> >      streams header packet.
> >    tests: Add chained ogg/opus stream dump test.
> >
> >   libavcodec/decode.c                   |  20 +++
> >   libavformat/oggdec.h                  |  14 +++
> >   libavformat/oggparseflac.c            |  21 ++++
> >   libavformat/oggparseopus.c            |  13 +-
> >   libavformat/oggparsevorbis.c          |  29 +++--
> >   tests/Makefile                        |   4 +
> >   tests/api/Makefile                    |   2 +-
> >   tests/api/api-dump-stream-meta-test.c | 175 ++++++++++++++++++++++++++
> >   tests/fate/ogg-flac.mak               |  11 ++
> >   tests/fate/ogg-opus.mak               |  11 ++
> >   tests/fate/ogg-vorbis.mak             |  11 ++
> >   11 files changed, 298 insertions(+), 13 deletions(-)
> >   create mode 100644 tests/api/api-dump-stream-meta-test.c
> >   create mode 100644 tests/fate/ogg-flac.mak
> >   create mode 100644 tests/fate/ogg-opus.mak
> >   create mode 100644 tests/fate/ogg-vorbis.mak
>
> I fail to see any changes. No mention of
> AVSTREAM_EVENT_FLAG_METADATA_UPDATED in any of the diffs?

It's because it's reusing what vorbis is already doing here:
https://code.ffmpeg.org/FFmpeg/FFmpeg/src/branch/master/libavformat/oggparsevorbis.c#L74-L84


More information about the ffmpeg-devel mailing list