FFmpeg
codec_par.c
Go to the documentation of this file.
1 /*
2  * AVCodecParameters functions for libavcodec
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 
21 /**
22  * @file
23  * AVCodecParameters functions for libavcodec.
24  */
25 
26 #include <string.h>
27 #include "libavutil/mem.h"
28 #include "avcodec.h"
29 #include "codec_par.h"
30 
32 {
33  av_freep(&par->extradata);
35 
36  memset(par, 0, sizeof(*par));
37 
40  par->format = -1;
48  par->sample_aspect_ratio = (AVRational){ 0, 1 };
50  par->level = FF_LEVEL_UNKNOWN;
51 }
52 
54 {
55  AVCodecParameters *par = av_mallocz(sizeof(*par));
56 
57  if (!par)
58  return NULL;
60  return par;
61 }
62 
64 {
65  AVCodecParameters *par = *ppar;
66 
67  if (!par)
68  return;
70 
71  av_freep(ppar);
72 }
73 
75 {
76  int ret;
77 
79  memcpy(dst, src, sizeof(*dst));
80 
81  dst->ch_layout = (AVChannelLayout){0};
82  dst->extradata = NULL;
83  dst->extradata_size = 0;
84  if (src->extradata) {
85  dst->extradata = av_mallocz(src->extradata_size + AV_INPUT_BUFFER_PADDING_SIZE);
86  if (!dst->extradata)
87  return AVERROR(ENOMEM);
88  memcpy(dst->extradata, src->extradata, src->extradata_size);
89  dst->extradata_size = src->extradata_size;
90  }
91 
92  ret = av_channel_layout_copy(&dst->ch_layout, &src->ch_layout);
93  if (ret < 0)
94  return ret;
95 
96  return 0;
97 }
98 
100  const AVCodecContext *codec)
101 {
102  int ret;
103 
105 
106  par->codec_type = codec->codec_type;
107  par->codec_id = codec->codec_id;
108  par->codec_tag = codec->codec_tag;
109 
110  par->bit_rate = codec->bit_rate;
113  par->profile = codec->profile;
114  par->level = codec->level;
115 
116  switch (par->codec_type) {
117  case AVMEDIA_TYPE_VIDEO:
118  par->format = codec->pix_fmt;
119  par->width = codec->width;
120  par->height = codec->height;
121  par->field_order = codec->field_order;
122  par->color_range = codec->color_range;
123  par->color_primaries = codec->color_primaries;
124  par->color_trc = codec->color_trc;
125  par->color_space = codec->colorspace;
128  par->video_delay = codec->has_b_frames;
129  break;
130  case AVMEDIA_TYPE_AUDIO:
131  par->format = codec->sample_fmt;
132 #if FF_API_OLD_CHANNEL_LAYOUT
134  // if the old/new fields are set inconsistently, prefer the old ones
135  if ((codec->channels && codec->channels != codec->ch_layout.nb_channels) ||
136  (codec->channel_layout && (codec->ch_layout.order != AV_CHANNEL_ORDER_NATIVE ||
137  codec->ch_layout.u.mask != codec->channel_layout))) {
138  if (codec->channel_layout)
139  av_channel_layout_from_mask(&par->ch_layout, codec->channel_layout);
140  else {
142  par->ch_layout.nb_channels = codec->channels;
143  }
145  } else {
146 #endif
147  ret = av_channel_layout_copy(&par->ch_layout, &codec->ch_layout);
148  if (ret < 0)
149  return ret;
150 #if FF_API_OLD_CHANNEL_LAYOUT
152  }
153  par->channel_layout = par->ch_layout.order == AV_CHANNEL_ORDER_NATIVE ?
154  par->ch_layout.u.mask : 0;
155  par->channels = par->ch_layout.nb_channels;
157 #endif
158  par->sample_rate = codec->sample_rate;
159  par->block_align = codec->block_align;
160  par->frame_size = codec->frame_size;
161  par->initial_padding = codec->initial_padding;
162  par->trailing_padding = codec->trailing_padding;
163  par->seek_preroll = codec->seek_preroll;
164  break;
166  par->width = codec->width;
167  par->height = codec->height;
168  break;
169  }
170 
171  if (codec->extradata) {
173  if (!par->extradata)
174  return AVERROR(ENOMEM);
175  memcpy(par->extradata, codec->extradata, codec->extradata_size);
176  par->extradata_size = codec->extradata_size;
177  }
178 
179  return 0;
180 }
181 
183  const AVCodecParameters *par)
184 {
185  int ret;
186 
187  codec->codec_type = par->codec_type;
188  codec->codec_id = par->codec_id;
189  codec->codec_tag = par->codec_tag;
190 
191  codec->bit_rate = par->bit_rate;
194  codec->profile = par->profile;
195  codec->level = par->level;
196 
197  switch (par->codec_type) {
198  case AVMEDIA_TYPE_VIDEO:
199  codec->pix_fmt = par->format;
200  codec->width = par->width;
201  codec->height = par->height;
202  codec->field_order = par->field_order;
203  codec->color_range = par->color_range;
204  codec->color_primaries = par->color_primaries;
205  codec->color_trc = par->color_trc;
206  codec->colorspace = par->color_space;
209  codec->has_b_frames = par->video_delay;
210  break;
211  case AVMEDIA_TYPE_AUDIO:
212  codec->sample_fmt = par->format;
213 #if FF_API_OLD_CHANNEL_LAYOUT
215  // if the old/new fields are set inconsistently, prefer the old ones
216  if ((par->channels && par->channels != par->ch_layout.nb_channels) ||
217  (par->channel_layout && (par->ch_layout.order != AV_CHANNEL_ORDER_NATIVE ||
218  par->ch_layout.u.mask != par->channel_layout))) {
219  if (par->channel_layout)
220  av_channel_layout_from_mask(&codec->ch_layout, par->channel_layout);
221  else {
223  codec->ch_layout.nb_channels = par->channels;
224  }
226  } else {
227 #endif
228  ret = av_channel_layout_copy(&codec->ch_layout, &par->ch_layout);
229  if (ret < 0)
230  return ret;
231 #if FF_API_OLD_CHANNEL_LAYOUT
233  }
234  codec->channel_layout = codec->ch_layout.order == AV_CHANNEL_ORDER_NATIVE ?
235  codec->ch_layout.u.mask : 0;
236  codec->channels = codec->ch_layout.nb_channels;
238 #endif
239  codec->sample_rate = par->sample_rate;
240  codec->block_align = par->block_align;
241  codec->frame_size = par->frame_size;
242  codec->delay =
243  codec->initial_padding = par->initial_padding;
244  codec->trailing_padding = par->trailing_padding;
245  codec->seek_preroll = par->seek_preroll;
246  break;
248  codec->width = par->width;
249  codec->height = par->height;
250  break;
251  }
252 
253  if (par->extradata) {
254  av_freep(&codec->extradata);
256  if (!codec->extradata)
257  return AVERROR(ENOMEM);
258  memcpy(codec->extradata, par->extradata, par->extradata_size);
259  codec->extradata_size = par->extradata_size;
260  }
261 
262  return 0;
263 }
AVCodecContext::frame_size
int frame_size
Number of samples per channel in an audio frame.
Definition: avcodec.h:1026
FF_ENABLE_DEPRECATION_WARNINGS
#define FF_ENABLE_DEPRECATION_WARNINGS
Definition: internal.h:83
AVMEDIA_TYPE_SUBTITLE
@ AVMEDIA_TYPE_SUBTITLE
Definition: avutil.h:204
AVCodecParameters::extradata
uint8_t * extradata
Extra binary data needed for initializing the decoder, codec-dependent.
Definition: codec_par.h:75
AVERROR
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
AVCodecParameters::codec_type
enum AVMediaType codec_type
General type of the encoded data.
Definition: codec_par.h:57
AVCodecContext::colorspace
enum AVColorSpace colorspace
YUV colorspace type.
Definition: avcodec.h:966
AVCodecContext::sample_rate
int sample_rate
samples per second
Definition: avcodec.h:998
AVCodecParameters
This struct describes the properties of an encoded stream.
Definition: codec_par.h:53
AVCodecParameters::color_space
enum AVColorSpace color_space
Definition: codec_par.h:150
avcodec_parameters_from_context
int avcodec_parameters_from_context(AVCodecParameters *par, const AVCodecContext *codec)
Fill the parameters struct based on the values from the supplied codec context.
Definition: codec_par.c:99
AVCodecContext::color_trc
enum AVColorTransferCharacteristic color_trc
Color Transfer Characteristic.
Definition: avcodec.h:959
AVCodecContext::field_order
enum AVFieldOrder field_order
Field order.
Definition: avcodec.h:995
AVCodecParameters::seek_preroll
int seek_preroll
Audio only.
Definition: codec_par.h:207
AVCOL_TRC_UNSPECIFIED
@ AVCOL_TRC_UNSPECIFIED
Definition: pixfmt.h:499
avcodec_parameters_free
void avcodec_parameters_free(AVCodecParameters **ppar)
Free an AVCodecParameters instance and everything associated with it and write NULL to the supplied p...
Definition: codec_par.c:63
AVCodecParameters::codec_tag
uint32_t codec_tag
Additional information about the codec (corresponds to the AVI FOURCC).
Definition: codec_par.h:65
FF_LEVEL_UNKNOWN
#define FF_LEVEL_UNKNOWN
Definition: avcodec.h:1674
AVChannelLayout::order
enum AVChannelOrder order
Channel order used in this layout.
Definition: channel_layout.h:295
AVChannelLayout::mask
uint64_t mask
This member must be used for AV_CHANNEL_ORDER_NATIVE, and may be used for AV_CHANNEL_ORDER_AMBISONIC ...
Definition: channel_layout.h:322
AVChannelLayout::nb_channels
int nb_channels
Number of channels in this layout.
Definition: channel_layout.h:300
AVCodecContext::delay
int delay
Codec delay.
Definition: avcodec.h:545
av_channel_layout_copy
int av_channel_layout_copy(AVChannelLayout *dst, const AVChannelLayout *src)
Make a copy of a channel layout.
Definition: channel_layout.c:637
AVCodecParameters::color_primaries
enum AVColorPrimaries color_primaries
Definition: codec_par.h:148
AVCodecContext::ch_layout
AVChannelLayout ch_layout
Audio channel layout.
Definition: avcodec.h:2056
AVCodecParameters::bits_per_raw_sample
int bits_per_raw_sample
This is the number of valid bits in each output sample.
Definition: codec_par.h:116
AVCodecContext::initial_padding
int initial_padding
Audio only.
Definition: avcodec.h:1723
AVCodecParameters::color_trc
enum AVColorTransferCharacteristic color_trc
Definition: codec_par.h:149
AVCodecContext::color_primaries
enum AVColorPrimaries color_primaries
Chromaticity coordinates of the source primaries.
Definition: avcodec.h:952
AV_CHANNEL_ORDER_NATIVE
@ AV_CHANNEL_ORDER_NATIVE
The native channel order, i.e.
Definition: channel_layout.h:112
AVCodecParameters::frame_size
int frame_size
Audio only.
Definition: codec_par.h:188
AVCodecContext::extradata_size
int extradata_size
Definition: avcodec.h:491
AVCodecContext::has_b_frames
int has_b_frames
Size of the frame reordering buffer in the decoder.
Definition: avcodec.h:685
AVCodecParameters::sample_aspect_ratio
AVRational sample_aspect_ratio
Video only.
Definition: codec_par.h:137
AV_CHANNEL_ORDER_UNSPEC
@ AV_CHANNEL_ORDER_UNSPEC
Only the channel count is specified, without any further information about the channel order.
Definition: channel_layout.h:106
AVMEDIA_TYPE_AUDIO
@ AVMEDIA_TYPE_AUDIO
Definition: avutil.h:202
AVCodecParameters::width
int width
Video only.
Definition: codec_par.h:127
FF_PROFILE_UNKNOWN
#define FF_PROFILE_UNKNOWN
Definition: avcodec.h:1548
AV_FIELD_UNKNOWN
@ AV_FIELD_UNKNOWN
Definition: codec_par.h:38
AVCodecContext::bits_per_raw_sample
int bits_per_raw_sample
Bits per sample/pixel of internal libavcodec pixel/sample format.
Definition: avcodec.h:1448
AVCOL_PRI_UNSPECIFIED
@ AVCOL_PRI_UNSPECIFIED
Definition: pixfmt.h:474
AVCodecContext::codec_id
enum AVCodecID codec_id
Definition: avcodec.h:399
AVChannelLayout::u
union AVChannelLayout::@296 u
Details about which channels are present in this layout.
NULL
#define NULL
Definition: coverity.c:32
AVCodecContext::color_range
enum AVColorRange color_range
MPEG vs JPEG YUV range.
Definition: avcodec.h:973
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
AVCodecContext::bit_rate
int64_t bit_rate
the average bitrate
Definition: avcodec.h:439
AVCodecContext::trailing_padding
int trailing_padding
Audio only.
Definition: avcodec.h:1900
AVCodecParameters::ch_layout
AVChannelLayout ch_layout
Audio only.
Definition: codec_par.h:212
AVCodecContext::level
int level
level
Definition: avcodec.h:1673
AVCOL_RANGE_UNSPECIFIED
@ AVCOL_RANGE_UNSPECIFIED
Definition: pixfmt.h:565
AVCodecParameters::level
int level
Definition: codec_par.h:122
AVCodecParameters::sample_rate
int sample_rate
Audio only.
Definition: codec_par.h:177
av_channel_layout_uninit
void av_channel_layout_uninit(AVChannelLayout *channel_layout)
Free any allocated data in the channel layout and reset the channel count to 0.
Definition: channel_layout.c:630
AVCodecParameters::extradata_size
int extradata_size
Size of the extradata content in bytes.
Definition: codec_par.h:79
AVChannelLayout
An AVChannelLayout holds information about the channel layout of audio data.
Definition: channel_layout.h:290
AVCodecContext::sample_fmt
enum AVSampleFormat sample_fmt
audio sample format
Definition: avcodec.h:1014
AVCodecParameters::profile
int profile
Codec-specific bitstream restrictions that the stream conforms to.
Definition: codec_par.h:121
AVCHROMA_LOC_UNSPECIFIED
@ AVCHROMA_LOC_UNSPECIFIED
Definition: pixfmt.h:619
AVMEDIA_TYPE_UNKNOWN
@ AVMEDIA_TYPE_UNKNOWN
Usually treated as AVMEDIA_TYPE_DATA.
Definition: avutil.h:200
codec_parameters_reset
static void codec_parameters_reset(AVCodecParameters *par)
Definition: codec_par.c:31
avcodec_parameters_copy
int avcodec_parameters_copy(AVCodecParameters *dst, const AVCodecParameters *src)
Copy the contents of src to dst.
Definition: codec_par.c:74
AVCodecContext::bits_per_coded_sample
int bits_per_coded_sample
bits per sample/pixel from the demuxer (needed for huffyuv).
Definition: avcodec.h:1441
AV_CODEC_ID_NONE
@ AV_CODEC_ID_NONE
Definition: codec_id.h:48
AVCodecContext::extradata
uint8_t * extradata
some codecs need / can use extradata like Huffman tables.
Definition: avcodec.h:490
AVCodecParameters::height
int height
Definition: codec_par.h:128
avcodec_parameters_to_context
int avcodec_parameters_to_context(AVCodecContext *codec, const AVCodecParameters *par)
Fill the codec context based on the values from the supplied codec parameters.
Definition: codec_par.c:182
AVCodecParameters::block_align
int block_align
Audio only.
Definition: codec_par.h:184
av_mallocz
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
Definition: mem.c:264
avcodec_parameters_alloc
AVCodecParameters * avcodec_parameters_alloc(void)
Allocate a new AVCodecParameters and set its fields to default values (unknown/invalid/0).
Definition: codec_par.c:53
AVCodecContext::chroma_sample_location
enum AVChromaLocation chroma_sample_location
This defines the location of chroma samples.
Definition: avcodec.h:980
AVCodecParameters::color_range
enum AVColorRange color_range
Video only.
Definition: codec_par.h:147
AVCOL_SPC_UNSPECIFIED
@ AVCOL_SPC_UNSPECIFIED
Definition: pixfmt.h:528
AVCodecContext::height
int height
Definition: avcodec.h:562
AVCodecContext::pix_fmt
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
Definition: avcodec.h:599
AVCodecParameters::field_order
enum AVFieldOrder field_order
Video only.
Definition: codec_par.h:142
avcodec.h
av_channel_layout_from_mask
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.
Definition: channel_layout.c:389
ret
ret
Definition: filter_design.txt:187
AVCodecContext::block_align
int block_align
number of bytes per packet if constant and known or 0 Used by some WAV based audio codecs.
Definition: avcodec.h:1043
AV_INPUT_BUFFER_PADDING_SIZE
#define AV_INPUT_BUFFER_PADDING_SIZE
Definition: defs.h:40
AVCodecParameters::chroma_location
enum AVChromaLocation chroma_location
Definition: codec_par.h:151
AVCodecParameters::trailing_padding
int trailing_padding
Audio only.
Definition: codec_par.h:203
AVCodecContext
main external API structure.
Definition: avcodec.h:389
AVCodecContext::profile
int profile
profile
Definition: avcodec.h:1547
FF_DISABLE_DEPRECATION_WARNINGS
#define FF_DISABLE_DEPRECATION_WARNINGS
Definition: internal.h:82
AVCodecContext::codec_type
enum AVMediaType codec_type
Definition: avcodec.h:397
AVCodecContext::seek_preroll
int seek_preroll
Number of samples to skip after a discontinuity.
Definition: avcodec.h:1803
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
AVCodecParameters::bits_per_coded_sample
int bits_per_coded_sample
The number of bits per sample in the codedwords.
Definition: codec_par.h:103
mem.h
AVCodecParameters::video_delay
int video_delay
Video only.
Definition: codec_par.h:156
AVCodecParameters::format
int format
Definition: codec_par.h:85
AVCodecContext::codec_tag
unsigned int codec_tag
fourcc (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A').
Definition: avcodec.h:414
codec_par.h
AVCodecParameters::codec_id
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
Definition: codec_par.h:61
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:34
src
INIT_CLIP pixel * src
Definition: h264pred_template.c:418
AVCodecContext::width
int width
picture width / height.
Definition: avcodec.h:562
AVCodecParameters::bit_rate
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
Definition: codec_par.h:90
AVCodecParameters::initial_padding
int initial_padding
Audio only.
Definition: codec_par.h:196
AVCodecContext::sample_aspect_ratio
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown) That is the width of a pixel divided by the height of the pixel.
Definition: avcodec.h:759