FFmpeg
Data Structures | Macros | Functions

Muxers take encoded data in the form of AVPackets and write it into files or other output bytestreams in the specified container format. More...

Data Structures

struct  AVOutputFormat
 

Macros

#define AVSTREAM_INIT_IN_WRITE_HEADER   0
 stream parameters initialized in avformat_write_header More...
 
#define AVSTREAM_INIT_IN_INIT_OUTPUT   1
 stream parameters initialized in avformat_init_output More...
 

Functions

av_warn_unused_result int avformat_write_header (AVFormatContext *s, AVDictionary **options)
 Allocate the stream private data and write the stream header to an output media file. More...
 
av_warn_unused_result int avformat_init_output (AVFormatContext *s, AVDictionary **options)
 Allocate the stream private data and initialize the codec, but do not write the header. More...
 
int av_write_frame (AVFormatContext *s, AVPacket *pkt)
 Write a packet to an output media file. More...
 
int av_interleaved_write_frame (AVFormatContext *s, AVPacket *pkt)
 Write a packet to an output media file ensuring correct interleaving. More...
 
int av_write_uncoded_frame (AVFormatContext *s, int stream_index, struct AVFrame *frame)
 Write an uncoded frame to an output media file. More...
 
int av_interleaved_write_uncoded_frame (AVFormatContext *s, int stream_index, struct AVFrame *frame)
 Write an uncoded frame to an output media file. More...
 
int av_write_uncoded_frame_query (AVFormatContext *s, int stream_index)
 Test whether a muxer supports uncoded frame. More...
 
int av_write_trailer (AVFormatContext *s)
 Write the stream trailer to an output media file and free the file private data. More...
 
const AVOutputFormatav_guess_format (const char *short_name, const char *filename, const char *mime_type)
 Return the output format in the list of registered output formats which best matches the provided parameters, or return NULL if there is no match. More...
 
enum AVCodecID av_guess_codec (const AVOutputFormat *fmt, const char *short_name, const char *filename, const char *mime_type, enum AVMediaType type)
 Guess the codec ID based upon muxer and filename. More...
 
int av_get_output_timestamp (struct AVFormatContext *s, int stream, int64_t *dts, int64_t *wall)
 Get timing information for the data currently output. More...
 

Detailed Description

Muxers take encoded data in the form of AVPackets and write it into files or other output bytestreams in the specified container format.

The main API functions for muxing are avformat_write_header() for writing the file header, av_write_frame() / av_interleaved_write_frame() for writing the packets and av_write_trailer() for finalizing the file.

At the beginning of the muxing process, the caller must first call avformat_alloc_context() to create a muxing context. The caller then sets up the muxer by filling the various fields in this context:

When the muxing context is fully set up, the caller must call avformat_write_header() to initialize the muxer internals and write the file header. Whether anything actually is written to the IO context at this step depends on the muxer, but this function must always be called. Any muxer private options must be passed in the options parameter to this function.

