33 #define X264_API_IMPORTS 1 99 static const int level_map[] = {
106 if (level < 0 || level > X264_LOG_DEBUG)
109 av_vlog(p, level_map[level], fmt, args);
114 const x264_nal_t *nals,
int nnal)
123 for (i = 0; i < nnal; i++)
124 size += nals[i].i_payload;
143 for (i = 0; i < nnal; i++){
144 memcpy(p, nals[i].p_payload, nals[i].i_payload);
145 p += nals[i].i_payload;
181 x264_encoder_reconfig(x4->
enc, &x4->
params);
186 x264_encoder_reconfig(x4->
enc, &x4->
params);
193 x264_encoder_reconfig(x4->
enc, &x4->
params);
196 if (x4->
params.rc.i_rc_method == X264_RC_ABR &&
199 x264_encoder_reconfig(x4->
enc, &x4->
params);
203 x4->
params.rc.i_rc_method == X264_RC_CRF &&
204 x4->
params.rc.f_rf_constant != x4->
crf) {
206 x264_encoder_reconfig(x4->
enc, &x4->
params);
209 if (x4->
params.rc.i_rc_method == X264_RC_CQP &&
211 x4->
params.rc.i_qp_constant != x4->
cqp) {
213 x264_encoder_reconfig(x4->
enc, &x4->
params);
219 x264_encoder_reconfig(x4->
enc, &x4->
params);
228 switch (stereo->
type) {
247 #if X264_BUILD >= 145 260 "Ignoring unsupported inverted stereo value %d\n", fpa_type);
264 if (fpa_type != x4->
params.i_frame_packing) {
265 x4->
params.i_frame_packing = fpa_type;
266 x264_encoder_reconfig(x4->
enc, &x4->
params);
277 x264_picture_t pic_out = {0};
280 x264_picture_init( &x4->
pic );
282 #if X264_BUILD >= 153 283 if (x4->
params.i_bitdepth > 8)
285 if (x264_bit_depth > 8)
287 x4->
pic.img.i_csp |= X264_CSP_HIGH_DEPTH;
291 for (i = 0; i < x4->
pic.img.i_plane; i++) {
292 x4->
pic.img.plane[i] = frame->
data[i];
296 x4->
pic.i_pts = frame->
pts;
301 : X264_TYPE_KEYFRAME;
304 x4->
pic.i_type = X264_TYPE_P;
307 x4->
pic.i_type = X264_TYPE_B;
310 x4->
pic.i_type = X264_TYPE_AUTO;
322 }
else if (sei_data) {
323 x4->
pic.extra_sei.payloads =
av_mallocz(
sizeof(x4->
pic.extra_sei.payloads[0]));
324 if (x4->
pic.extra_sei.payloads ==
NULL) {
330 x4->
pic.extra_sei.payloads[0].payload_size =
sei_size;
331 x4->
pic.extra_sei.payloads[0].payload = sei_data;
332 x4->
pic.extra_sei.num_payloads = 1;
333 x4->
pic.extra_sei.payloads[0].payload_type = 4;
340 if (x264_encoder_encode(x4->
enc, &nal, &nnal, frame? &x4->
pic:
NULL, &pic_out) < 0)
346 }
while (!ret && !frame && x264_encoder_delayed_frames(x4->
enc));
348 pkt->
pts = pic_out.i_pts;
349 pkt->
dts = pic_out.i_dts;
352 switch (pic_out.i_type) {
367 #if FF_API_CODED_FRAME 377 #if FF_API_CODED_FRAME 396 x264_encoder_close(x4->
enc);
403 #define OPT_STR(opt, param) \ 406 if ((ret = x264_param_parse(&x4->params, opt, param)) < 0) { \ 407 if(ret == X264_PARAM_BAD_NAME) \ 408 av_log(avctx, AV_LOG_ERROR, \ 409 "bad option '%s': '%s'\n", opt, param); \ 411 av_log(avctx, AV_LOG_ERROR, \ 412 "bad value for '%s': '%s'\n", opt, param); \ 431 #if CONFIG_LIBX264RGB_ENCODER 433 return X264_CSP_BGRA;
450 #define PARSE_X264_OPT(name, var)\ 451 if (x4->var && x264_param_parse(&x4->params, name, x4->var) < 0) {\ 452 av_log(avctx, AV_LOG_ERROR, "Error parsing option '%s' with value '%s'.\n", name, x4->var);\ 453 return AVERROR(EINVAL);\ 465 #if CONFIG_LIBX262_ENCODER 468 x264_param_default_mpeg2(&x4->
params);
471 x264_param_default(&x4->
params);
480 for (i = 0; x264_preset_names[i]; i++)
484 for (i = 0; x264_tune_names[i]; i++)
490 if (avctx->
level > 0)
494 x4->
params.p_log_private = avctx;
495 x4->
params.i_log_level = X264_LOG_DEBUG;
497 #if X264_BUILD >= 153 505 x4->
params.rc.i_rc_method = X264_RC_ABR;
511 x4->
params.rc.b_stat_read = 1;
514 x4->
params.rc.i_rc_method = X264_RC_CRF;
516 }
else if (x4->
cqp >= 0) {
517 x4->
params.rc.i_rc_method = X264_RC_CQP;
527 x4->
params.rc.f_vbv_buffer_init =
538 #if FF_API_PRIVATE_OPT 552 #if FF_API_PRIVATE_OPT 561 if (avctx->
qmin >= 0)
563 if (avctx->
qmax >= 0)
567 if (avctx->
qblur >= 0)
571 if (avctx->
refs >= 0)
573 else if (x4->
level) {
578 int scale = X264_BUILD < 129 ? 384 : 1;
580 if (!strcmp(x4->
level,
"1b")) {
582 }
else if (strlen(x4->
level) <= 3){
590 for (i = 0; i<x264_levels[i].level_idc; i++)
591 if (x264_levels[i].level_idc == level_id)
592 x4->
params.i_frame_reference = av_clip(x264_levels[i].dpb / mbn / scale, 1, x4->
params.i_frame_reference);
599 #if FF_API_PRIVATE_OPT 609 #if FF_API_PRIVATE_OPT 617 #if FF_API_CODER_TYPE 651 x4->
params.b_vfr_input = 0;
654 #if X264_BUILD >= 142 658 "x264 too old for AVC Intra, at least version 142 needed\n");
660 if (x4->
b_bias != INT_MIN)
681 x264_param_apply_fastfirstpass(&x4->
params);
721 if (x264_param_apply_profile(&x4->
params, x4->
profile) < 0) {
725 for (i = 0; x264_profile_names[i]; i++)
734 x4->
params.vui.i_sar_width = sw;
735 x4->
params.vui.i_sar_height = sh;
766 x4->
params.b_repeat_headers = 0;
771 char param[4096]={0},
val[4096]={0};
772 if(sscanf(p,
"%4095[^:=]=%4095[^:]", param,
val) == 1){
789 "Error parsing option '%s = %s'.\n",
799 x4->
params.i_bframe_pyramid ? 2 : 1 : 0;
805 x4->
enc = x264_encoder_open(&x4->
params);
814 s = x264_encoder_headers(x4->
enc, &nal, &nnal);
819 for (i = 0; i < nnal; i++) {
821 if (nal[i].i_type == NAL_SEI) {
827 memcpy(x4->
sei, nal[i].p_payload, nal[i].i_payload);
830 memcpy(p, nal[i].p_payload, nal[i].i_payload);
831 p += nal[i].i_payload;
890 #if CONFIG_LIBX264RGB_ENCODER 902 if (x264_bit_depth == 8)
904 else if (x264_bit_depth == 9)
906 else if (x264_bit_depth == 10)
913 #define OFFSET(x) offsetof(X264Context, x) 914 #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM 926 {
"crf_max",
"In CRF mode, prevents VBV from lowering quality beyond this point.",
OFFSET(
crf_max),
AV_OPT_TYPE_FLOAT, {.dbl = -1 }, -1, FLT_MAX, VE },
927 {
"qp",
"Constant quantization parameter rate control method",
OFFSET(
cqp),
AV_OPT_TYPE_INT, { .i64 = -1 }, -1, INT_MAX, VE },
930 {
"variance",
"Variance AQ (complexity mask)", 0,
AV_OPT_TYPE_CONST, {.i64 = X264_AQ_VARIANCE}, INT_MIN, INT_MAX,
VE,
"aq_mode" },
931 {
"autovariance",
"Auto-variance AQ", 0,
AV_OPT_TYPE_CONST, {.i64 = X264_AQ_AUTOVARIANCE}, INT_MIN, INT_MAX,
VE,
"aq_mode" },
932 #if X264_BUILD >= 144 933 {
"autovariance-biased",
"Auto-variance AQ with bias to dark scenes", 0,
AV_OPT_TYPE_CONST, {.i64 = X264_AQ_AUTOVARIANCE_BIASED}, INT_MIN, INT_MAX,
VE,
"aq_mode" },
950 {
"strict",
"Strictly hierarchical pyramid", 0,
AV_OPT_TYPE_CONST, {.i64 = X264_B_PYRAMID_STRICT}, INT_MIN, INT_MAX,
VE,
"b_pyramid" },
951 {
"normal",
"Non-strict (not Blu-ray compatible)", 0,
AV_OPT_TYPE_CONST, {.i64 = X264_B_PYRAMID_NORMAL}, INT_MIN, INT_MAX,
VE,
"b_pyramid" },
959 {
"partitions",
"A comma-separated list of partitions to consider. " 960 "Possible values: p8x8, p4x4, b8x8, i8x8, i4x4, none, all",
OFFSET(
partitions),
AV_OPT_TYPE_STRING, { 0 }, 0, 0, VE},
968 {
"nal-hrd",
"Signal HRD information (requires vbv-bufsize; " 1002 {
"i_qfactor",
"-1" },
1003 {
"b_qfactor",
"-1" },
1011 #if FF_API_PRIVATE_OPT 1012 {
"sc_threshold",
"-1" },
1014 {
"trellis",
"-1" },
1015 #if FF_API_PRIVATE_OPT 1018 {
"me_range",
"-1" },
1020 #if FF_API_PRIVATE_OPT 1021 {
"b_strategy",
"-1" },
1023 {
"keyint_min",
"-1" },
1024 #if FF_API_CODER_TYPE 1029 {
"thread_type",
"0" },
1030 {
"flags",
"+cgop" },
1031 {
"rc_init_occupancy",
"-1" },
1035 #if CONFIG_LIBX264_ENCODER 1036 static const AVClass x264_class = {
1053 .priv_class = &x264_class,
1058 .wrapper_name =
"libx264",
1062 #if CONFIG_LIBX264RGB_ENCODER 1063 static const AVClass rgbclass = {
1071 .
name =
"libx264rgb",
1080 .priv_class = &rgbclass,
1083 .wrapper_name =
"libx264",
1087 #if CONFIG_LIBX262_ENCODER 1088 static const AVClass X262_class = {
1105 .priv_class = &X262_class,
1110 .wrapper_name =
"libx264",
#define FF_CODEC_CAP_INIT_CLEANUP
The codec allows calling the close function for deallocation even if the init function returned a fai...
#define FF_PROFILE_H264_MAIN
#define AV_STEREO3D_FLAG_INVERT
Inverted views, Right/Bottom represents the left view.
static int convert_pix_fmt(enum AVPixelFormat pix_fmt)
const char const char void * val
static enum AVPixelFormat pix_fmt
static int avfmt2_num_planes(int avfmt)
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
This structure describes decoded (raw) audio or video data.
int ff_side_data_set_encoder_stats(AVPacket *pkt, int quality, int64_t *error, int error_count, int pict_type)
#define AV_CODEC_FLAG_INTERLACED_DCT
Use interlaced DCT.
#define AV_CODEC_FLAG_LOOP_FILTER
loop filter.
float qblur
amount of qscale smoothing over time (0.0-1.0)
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
#define AV_LOG_WARNING
Something somehow does not look correct.
int64_t bit_rate
the average bitrate
#define LIBAVUTIL_VERSION_INT
packed RGB 8:8:8, 24bpp, RGBRGB...
Memory handling functions.
static av_cold int init(AVCodecContext *avctx)
int max_bitrate
Maximum bitrate of the stream, in bits per second.
int max_b_frames
maximum number of B-frames between non-B-frames Note: The output will be delayed by max_b_frames+1 re...
AVCodec ff_libx262_encoder
int rc_initial_buffer_occupancy
Number of bits which should be loaded into the rc buffer before decoding starts.
enum AVColorRange color_range
MPEG vs JPEG YUV range.
const char * av_default_item_name(void *ptr)
Return the context name.
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown) That is the width of a pixel divided by the height of the pixel...
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
static void X264_log(void *p, int level, const char *fmt, va_list args)
Views are next to each other.
#define AV_CODEC_CAP_AUTO_THREADS
Codec supports avctx->thread_count == 0 (auto).
static av_cold int X264_init(AVCodecContext *avctx)
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented...
AVFrameSideData * av_frame_get_side_data(const AVFrame *frame, enum AVFrameSideDataType type)
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
#define AV_CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
int ff_alloc_packet2(AVCodecContext *avctx, AVPacket *avpkt, int64_t size, int64_t min_size)
Check AVPacket size and/or allocate data.
#define FF_PROFILE_H264_BASELINE
#define FF_CODEC_CAP_INIT_THREADSAFE
The codec does not modify any global variables in the init function, allowing to call the init functi...
AVComponentDescriptor comp[4]
Parameters that describe how pixels are packed.
Stereo 3D type: this structure describes how two videos are packed within a single video surface...
int me_range
maximum motion estimation search range in subpel units If 0 then no limit.
float b_quant_factor
qscale factor between IP and B-frames If > 0 then the last P-frame quantizer will be used (q= lastp_q...
int64_t pts
Presentation timestamp in time_base units (time when frame should be shown to user).
uint8_t * extradata
some codecs need / can use extradata like Huffman tables.
int me_cmp
motion estimation comparison function
Structure to hold side data for an AVFrame.
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
planar YUV 4:2:2, 16bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV422P and setting col...
Video is not stereoscopic (and metadata has to be there).
int buffer_size
The size of the buffer to which the ratecontrol is applied, in bits.
int av_reduce(int *dst_num, int *dst_den, int64_t num, int64_t den, int64_t max)
Reduce a fraction.
static enum AVPixelFormat pix_fmts_all[]
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
static enum AVPixelFormat pix_fmts_10bit[]
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
int has_b_frames
Size of the frame reordering buffer in the decoder.
int flags
Additional information about the frame packing.
int qmax
maximum quantizer
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
Views are packed per line, as if interlaced.
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values. ...
#define FF_PROFILE_H264_HIGH_422
#define FF_PROFILE_H264_HIGH
int flags
AV_CODEC_FLAG_*.
planar YUV 4:2:0, 12bpp, 1 plane for Y and 1 plane for the UV components, which are interleaved (firs...
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
const char * name
Name of the codec implementation.
float i_quant_factor
qscale factor between P- and I-frames If > 0 then the last P-frame quantizer will be used (q = lastp_...
#define AV_PIX_FMT_YUV444P10
static const AVCodecDefault defaults[]
int flags
A combination of AV_PKT_FLAG values.
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
int rc_buffer_size
decoder bitstream buffer size
Views are alternated temporally.
common internal API header
as above, but U and V bytes are swapped
int refs
number of reference frames
static enum AVPixelFormat pix_fmts_9bit[]
#define PARSE_X264_OPT(name, var)
enum AVPixelFormat * pix_fmts
array of supported pixel formats, or NULL if unknown, array is terminated by -1
enum AVPictureType pict_type
Picture type of the frame.
#define OPT_STR(opt, param)
planar YUV 4:2:0, 12bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV420P and setting col...
int width
picture width / height.
attribute_deprecated int noise_reduction
const char AVS_Value args
#define AV_CODEC_FLAG_PSNR
error[?] variables will be set during encoding.
#define AV_CODEC_FLAG_PASS1
Use internal 2pass ratecontrol in first pass mode.
enum AVColorPrimaries color_primaries
Chromaticity coordinates of the source primaries.
#define FF_THREAD_SLICE
Decode more than one part of a single frame at once.
int quality
quality (between 1 (good) and FF_LAMBDA_MAX (bad))
int scenechange_threshold
int ticks_per_frame
For some codecs, the time base is closer to the field rate than the frame rate.
packed RGB 8:8:8, 24bpp, BGRBGR...
int max_qdiff
maximum quantizer difference between frames
#define AV_PIX_FMT_YUV444P9
attribute_deprecated int coder_type
preferred ID for MPEG-1/2 video decoding
int thread_count
thread count is used to decide how many independent tasks should be passed to execute() ...
the normal 2^n-1 "JPEG" YUV ranges
static enum AVPixelFormat pix_fmts_8bit[]
static const AVCodecDefault x264_defaults[]
double av_strtod(const char *numstr, char **tail)
Parse the string in numstr and return its value as a double.
int av_dict_parse_string(AVDictionary **pm, const char *str, const char *key_val_sep, const char *pairs_sep, int flags)
Parse the key/value pairs list and add the parsed entries to a dictionary.
This structure describes the bitrate properties of an encoded bitstream.
enum AVStereo3DType type
How views are packed within the video.
#define AV_LOG_INFO
Standard information.
Views are packed in a checkerboard-like structure per pixel.
char * av_strdup(const char *s)
Duplicate a string.
Libavcodec external API header.
Views are on top of each other.
static av_cold int X264_close(AVCodecContext *avctx)
attribute_deprecated int scenechange_threshold
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
attribute_deprecated int b_frame_strategy
main external API structure.
static const AVOption options[]
int qmin
minimum quantizer
#define AV_PIX_FMT_YUV420P10
Describe the class of an AVClass context structure.
enum AVColorSpace colorspace
YUV colorspace type.
enum AVColorTransferCharacteristic color_trc
Color Transfer Characteristic.
void av_vlog(void *avcl, int level, const char *fmt, va_list vl)
Send the specified message to the log if the level is less than or equal to the current av_log_level...
static int encode_nals(AVCodecContext *ctx, AVPacket *pkt, const x264_nal_t *nals, int nnal)
packed BGR 8:8:8, 32bpp, BGRXBGRX... X=unused/undefined
#define FF_PROFILE_H264_HIGH_444
#define AV_PIX_FMT_YUV420P9
attribute_deprecated int chromaoffset
float qcompress
amount of qscale change between easy & hard scenes (0.0-1.0)
static void reconfig_encoder(AVCodecContext *ctx, const AVFrame *frame)
static enum AVPixelFormat pix_fmts[]
int global_quality
Global quality for codecs which cannot change it per frame.
#define AV_PIX_FMT_YUV422P10
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
#define AV_CODEC_FLAG_GLOBAL_HEADER
Place global headers in extradata instead of every keyframe.
int gop_size
the number of pictures in a group of pictures, or 0 for intra_only
static av_cold void X264_init_static(AVCodec *codec)
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
#define FF_DISABLE_DEPRECATION_WARNINGS
common internal api header.
planar YUV 4:4:4, 24bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV444P and setting col...
attribute_deprecated AVFrame * coded_frame
the picture in the bitstream
Views are packed per column.
interleaved chroma YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
int trellis
trellis RD quantization
AVCPBProperties * ff_add_cpb_side_data(AVCodecContext *avctx)
Add a CPB properties side data to an encoding context.
#define AV_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
#define AV_CODEC_FLAG_PASS2
Use internal 2pass ratecontrol in second pass mode.
int slices
Number of slices.
#define FF_ENABLE_DEPRECATION_WARNINGS
int top_field_first
If the content is interlaced, is top field displayed first.
int avg_bitrate
Average bitrate of the stream, in bits per second.
AVCodec ff_libx264rgb_encoder
#define FF_QP2LAMBDA
factor to convert from H.263 QP to lambda
AVCodec ff_libx264_encoder
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed...
int ff_alloc_a53_sei(const AVFrame *frame, size_t prefix_len, void **data, size_t *sei_size)
Check AVFrame for A53 side data and allocate and fill SEI message with A53 info.
#define AV_DICT_IGNORE_SUFFIX
Return first entry in a dictionary whose first part corresponds to the search key, ignoring the suffix of the found key string.
static int X264_frame(AVCodecContext *ctx, AVPacket *pkt, const AVFrame *frame, int *got_packet)
#define AV_CODEC_FLAG_CLOSED_GOP
int depth
Number of bits in the component.
#define FF_PROFILE_H264_HIGH_10
Stereoscopic 3d metadata.
#define AVERROR_EXTERNAL
Generic error in an external library.
AVPixelFormat
Pixel format.
This structure stores compressed data.
int me_subpel_quality
subpel ME quality
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
int thread_type
Which multithreading methods to use.
int64_t rc_max_rate
maximum bitrate
simple arithmetic expression evaluator
#define AV_CEIL_RSHIFT(a, b)
int keyint_min
minimum GOP size