Go to the documentation of this file.
328 static const struct {
368 return bitmap < 0x40000 ? bitmap : 0;
377 for (
i = 0; layout_map[
i].
tag != 0;
i++) {
389 return 1
U << (label - 1);
425 uint32_t **pchannel_desc)
453 for (j = 0; layout_map[j].
tag != 0; j++) {
459 if (layout_map[j].
tag)
467 *pchannel_desc =
NULL;
471 uint32_t *channel_desc;
488 if (channel_desc[
i] == 0) {
494 *pchannel_desc = channel_desc;
503 uint32_t layout_tag, bitmap, num_descr;
504 uint64_t label_mask,
mask = 0;
515 "bitmap=%"PRIu32
" num_descr=%"PRIu32
"\n",
516 layout_tag, bitmap, num_descr);
518 if (
size < 12ULL + num_descr * 20ULL)
522 for (
i = 0;
i < num_descr;
i++) {
526 "reached EOF while reading channel layout\n");
535 if (layout_tag == 0) {
537 if (mask_incr == 0) {
541 label_mask |= mask_incr;
544 if (layout_tag == 0) {
@ MOV_CH_LAYOUT_QUADRAPHONIC
#define AV_CH_LAYOUT_7POINT0
@ MOV_CH_LAYOUT_EAC3_7_1_D
#define AV_CH_LAYOUT_6POINT1
@ MOV_CH_LAYOUT_MPEG_4_0_A
@ MOV_CH_LAYOUT_EAC3_7_1_H
#define AV_CH_LAYOUT_5POINT0_BACK
@ AV_CHAN_STEREO_RIGHT
See above.
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
@ MOV_CH_LAYOUT_MPEG_5_1_A
#define AV_CH_TOP_FRONT_CENTER
@ AV_CHAN_LOW_FREQUENCY_2
This struct describes the properties of an encoded stream.
#define AV_CH_LOW_FREQUENCY_2
enum MovChannelLayoutTag * layouts
@ MOV_CH_LAYOUT_DTS_6_1_D
#define AV_CH_LAYOUT_MONO
@ MOV_CH_LAYOUT_DTS_8_0_A
#define AV_CH_TOP_FRONT_RIGHT
@ MOV_CH_LAYOUT_AUDIOUNIT_7_0_FRONT
@ MOV_CH_LAYOUT_AC3_3_0_1
@ MOV_CH_LAYOUT_AUDIOUNIT_7_0
#define AV_CH_LAYOUT_HEXAGONAL
@ MOV_CH_LAYOUT_EAC3_7_1_B
#define AV_CH_LAYOUT_6POINT0_FRONT
#define AV_CH_LAYOUT_6POINT1_FRONT
#define AV_CH_TOP_FRONT_LEFT
@ MOV_CH_LAYOUT_AMBISONIC_B_FORMAT
enum AVChannelOrder order
Channel order used in this layout.
uint64_t mask
This member must be used for AV_CHANNEL_ORDER_NATIVE, and may be used for AV_CHANNEL_ORDER_AMBISONIC ...
int nb_channels
Number of channels in this layout.
int ff_mov_get_channel_layout_tag(const AVCodecParameters *par, uint32_t *layout, uint32_t *bitmap, uint32_t **pchannel_desc)
Get the channel layout tag for the specified codec id and channel layout.
#define AV_CH_SURROUND_DIRECT_RIGHT
@ MOV_CH_LAYOUT_DTS_6_0_A
#define AV_CH_TOP_BACK_LEFT
@ MOV_CH_LAYOUT_MATRIXSTEREO
#define AV_CH_LAYOUT_6POINT0
@ MOV_CH_LAYOUT_MPEG_5_0_A
@ MOV_CH_LAYOUT_EAC3_7_1_C
@ AV_CHAN_STEREO_LEFT
Stereo downmix.
@ MOV_CH_LAYOUT_MPEG_5_1_D
static uint64_t mov_get_channel_layout(uint32_t tag, uint32_t bitmap)
Get the channel layout for the specified channel layout tag.
static enum MovChannelLayoutTag mov_ch_layouts_alac[]
@ MOV_CH_LAYOUT_DTS_6_0_B
#define AV_CH_LAYOUT_STEREO
#define AV_CH_LAYOUT_QUAD
@ MOV_CH_LAYOUT_DTS_8_0_B
@ MOV_CH_LAYOUT_EAC3_7_1_G
unsigned int avio_rb32(AVIOContext *s)
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
@ MOV_CH_LAYOUT_AC3_1_0_1
@ AV_CHANNEL_ORDER_NATIVE
The native channel order, i.e.
#define AV_CH_LOW_FREQUENCY
@ MOV_CH_LAYOUT_HEXAGONAL
@ MOV_CH_LAYOUT_MPEG_5_1_C
static const uint16_t mask[17]
@ AV_CHANNEL_ORDER_UNSPEC
Only the channel count is specified, without any further information about the channel order.
@ MOV_CH_LAYOUT_EAC3_6_1_A
static const struct MovChannelLayoutMap mov_ch_layout_map_7ch[]
@ MOV_CH_LAYOUT_DTS_8_1_A
#define AV_CH_LAYOUT_7POINT0_FRONT
#define AV_CH_LAYOUT_STEREO_DOWNMIX
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
@ MOV_CH_LAYOUT_DTS_8_1_B
@ MOV_CH_LAYOUT_MPEG_7_1_B
@ MOV_CH_LAYOUT_PENTAGONAL
#define AV_CH_STEREO_RIGHT
@ MOV_CH_LAYOUT_SMPTE_DTV
AVCodecParameters * codecpar
Codec parameters associated with this stream.
MovChannelLayoutTag
mov 'chan' tag reading/writing.
union AVChannelLayout::@296 u
Details about which channels are present in this layout.
static const struct MovChannelLayoutMap mov_ch_layout_map_1ch[]
static uint64_t mov_get_channel_mask(uint32_t label)
static const struct @273 mov_codec_ch_layouts[]
#define MOV_CH_LAYOUT_UNKNOWN
@ MOV_CH_LAYOUT_EAC3_6_0_A
@ MOV_CH_LAYOUT_DTS_6_1_C
#define AV_CH_LAYOUT_5POINT1
@ MOV_CH_LAYOUT_MPEG_3_0_B
AVChannelLayout ch_layout
Audio only.
#define AV_CH_FRONT_LEFT_OF_CENTER
mov 'chan' tag reading/writing.
void av_channel_layout_uninit(AVChannelLayout *channel_layout)
Free any allocated data in the channel layout and reset the channel count to 0.
AVCodecID
Identify the syntax and semantics of the bitstream.
@ MOV_CH_LAYOUT_EAC3_6_1_C
unsigned int avio_rl32(AVIOContext *s)
@ MOV_CH_LAYOUT_STEREOHEADPHONES
@ MOV_CH_LAYOUT_DISCRETEINORDER
@ MOV_CH_LAYOUT_MPEG_5_1_B
@ MOV_CH_LAYOUT_MPEG_7_1_A
@ MOV_CH_LAYOUT_DTS_6_1_A
#define AV_CH_LAYOUT_5POINT1_BACK
@ MOV_CH_LAYOUT_MPEG_3_0_A
#define AV_CH_TOP_BACK_RIGHT
#define AV_CH_FRONT_RIGHT_OF_CENTER
#define AV_CH_LAYOUT_3POINT1
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel layout
static const struct MovChannelLayoutMap mov_ch_layout_map_5ch[]
#define AV_CH_LAYOUT_OCTAGONAL
#define AV_CH_LAYOUT_5POINT0
@ MOV_CH_LAYOUT_MPEG_5_0_D
@ MOV_CH_LAYOUT_EMAGIC_DEFAULT_7_1
static const struct MovChannelLayoutMap mov_ch_layout_map_9ch[]
static const struct MovChannelLayoutMap mov_ch_layout_map_8ch[]
#define i(width, name, range_min, range_max)
#define AV_CH_LAYOUT_2POINT1
#define av_malloc_array(a, b)
#define AV_CH_LAYOUT_7POINT1
#define AV_CH_LAYOUT_4POINT1
#define AV_CH_BACK_CENTER
@ MOV_CH_LAYOUT_MPEG_6_1_A
#define AV_CH_LAYOUT_7POINT1_WIDE
@ MOV_CH_LAYOUT_AUDIOUNIT_6_0
static const struct MovChannelLayoutMap *const mov_ch_layout_map[]
@ MOV_CH_LAYOUT_AC3_2_1_1
@ MOV_CH_LAYOUT_MPEG_4_0_B
enum AVChannel av_channel_layout_channel_from_index(const AVChannelLayout *channel_layout, unsigned int idx)
Get the channel with the given index in a channel layout.
@ MOV_CH_LAYOUT_MPEG_5_0_C
FF_ENABLE_DEPRECATION_WARNINGS int av_channel_layout_from_mask(AVChannelLayout *channel_layout, uint64_t mask)
Initialize a native channel layout from a bitmask indicating which channels are present.
#define AV_CH_LAYOUT_SURROUND
@ MOV_CH_LAYOUT_TMH_10_2_FULL
static const struct MovChannelLayoutMap mov_ch_layout_map_6ch[]
@ MOV_CH_LAYOUT_OCTAGONAL
@ MOV_CH_LAYOUT_EAC3_7_1_A
@ MOV_CH_LAYOUT_EAC3_7_0_A
int eof_reached
true if was unable to read due to error or eof
#define AV_CH_SURROUND_DIRECT_LEFT
@ MOV_CH_LAYOUT_MPEG_7_1_C
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward.
static enum MovChannelLayoutTag mov_ch_layouts_aac[]
@ MOV_CH_LAYOUT_AAC_OCTAGONAL
@ MOV_CH_LAYOUT_DTS_6_0_C
static uint32_t mov_get_channel_label(enum AVChannel channel)
static const struct MovChannelLayoutMap mov_ch_layout_map_2ch[]
@ MOV_CH_LAYOUT_EAC3_7_1_E
@ MOV_CH_LAYOUT_AC3_3_1_1
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
@ MOV_CH_LAYOUT_MPEG_5_0_B
@ MOV_CH_LAYOUT_DTS_6_1_B
#define AV_CH_LAYOUT_4POINT0
#define AV_CH_LAYOUT_6POINT1_BACK
static const struct MovChannelLayoutMap mov_ch_layout_map_3ch[]
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
static const struct MovChannelLayoutMap mov_ch_layout_map_misc[]
#define AV_CH_STEREO_LEFT
@ MOV_CH_LAYOUT_TMH_10_2_STD
static enum MovChannelLayoutTag mov_ch_layouts_wav[]
@ MOV_CH_LAYOUT_EAC3_7_1_F
static enum MovChannelLayoutTag mov_ch_layouts_ac3[]
@ MOV_CH_LAYOUT_EAC3_6_1_B
static const struct MovChannelLayoutMap mov_ch_layout_map_4ch[]
@ MOV_CH_LAYOUT_USE_BITMAP
@ MOV_CH_LAYOUT_USE_DESCRIPTIONS
int ff_mov_read_chan(AVFormatContext *s, AVIOContext *pb, AVStream *st, int64_t size)
Read 'chan' tag from the input stream.