1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-03 05:10:03 +02:00
FFmpeg/tests/ref/fate/movenc
Anton Khirnov 9200514ad8 lavf: replace AVStream.codec with AVStream.codecpar
Currently, AVStream contains an embedded AVCodecContext instance, which
is used by demuxers to export stream parameters to the caller and by
muxers to receive stream parameters from the caller. It is also used
internally as the codec context that is passed to parsers.

In addition, it is also widely used by the callers as the decoding (when
demuxer) or encoding (when muxing) context, though this has been
officially discouraged since Libav 11.

There are multiple important problems with this approach:
    - the fields in AVCodecContext are in general one of
        * stream parameters
        * codec options
        * codec state
      However, it's not clear which ones are which. It is consequently
      unclear which fields are a demuxer allowed to set or a muxer allowed to
      read. This leads to erratic behaviour depending on whether decoding or
      encoding is being performed or not (and whether it uses the AVStream
      embedded codec context).
    - various synchronization issues arising from the fact that the same
      context is used by several different APIs (muxers/demuxers,
      parsers, bitstream filters and encoders/decoders) simultaneously, with
      there being no clear rules for who can modify what and the different
      processes being typically delayed with respect to each other.
    - avformat_find_stream_info() making it necessary to support opening
      and closing a single codec context multiple times, thus
      complicating the semantics of freeing various allocated objects in the
      codec context.

Those problems are resolved by replacing the AVStream embedded codec
context with a newly added AVCodecParameters instance, which stores only
the stream parameters exported by the demuxers or read by the muxers.
2016-02-23 17:01:58 +01:00

29 lines
1.7 KiB
Plaintext

07cee26b35b140ae50268c3083e2d880 2449 non-empty-moov
c3c47c2c9566cb410e0832c37f4f8527 2897 non-empty-moov-elst
abc910edf1fc2a205658353dfdfc9a5f 2817 non-empty-moov-no-elst
e8e0346bf20bfcb448695bd905946f78 3871 ismv
89ea214e1d1079556164664eea9a7884 2327 empty-moov
cf9eec38fe557203a37a44c8adafb1fe 2727 empty-moov-no-elst
42eca5843d98aa9a9b3275de201700b8 2559 empty-moov-no-elst-no-adjust
89ea214e1d1079556164664eea9a7884 2327 delay-moov
8fd78a5a91d73a735da53ac02f844177 2639 delay-moov-elst
848d2fe2f27882960b8e10315460bc23 1846 delay-moov-empty-track
cbf60ba66c47b8506c1a724d43f12cdc 1749 delay-moov-empty-track-flush
c0b13fd47ca4c6de13c03155c38c231c 1183 empty-moov-header
f12baf7c4269695817337192c7069328 996 empty-moov-content
c0b13fd47ca4c6de13c03155c38c231c 1183 delay-moov-header
f12baf7c4269695817337192c7069328 996 delay-moov-content
76e1081bbab7541eadcaf4b19d37eff6 584 empty-moov-second-frag
76e1081bbab7541eadcaf4b19d37eff6 584 empty-moov-second-frag-discont
76e1081bbab7541eadcaf4b19d37eff6 584 delay-moov-second-frag-discont
fdc08ccfb9ca1a7a63a8e82a99e28e83 1207 delay-moov-elst-init
41afdc44b0e376fae49a730afe0c53c2 704 delay-moov-elst-second-frag
fdc08ccfb9ca1a7a63a8e82a99e28e83 1207 delay-moov-elst-init-discont
41afdc44b0e376fae49a730afe0c53c2 704 delay-moov-elst-second-frag-discont
57c113cd2baf7b231355eee6980fb6b5 1243 delay-moov-elst-signal-init
13b8487a4f004ec9f1db543aee1e5e18 704 delay-moov-elst-signal-second-frag
57c113cd2baf7b231355eee6980fb6b5 1243 delay-moov-elst-signal-init-discont
13b8487a4f004ec9f1db543aee1e5e18 704 delay-moov-elst-signal-second-frag-discont
5e676152714f9478b5f74ce67cd7ed60 3647 vfr
5e676152714f9478b5f74ce67cd7ed60 3647 vfr-noduration