Go to the documentation of this file.
   41      [1] = {1280*720*24,    1280,  20,  50},
 
   42      [2] = {1280*720*30,    1280,  20,  50},
 
   43      [3] = {1920*1080*24,   1920,  20,  70},
 
   44      [4] = {1920*1080*30,   2560,  20,  70},
 
   45      [5] = {1920*1080*60,   3840,  20,  70},
 
   46      [6] = {3840*2160*24,   3840,  25, 130},
 
   47      [7] = {3840*2160*30,   3840,  25, 130},
 
   48      [8] = {3840*2160*48,   3840,  40, 130},
 
   49      [9] = {3840*2160*60,   3840,  40, 130},
 
   50     [10] = {3840*2160*120,  3840,  60, 240},
 
   51     [11] = {3840*2160*120,  7680,  60, 240},
 
   52     [12] = {7680*4320*60,   7680, 120, 450},
 
   53     [13] = {7680*4320*120
u, 7680, 240, 800},
 
   59                                       int strict_std_compliance,
 
   67                                       int *nb_coded_side_data)
 
   71     int dv_profile, dv_level, bl_compat_id = -1;
 
  106         av_unreachable(
"ff_dovi_configure only used with AV1, H.264 and HEVC");
 
  110         if (dv_profile == 9) {
 
  119     switch (dv_profile) {
 
  124                    "layers is currently unsupported.");
 
  156     if (!dv_profile || bl_compat_id < 0) {
 
  159                    "not determine profile and compatibility mode. Double-check " 
  160                    "colorspace and format settings for compatibility?\n");
 
  169                    "is not permitted for profiles 7 and earlier. (dv_profile: %d, " 
  170                    "compression: %d)\n", dv_profile, compression);
 
  175                    "compression is experimental and not supported by " 
  178         } 
else if (dv_profile == 8) {
 
  180                    "for profile 8 is known to be unsupported by many devices, " 
  181                    "use with caution.\n");
 
  209                    "exceed Dolby Vision limitations\n", 
pps, 
width);
 
  213                    "exceed Dolby Vision limitations. Ignoring, resulting file " 
  214                    "may be non-conforming.\n", 
pps, 
width);
 
  251                                             int strict_std_compliance)
 
  315             if (!memcmp(&ext->
dm_static[j], dm, 
sizeof(*dm))) {
 
  337     union { uint32_t u32; 
float f32; } fpart;
 
  355     union { uint32_t u32; 
float f32; } fpart;
 
  372     if (!q.
den || q.
den == den)
 
  380     int ext_block_length, start_pos, pad_bits;
 
  383     case 1:   ext_block_length = 5;  
break;
 
  384     case 2:   ext_block_length = 11; 
break;
 
  385     case 4:   ext_block_length = 3;  
break;
 
  386     case 5:   ext_block_length = 7;  
break;
 
  387     case 6:   ext_block_length = 8;  
break;
 
  388     case 255: ext_block_length = 6;  
break;
 
  430         for (
int i = 0; 
i < 4; 
i++)
 
  435     pad_bits = ext_block_length * 8 - (
put_bits_count(pb) - start_pos);
 
  442     const int denom = 32767;
 
  447 #define ANY6(arr) (arr[0] || arr[1] || arr[2] || arr[3] || arr[4] || arr[5]) 
  448 #define ANY_XY(xy) (xy.x.num || xy.y.num) 
  449 #define ANY_CSP(csp) (ANY_XY(csp.prim.r) || ANY_XY(csp.prim.g) || \ 
  450                       ANY_XY(csp.prim.b) || ANY_XY(csp.wp)) 
  454     int ext_block_length, start_pos, pad_bits;
 
  457     case 3: ext_block_length = 5; 
break;
 
  460             ext_block_length = 25;
 
  462             ext_block_length = 19;
 
  464             ext_block_length = 13;
 
  466             ext_block_length = 12;
 
  468             ext_block_length = 10;
 
  473             ext_block_length = 17;
 
  475             ext_block_length = 1;
 
  480             ext_block_length = 21;
 
  482             ext_block_length = 5;
 
  485     case 11:  ext_block_length = 4; 
break;
 
  486     case 254: ext_block_length = 2; 
break;
 
  508         if (ext_block_length < 12)
 
  511         if (ext_block_length < 13)
 
  514         if (ext_block_length < 19)
 
  516         for (
int i = 0; 
i < 6; 
i++)
 
  518         if (ext_block_length < 25)
 
  520         for (
int i = 0; 
i < 6; 
i++)
 
  525         if (ext_block_length < 17)
 
  537         if (ext_block_length < 21)
 
  562     pad_bits = ext_block_length * 8 - (
put_bits_count(pb) - start_pos);
 
  574     int vdr_dm_metadata_present, vdr_rpu_id, use_prev_vdr_rpu, 
