X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=x264.h;h=9b6d8f41d2e527e6d9ba141a3de738b24f3ab0ec;hb=001d30598c75d9bbc3aa80f67f9bdac17692437d;hp=3d574ecb62de9cba1facb9168ab57f22a9ce3ff3;hpb=627f891c571cacb51deb5e211b23c309b14a6587;p=x264 diff --git a/x264.h b/x264.h index 3d574ecb..9b6d8f41 100644 --- a/x264.h +++ b/x264.h @@ -28,6 +28,10 @@ #ifndef X264_X264_H #define X264_X264_H +#ifdef __cplusplus +extern "C" { +#endif + #if !defined(_STDINT_H) && !defined(_STDINT_H_) && !defined(_STDINT_H_INCLUDED) && !defined(_STDINT) &&\ !defined(_SYS_STDINT_H_) && !defined(_INTTYPES_H) && !defined(_INTTYPES_H_) && !defined(_INTTYPES) # ifdef _MSC_VER @@ -41,7 +45,7 @@ #include "x264_config.h" -#define X264_BUILD 147 +#define X264_BUILD 148 /* Application developers planning to link against a shared library version of * libx264 from a Microsoft Visual Studio or similar development environment @@ -90,7 +94,7 @@ enum nal_priority_e * All data returned in an x264_nal_t, including the data in p_payload, is no longer * valid after the next call to x264_encoder_encode. Thus it must be used or copied * before calling x264_encoder_encode or x264_encoder_headers again. */ -typedef struct +typedef struct x264_nal_t { int i_ref_idc; /* nal_priority_e */ int i_type; /* nal_unit_type_e */ @@ -158,6 +162,9 @@ typedef struct #define X264_CPU_FAST_NEON_MRC 0x0000004 /* Transfer from NEON to ARM register is fast (Cortex-A9) */ #define X264_CPU_ARMV8 0x0000008 +/* MIPS */ +#define X264_CPU_MSA 0x0000001 /* MIPS MSA */ + /* Analyse flags */ #define X264_ANALYSE_I4x4 0x0001 /* Analyse i4x4 */ #define X264_ANALYSE_I8x8 0x0002 /* Analyse i8x8 (requires 8x8 transform) */ @@ -236,7 +243,7 @@ static const char * const x264_nal_hrd_names[] = { "none", "vbr", "cbr", 0 }; #define X264_TYPE_BREF 0x0004 /* Non-disposable B-frame */ #define X264_TYPE_B 0x0005 #define X264_TYPE_KEYFRAME 0x0006 /* IDR or I depending on b_open_gop option */ -#define IS_X264_TYPE_I(x) ((x)==X264_TYPE_I || (x)==X264_TYPE_IDR) +#define IS_X264_TYPE_I(x) ((x)==X264_TYPE_I || (x)==X264_TYPE_IDR || (x)==X264_TYPE_KEYFRAME) #define IS_X264_TYPE_B(x) ((x)==X264_TYPE_B || (x)==X264_TYPE_BREF) /* Log level */ @@ -258,7 +265,7 @@ static const char * const x264_nal_hrd_names[] = { "none", "vbr", "cbr", 0 }; /* Zones: override ratecontrol or other options for specific sections of the video. * See x264_encoder_reconfig() for which options can be changed. * If zones overlap, whichever comes later in the list takes precedence. */ -typedef struct +typedef struct x264_zone_t { int i_start, i_end; /* range of frame numbers */ int b_force_qp; /* whether to use qp vs bitrate factor */ @@ -552,7 +559,7 @@ void x264_nal_encode( x264_t *h, uint8_t *dst, x264_nal_t *nal ); * H.264 level restriction information ****************************************************************************/ -typedef struct +typedef struct x264_level_t { int level_idc; int mbps; /* max macroblock processing rate (macroblocks/sec) */ @@ -689,7 +696,7 @@ enum pic_struct_e PIC_STRUCT_TRIPLE = 9, // triple frame }; -typedef struct +typedef struct x264_hrd_t { double cpb_initial_arrival_time; double cpb_final_arrival_time; @@ -707,14 +714,14 @@ typedef struct * Payloads are written first in order of input, apart from in the case when HRD * is enabled where payloads are written after the Buffering Period SEI. */ -typedef struct +typedef struct x264_sei_payload_t { int payload_size; int payload_type; uint8_t *payload; } x264_sei_payload_t; -typedef struct +typedef struct x264_sei_t { int num_payloads; x264_sei_payload_t *payloads; @@ -722,7 +729,7 @@ typedef struct void (*sei_free)( void* ); } x264_sei_t; -typedef struct +typedef struct x264_image_t { int i_csp; /* Colorspace */ int i_plane; /* Number of image planes */ @@ -730,7 +737,7 @@ typedef struct uint8_t *plane[4]; /* Pointers to each plane */ } x264_image_t; -typedef struct +typedef struct x264_image_properties_t { /* All arrays of data here are ordered as follows: * each array contains one offset per macroblock, in raster scan order. In interlaced @@ -786,13 +793,11 @@ typedef struct double f_crf_avg; } x264_image_properties_t; -typedef struct +typedef struct x264_picture_t { /* In: force picture type (if not auto) * If x264 encoding parameters are violated in the forcing of picture types, * x264 will correct the input picture type and log a warning. - * The quality of frametype decisions may suffer if a great deal of fine-grained - * mixing of auto and forced frametypes is done. * Out: type of the picture encoded */ int i_type; /* In: force quantizer for != X264_QP_AUTO */ @@ -947,4 +952,8 @@ void x264_encoder_intra_refresh( x264_t * ); * Returns 0 on success, negative on failure. */ int x264_encoder_invalidate_reference( x264_t *, int64_t pts ); +#ifdef __cplusplus +} +#endif + #endif