The data is then sent to the muxer by repeatedly calling av_write_frame() or av_interleaved_write_frame() (consult those functions' documentation for discussion on the difference between them; only one of them may be used with a single muxing context, they should not be mixed). Do note that the timing information on the packets sent to the muxer must be in the corresponding AVStream's timebase. That timebase is set by the muxer (in the avformat_write_header() step) and may be different from the timebase requested by the caller.

Once all the data has been written, the caller must call av_write_trailer() to flush any buffered packets and finalize the output file, then close the IO context (if any) and finally free the muxing context with avformat_free_context().

Macro Definition Documentation

◆ AVSTREAM_INIT_IN_WRITE_HEADER

#define AVSTREAM_INIT_IN_WRITE_HEADER   0

stream parameters initialized in avformat_write_header

Definition at line 2500 of file avformat.h.

◆ AVSTREAM_INIT_IN_INIT_OUTPUT

#define AVSTREAM_INIT_IN_INIT_OUTPUT   1

stream parameters initialized in avformat_init_output

Definition at line 2501 of file avformat.h.

Function Documentation

◆ avformat_write_header()

av_warn_unused_result int avformat_write_header ( AVFormatContext s,
AVDictionary **  options 
)

Allocate the stream private data and write the stream header to an output media file.

Parameters
sMedia file handle, must be allocated with avformat_alloc_context(). Its oformat field must be set to the desired output format; Its pb field must be set to an already opened AVIOContext.
optionsAn AVDictionary filled with AVFormatContext and muxer-private options. On return this parameter will be destroyed and replaced with a dict containing options that were not found. May be NULL.
Return values
AVSTREAM_INIT_IN_WRITE_HEADEROn success, if the codec had not already been fully initialized in avformat_init_output().
AVSTREAM_INIT_IN_INIT_OUTPUTOn success, if the codec had already been fully initialized in avformat_init_output().
AVERRORA negative AVERROR on failure.
See also
av_opt_find, av_dict_set, avio_open, av_oformat_next, avformat_init_output.
Examples
qsv_transcode.c, remux.c, transcode.c, transcode_aac.c, and vaapi_transcode.c.

Definition at line 487 of file mux.c.

Referenced by dash_write_header(), dec_enc(), ff_rtp_chain_mux_open(), fifo_basic_test(), fifo_overflow_drop_test(), fifo_thread_write_header(), hds_write_header(), hls_start(), hls_write_header(), init_fps(), ism_write_header(), main(), mov_write_ttml_document_from_queue(), mpegts_init(), mux_check_init(), open_output_file(), open_slave(), rtp_mpegts_write_header(), seg_init(), seg_write_header(), segment_start(), webm_chunk_write_header(), write_muxed_file(), and write_output_file_header().

◆ avformat_init_output()

av_warn_unused_result int avformat_init_output ( AVFormatContext s,
AVDictionary **  options 
)

Allocate the stream private data and initialize the codec, but do not write the header.

May optionally be used before avformat_write_header() to initialize stream parameters before actually writing the header. If using this function, do not pass the same options to avformat_write_header().

Parameters
sMedia file handle, must be allocated with avformat_alloc_context(). Its oformat field must be set to the desired output format; Its pb field must be set to an already opened AVIOContext.
optionsAn AVDictionary filled with AVFormatContext and muxer-private options. On return this parameter will be destroyed and replaced with a dict containing options that were not found. May be NULL.
Return values
AVSTREAM_INIT_IN_WRITE_HEADEROn success, if the codec requires avformat_write_header to fully initialize.
AVSTREAM_INIT_IN_INIT_OUTPUTOn success, if the codec has been fully initialized.
AVERRORAnegative AVERROR on failure.
See also
av_opt_find, av_dict_set, avio_open, av_oformat_next, avformat_write_header.

Definition at line 466 of file mux.c.

Referenced by avformat_write_header(), dash_init(), hls_mux_init(), seg_init(), and webm_chunk_init().

◆ av_write_frame()

int av_write_frame ( AVFormatContext s,
AVPacket pkt 
)

Write a packet to an output media file.

This function passes the packet directly to the muxer, without any buffering or reordering. The caller is responsible for correctly interleaving the packets if the format requires it. Callers that want libavformat to handle the interleaving should call av_interleaved_write_frame() instead of this function.

Parameters
smedia file handle
pktThe packet containing the data to be written. Note that unlike av_interleaved_write_frame(), this function does not take ownership of the packet passed to it (though some muxers may make an internal reference to the input packet).
This parameter can be NULL (at any time, not just at the end), in order to immediately flush data buffered within the muxer, for muxers that buffer up data internally before writing it to the output.
Packet's stream_index field must be set to the index of the corresponding stream in s->streams.
The timestamps (pts, dts) must be set to correct values in the stream's timebase (unless the output format is flagged with the AVFMT_NOTIMESTAMPS flag, then they can be set to AV_NOPTS_VALUE). The dts for subsequent packets passed to this function must be strictly increasing when compared in their respective timebases (unless the output format is flagged with the AVFMT_TS_NONSTRICT, then they merely have to be nondecreasing). duration) should also be set if known.
Returns
< 0 on error, = 0 if OK, 1 if flushed and there is no more data to flush
See also
av_interleaved_write_frame()
Examples
transcode_aac.c.

Definition at line 1233 of file mux.c.

Referenced by chunk_end(), dash_write_packet(), encode_audio_frame(), ff_write_chained(), fifo_basic_test(), fifo_overflow_drop_test(), fifo_thread_flush_output(), fifo_thread_write_packet(), flush_dynbuf(), hls_write_packet(), hls_write_trailer(), ism_flush(), main(), mov_write_ttml_document_from_queue(), mpegts_write_packet_internal(), mux_frames(), mux_id3(), rtp_mpegts_write_packet(), seg_write_header(), segment_end(), signal_init_ts(), webm_chunk_write_packet(), and write_uncoded_frame_internal().

◆ av_interleaved_write_frame()

int av_interleaved_write_frame ( AVFormatContext s,
AVPacket pkt 
)

Write a packet to an output media file ensuring correct interleaving.

This function will buffer the packets internally as needed to make sure the packets in the output file are properly interleaved, usually ordered by increasing dts. Callers doing their own interleaving should call av_write_frame() instead of this function.

Using this function instead of av_write_frame() can give muxers advance knowledge of future packets, improving e.g. the behaviour of the mp4 muxer for VFR content in fragmenting mode.

Parameters
smedia file handle
pktThe packet containing the data to be written.
If the packet is reference-counted, this function will take ownership of this reference and unreference it later when it sees fit. If the packet is not reference-counted, libavformat will make a copy. The returned packet will be blank (as if returned from av_packet_alloc()), even on error.
This parameter can be NULL (at any time, not just at the end), to flush the interleaving queues.
Packet's stream_index field must be set to the index of the corresponding stream in s->streams.
The timestamps (pts, dts) must be set to correct values in the stream's timebase (unless the output format is flagged with the AVFMT_NOTIMESTAMPS flag, then they can be set to AV_NOPTS_VALUE). The dts for subsequent packets in one stream must be strictly increasing (unless the output format is flagged with the AVFMT_TS_NONSTRICT, then they merely have to be nondecreasing). duration should also be set if known.
Returns
0 on success, a negative AVERROR on error.
See also
av_write_frame(), AVFormatContext.max_interleave_delta
Examples
qsv_transcode.c, remux.c, transcode.c, and vaapi_transcode.c.

Definition at line 1280 of file mux.c.

Referenced by encode_write(), encode_write_frame(), ff_write_chained(), main(), mux_frames(), tee_write_packet(), write_frame(), write_muxed_file(), write_packet(), and write_uncoded_frame_internal().

◆ av_write_uncoded_frame()

int av_write_uncoded_frame ( AVFormatContext s,
int  stream_index,
struct AVFrame frame 
)

Write an uncoded frame to an output media file.

The frame must be correctly interleaved according to the container specification; if not, av_interleaved_write_uncoded_frame() must be used.

See av_interleaved_write_uncoded_frame() for details.

Definition at line 1473 of file mux.c.

◆ av_interleaved_write_uncoded_frame()

int av_interleaved_write_uncoded_frame ( AVFormatContext s,
int  stream_index,
struct AVFrame frame 
)

Write an uncoded frame to an output media file.

If the muxer supports it, this function makes it possible to write an AVFrame structure directly, without encoding it into a packet. It is mostly useful for devices and similar special muxers that use raw video or PCM data and will not serialize it into a byte stream.

To test whether it is possible to use it with a given muxer and stream, use av_write_uncoded_frame_query().

The caller gives up ownership of the frame and must not access it afterwards.

Returns
>=0 for success, a negative code on error

Definition at line 1479 of file mux.c.

Referenced by main().

◆ av_write_uncoded_frame_query()

int av_write_uncoded_frame_query ( AVFormatContext s,
int  stream_index 
)

Test whether a muxer supports uncoded frame.

Returns
>=0 if an uncoded frame can be written to that muxer and stream, <0 if not

Definition at line 1485 of file mux.c.

Referenced by main().

◆ av_write_trailer()

int av_write_trailer ( AVFormatContext s)

Write the stream trailer to an output media file and free the file private data.

May only be called after a successful call to avformat_write_header.

Parameters
smedia file handle
Returns
0 if OK, AVERROR_xxx on error
Examples
qsv_transcode.c, remux.c, transcode.c, transcode_aac.c, and vaapi_transcode.c.

Definition at line 1295 of file mux.c.

Referenced by close_slave(), dash_flush(), ff_mov_close_hinting(), ff_rtsp_undo_setup(), fifo_basic_test(), fifo_overflow_drop_test(), fifo_thread_write_trailer(), finish(), hds_free(), hls_write_trailer(), main(), mov_write_ttml_document_from_queue(), of_write_trailer(), rtp_mpegts_write_close(), sap_write_close(), seg_write_trailer(), segment_end(), webm_chunk_write_trailer(), write_muxed_file(), and write_output_file_trailer().

◆ av_guess_format()

const AVOutputFormat* av_guess_format ( const char *  short_name,
const char *  filename,
const char *  mime_type 
)

Return the output format in the list of registered output formats which best matches the provided parameters, or return NULL if there is no match.

Parameters
short_nameif non-NULL checks if short_name matches with the names of the registered formats
filenameif non-NULL checks if filename terminates with the extensions of the registered formats
mime_typeif non-NULL checks if mime_type matches with the MIME type of the registered formats
Examples
transcode_aac.c.

Definition at line 79 of file format.c.

Referenced by av_guess_codec(), avformat_alloc_output_context2(), dash_init(), ff_rtp_chain_mux_open(), fifo_init(), hds_write_header(), hls_init(), init_fps(), ism_write_header(), mpegts_init(), open_output_file(), rtp_mpegts_write_header(), seg_init(), show_help_muxer(), and webm_chunk_init().

◆ av_guess_codec()

enum AVCodecID av_guess_codec ( const AVOutputFormat fmt,
const char *  short_name,
const char *  filename,
const char *  mime_type,
enum AVMediaType  type 
)

Guess the codec ID based upon muxer and filename.

Definition at line 115 of file format.c.

Referenced by choose_encoder(), map_auto_audio(), map_auto_data(), and map_auto_video().

◆ av_get_output_timestamp()

int av_get_output_timestamp ( struct AVFormatContext s,
int  stream,
int64_t dts,
int64_t wall 
)

Get timing information for the data currently output.

The exact meaning of "currently output" depends on the format. It is mostly relevant for devices that have an internal buffer and/or work in real time.

Parameters
smedia file handle
streamstream in the media file
[out]dtsDTS of the last packet output for the stream, in stream time_base units
[out]wallabsolute time when that packet whas output, in microsecond
Return values
0Success
AVERROR(ENOSYS)The format does not support it
Note
Some formats or devices may not allow to measure dts and wall atomically.

Definition at line 1341 of file mux.c.