profile,
 
  575         buffer_size, rpu_size, pad, zero_run, dm_compression;
 
  576     int num_ext_blocks_v1, num_ext_blocks_v2;
 
  577     int dv_md_compression = 
s->cfg.dv_md_compression;
 
  606     use_prev_vdr_rpu = 0;
 
  608     if (!
s->vdr[vdr_rpu_id]) {
 
  610         if (!
s->vdr[vdr_rpu_id])
 
  614     switch (dv_md_compression) {
 
  621         if (
s->vdr[vdr_rpu_id])
 
  622             use_prev_vdr_rpu = !memcmp(
s->vdr[vdr_rpu_id], mapping, 
sizeof(*mapping));
 
  637     if (
metadata->num_ext_blocks && !
s->ext_blocks) {
 
  645         vdr_dm_metadata_present = 1;
 
  647     if (vdr_dm_metadata_present && !
s->dm) {
 
  659     num_ext_blocks_v1 = num_ext_blocks_v2 = 0;
 
  660     for (
int i = 0; 
i < 
metadata->num_ext_blocks; 
i++) {
 
  689     buffer_size = 12  + 5 ;
 
  690     buffer_size += num_ext_blocks_v1 * 13;
 
  691     buffer_size += num_ext_blocks_v2 * 28;
 
  692     if (!use_prev_vdr_rpu) {
 
  694         for (
int c = 0; 
c < 3; 
c++) {
 
  703     if (vdr_dm_metadata_present)
 
  735     put_bits(pb, 1, vdr_dm_metadata_present);
 
  738     s->mapping = 
s->vdr[vdr_rpu_id];
 
  742     if (!use_prev_vdr_rpu) {
 
  745         for (
int c = 0; 
c < 3; 
c++) {
 
  764         for (
int c = 0; 
c < 3; 
c++) {
 
  780                     for (
int j = 0; j < curve->
mmr_order[
i]; j++) {
 
  781                         for (
int k = 0; k < 7; k++)
 
  791             for (
int c = 0; 
c < 3; 
c++) {
 
  804         memcpy(
s->vdr[vdr_rpu_id], mapping, 
sizeof(*mapping));
 
  807     if (vdr_dm_metadata_present) {
 
  809         const int denom = 
profile == 4 ? (1 << 30) : (1 << 28);
 
  813         if (!dm_compression) {
 
  814             for (
int i = 0; 
i < 9; 
i++)
 
  816             for (
int i = 0; 
i < 3; 
i++)
 
  818             for (
int i = 0; 
i < 9; 
i++)
 
  839         for (
int i = 0; 
i < 
metadata->num_ext_blocks; 
i++) {
 
  846         if (num_ext_blocks_v2) {
 
  849             for (
int i = 0; 
i < 
metadata->num_ext_blocks; 
i++) {
 
  862             for (
int i = 0; 
i < 
metadata->num_ext_blocks; 
i++) {
 
  866                 else if (!dm_compression)
 
  892         if (rpu_size > 0xFF) {
 
  894             put_bits(pb, 8, (rpu_size >> 8) - 1);
 
  916         for (
int i = 0; 
i < rpu_size; 
i++) {
 
  918                 if (
s->rpu_buf[
i] == 0) {
 
  924                 if ((
s->rpu_buf[
i] & ~3) == 0) {
 
  928                 zero_run = 
s->rpu_buf[
i] == 0;
 
  930             *
dst++ = 
s->rpu_buf[
i];
 
  936         *out_rpu = 
s->rpu_buf;
 
  
#define AV_LOG_WARNING
Something somehow does not look correct.
enum AVDOVINLQMethod nlq_method_idc
AVPixelFormat
Pixel format.
uint16_t trim_chroma_weight
uint8_t saturation_vector_field[6]
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
enum AVColorSpace colorspace
YUV colorspace type.
AVColorTransferCharacteristic
Color Transfer Characteristic.
static void align_put_bits(PutBitContext *s)
Pad the bitstream with zeros up to the next byte boundary.
AVFrameSideData ** decoded_side_data
Array containing static side data, such as HDR10 CLL / MDCV structures.
int ff_dovi_rpu_generate(DOVIContext *s, const AVDOVIMetadata *metadata, int flags, uint8_t **out_rpu, int *out_size)
Synthesize a Dolby Vision RPU reflecting the current state.
AVWhitepointCoefficients wp
static int put_bytes_output(const PutBitContext *s)
This struct describes the properties of an encoded stream.
enum AVColorSpace color_space
@ AV_FRAME_DATA_DOVI_METADATA
Parsed Dolby Vision metadata, suitable for passing to a software implementation.
AVPacketSideData * coded_side_data
Additional data associated with the entire coded stream.
static void put_sbits(PutBitContext *pb, int n, int32_t value)
static void init_put_bits(PutBitContext *s, uint8_t *buffer, int buffer_size)
Initialize the PutBitContext s.
AVColorPrimariesDesc source_display_primaries
uint16_t trim_saturation_gain
uint8_t frame_rate_conversion
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
enum AVColorTransferCharacteristic color_trc
Color Transfer Characteristic.
This structure stores auxiliary information for decoding, presenting, or otherwise processing the cod...
const AVDOVIColorMetadata ff_dovi_color_default
#define u(width, name, range_min, range_max)
int64_t mmr_coef[AV_DOVI_MAX_PIECES][3][7]
uint8_t target_primary_index
#define FF_COMPLIANCE_STRICT
Strictly conform to all the things in the spec no matter what consequences.
#define AV_PIX_FMT_YUV420P10
enum AVDOVIMappingMethod mapping_idc[AV_DOVI_MAX_PIECES]
AVRational framerate
Video only.
uint8_t target_display_index
static av_unused void put_bits32(PutBitContext *s, uint32_t value)
Write exactly 32 bits into a bitstream.
av_cold int ff_dovi_configure(DOVIContext *s, AVCodecContext *avctx)
Variant of ff_dovi_configure_from_codedpar which infers the codec parameters from an AVCodecContext.
#define FF_COMPLIANCE_EXPERIMENTAL
Allow nonstandardized experimental things.
AVColorPrimaries
Chromaticity coordinates of the source primaries.
uint8_t mapping_color_space
static av_cold int dovi_configure_ext(DOVIContext *s, enum AVCodecID codec_id, const AVDOVIMetadata *metadata, enum AVDOVICompression compression, int strict_std_compliance, int width, int height, AVRational framerate, enum AVPixelFormat pix_format, enum AVColorSpace color_space, enum AVColorPrimaries color_primaries, enum AVColorTransferCharacteristic color_trc, AVPacketSideData **coded_side_data, int *nb_coded_side_data)
uint8_t hue_vector_field[6]
@ FF_DOVI_WRAP_T35
wrap inside T.35+EMDF
@ AV_PKT_DATA_DOVI_CONF
DOVI configuration ref: dolby-vision-bitstreams-within-the-iso-base-media-file-format-v2....
enum AVColorPrimaries color_primaries
void ff_copy_bits(PutBitContext *pb, const uint8_t *src, int length)
Copy the content of src to the bitstream.
uint8_t reference_mode_flag
uint8_t dv_md_compression
#define FF_DOVI_AUTOMATIC
Enable tri-state.
static void generate_ext_v1(PutBitContext *pb, const AVDOVIDmData *dm)
static void * av_refstruct_allocz(size_t size)
Equivalent to av_refstruct_alloc_ext(size, 0, NULL, NULL)
enum AVColorTransferCharacteristic color_trc
Dolby Vision metadata extension block.
exp golomb vlc writing stuff
enum AVColorPrimaries color_primaries
Chromaticity coordinates of the source primaries.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
#define FF_ARRAY_ELEMS(a)
static const struct @118 dv_levels[]
uint8_t mmr_order[AV_DOVI_MAX_PIECES]
AVDOVIDmData dm_static[7]
static extension blocks
#define av_assert0(cond)
assert() equivalent, that is always enabled.
static void put_bits63(PutBitContext *s, int n, uint64_t value)
Write up to 63 bits into a bitstream.
@ AV_PIX_FMT_YUV420P
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
static void put_se_coef(PutBitContext *pb, const AVDOVIRpuDataHeader *hdr, uint64_t coef)
int nb_coded_side_data
Amount of entries in coded_side_data.
@ AVCOL_SPC_IPT_C2
SMPTE ST 2128, IPT-C2.
uint8_t poly_order[AV_DOVI_MAX_PIECES]
uint64_t linear_deadzone_threshold
uint16_t target_mid_contrast
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
uint8_t dv_bl_signal_compatibility_id
Rational number (pair of numerator and denominator).
#define av_unreachable(msg)
Asserts that are used as compiler optimization hints depending upon ASSERT_LEVEL and NBDEBUG.
@ AVCOL_PRI_BT709
also ITU-R BT1361 / IEC 61966-2-4 / SMPTE RP 177 Annex B
static void put_cie_xy(PutBitContext *pb, AVCIExy xy)
int64_t mmr_constant[AV_DOVI_MAX_PIECES]
uint8_t source_primary_index
Struct containing chromaticity x and y values for the standard CIE 1931 chromaticity definition.
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
AVCodecID
Identify the syntax and semantics of the bitstream.
@ AVCOL_PRI_BT2020
ITU-R BT2020.
static const AVColorPrimariesDesc color_primaries[AVCOL_PRI_NB]
@ AVCOL_TRC_SMPTE2084
SMPTE ST 2084 for 10-, 12-, 14- and 16-bit systems.
#define ITU_T_T35_PROVIDER_CODE_DOLBY
uint8_t target_display_index
static int av_q2den(AVRational q, int den)
AVColorPrimariesDesc target_display_primaries
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
static int try_reuse_ext(DOVIExt *ext, const AVDOVIMetadata *metadata)
uint16_t trim_saturation_gain
static const uint32_t color[16+AV_CLASS_CATEGORY_NB]
static AVRational av_make_q(int num, int den)
Create an AVRational.
uint16_t trim_chroma_weight
AVDOVIDmData dm_dynamic[25]
dynamic extension blocks
static void set_se_golomb(PutBitContext *pb, int i)
write signed exp golomb code.
int64_t poly_coef[AV_DOVI_MAX_PIECES][3]
const AVCRC * av_crc_get_table(AVCRCId crc_id)
Get an initialized standard CRC table.
AVPacketSideData * av_packet_side_data_add(AVPacketSideData **psd, int *pnb_sd, enum AVPacketSideDataType type, void *data, size_t size, int flags)
Wrap existing data as packet side data.
#define FF_COMPLIANCE_UNOFFICIAL
Allow unofficial extensions.
@ AVCOL_TRC_BT709
also ITU-R BT1361
void av_refstruct_unref(void *objp)
Decrement the reference count of the underlying object and automatically free the object if there are...
#define av_assert2(cond)
assert() equivalent, that does lie in speed critical code.
#define i(width, name, range_min, range_max)
static int put_bits_count(PutBitContext *s)
@ AVCOL_SPC_BT2020_NCL
ITU-R BT2020 non-constant luminance system.
AVColorSpace
YUV colorspace type.
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
uint32_t num_y_partitions
void av_fast_padded_malloc(void *ptr, unsigned int *size, size_t min_size)
Same behaviour av_fast_malloc but the buffer has additional AV_INPUT_BUFFER_PADDING_SIZE at the end w...
Coefficients of the non-linear inverse quantization.
AVPacketSideData * coded_side_data
Additional data associated with the entire stream.
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
@ FF_DOVI_COMPRESS_RPU
enable compression for this RPU
static void set_ue_golomb(PutBitContext *pb, int i)
write unsigned exp golomb code.
AVDOVIReshapingCurve curves[3]
uint64_t linear_deadzone_slope
static int av_cmp_q(AVRational a, AVRational b)
Compare two rationals.
static void generate_ext_v2(PutBitContext *pb, const AVDOVIDmData *dm)
uint8_t mpeg_noise_reduction
#define FFSWAP(type, a, b)
int strict_std_compliance
strictly follow the standard (MPEG-4, ...).
main external API structure.
@ AVCOL_TRC_ARIB_STD_B67
ARIB STD-B67, known as "Hybrid log-gamma".
uint8_t mapping_chroma_format_idc
uint32_t av_crc(const AVCRC *ctx, uint32_t crc, const uint8_t *buffer, size_t length)
Calculate the CRC of a block.
static int ff_dovi_rpu_extension_is_static(int level)
AVRational av_mul_q(AVRational b, AVRational c)
Multiply two rationals.
#define ITU_T_T35_COUNTRY_CODE_US
Structure to hold side data for an AVFrame.
static void flush_put_bits(PutBitContext *s)
Pad the end of the output stream with zeros.
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
uint16_t pivots[AV_DOVI_MAX_PIECES+1]
AVPrimaryCoefficients prim
static const AVFrameSideData * av_frame_side_data_get(AVFrameSideData *const *sd, const int nb_sd, enum AVFrameSideDataType type)
Wrapper around av_frame_side_data_get_c() to workaround the limitation that for any type T the conver...
int width
picture width / height.
av_cold int ff_dovi_configure_from_codedpar(DOVIContext *s, AVCodecParameters *par, const AVDOVIMetadata *metadata, enum AVDOVICompression compression, int strict_std_compliance)
Configure the encoder for Dolby Vision encoding.
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
@ FF_DOVI_WRAP_NAL
wrap inside NAL RBSP
@ AVCOL_SPC_BT709
also ITU-R BT1361 / IEC 61966-2-4 xvYCC709 / derived in SMPTE RP 177 Annex B
static void put_ue_coef(PutBitContext *pb, const AVDOVIRpuDataHeader *hdr, uint64_t coef)
Dolby Vision RPU data mapping parameters.
static int cmp_dm_level0(const AVDOVIColorMetadata *dm1, const AVDOVIColorMetadata *dm2)
static void BS_FUNC() skip(BSCTX *bc, unsigned int n)
Skip n bits in the buffer.
uint32_t num_x_partitions
int ff_dovi_guess_profile_hevc(const AVDOVIRpuDataHeader *hdr)
Internal helper function to guess the correct DV profile for HEVC.