GstH265Parser

It offers you bitstream parsing in HEVC mode and non-HEVC mode. To identify Nals in a bitstream and parse its headers, you should call:

Then, depending on the GstH265NalUnitType of the newly parsed GstH265NalUnit, you should call the differents functions to parse the structure:

Note: You should always call gst_h265_parser_parse_nal if you don't actually need GstH265NalUnitType to be parsed for your personal use, in order to guarantee that the GstH265Parser is always up to date.

For more details about the structures, look at the ITU-T H.265 specifications, you can download them from:

  • ITU-T H.265: http://www.itu.int/rec/T-REC-H.265

Functions

gst_h265_create_sei_memory

GstMemory *
gst_h265_create_sei_memory (guint8 layer_id,
                            guint8 temporal_id_plus1,
                            guint8 start_code_prefix_length,
                            GArray * messages)

Creates raw byte-stream format (a.k.a Annex B type) SEI nal unit data from messages

Parameters:

layer_id

a nal unit layer id

temporal_id_plus1

a nal unit temporal identifier

start_code_prefix_length

a length of start code prefix, must be 3 or 4

messages

a GArray of GstH265SEIMessage

Returns (GstMemory *)

a GstMemory containing a PREFIX SEI nal unit

Since : 1.18


gst_h265_create_sei_memory_hevc

GstMemory *
gst_h265_create_sei_memory_hevc (guint8 layer_id,
                                 guint8 temporal_id_plus1,
                                 guint8 nal_length_size,
                                 GArray * messages)

Creates raw packetized format SEI nal unit data from messages

Parameters:

layer_id

a nal unit layer id

temporal_id_plus1

a nal unit temporal identifier

nal_length_size

a size of nal length field, allowed range is [1, 4]

messages

a GArray of GstH265SEIMessage

Returns (GstMemory *)

a GstMemory containing a PREFIX SEI nal unit

Since : 1.18


gst_h265_decoder_config_record_free

void 
gst_h265_decoder_config_record_free (GstH265DecoderConfigRecord * config)

Free config data

Parameters:

config

a GstH265DecoderConfigRecord data

Returns (void )
No description available

Since : 1.24


gst_h265_get_profile_from_sps

GstH265Profile
gst_h265_get_profile_from_sps (GstH265SPS * sps)

Return the H265 profile from sps.

Parameters:

sps

a GstH265SPS

Returns (GstH265Profile)

a GstH265Profile

Since : 1.20


gst_h265_parse_pps

GstH265ParserResult
gst_h265_parse_pps (GstH265Parser * parser,
                    GstH265NalUnit * nalu,
                    GstH265PPS * pps)

Parses data, and fills the pps structure.

Parameters:

parser

a GstH265Parser

nalu

The GST_H265_NAL_PPS GstH265NalUnit to parse

pps

The GstH265PPS to fill.


gst_h265_parse_sps

GstH265ParserResult
gst_h265_parse_sps (GstH265Parser * parser,
                    GstH265NalUnit * nalu,
                    GstH265SPS * sps,
                    gboolean parse_vui_params)

parser: The GstH265Parser nalu: The GST_H265_NAL_SPS GstH265NalUnit to parse sps: The GstH265SPS to fill. parse_vui_params: Whether to parse the vui_params or not

Parameters:

parser
No description available
nalu
No description available
sps
No description available
parse_vui_params
No description available
Returns (GstH265ParserResult)
No description available

gst_h265_parse_vps

GstH265ParserResult
gst_h265_parse_vps (GstH265NalUnit * nalu,
                    GstH265VPS * vps)

Parses data, and fills the vps structure.

Parameters:

nalu

The GST_H265_NAL_VPS GstH265NalUnit to parse

vps
No description available

gst_h265_parser_free

void 
gst_h265_parser_free (GstH265Parser * parser)

Frees parser

Parameters:

parser

the GstH265Parser to free

Returns (void )
No description available

gst_h265_parser_identify_and_split_nalu_hevc

GstH265ParserResult
gst_h265_parser_identify_and_split_nalu_hevc (GstH265Parser * parser,
                                              guint8 * data,
                                              guint offset,
                                              gsize size,
                                              guint8 nal_length_size,
                                              GArray * nalus,
                                              gsize * consumed)

Parses data for packetized (e.g., hvc1/hev1) bitstream and sets nalus. In addition to nal identifying process, this method scans start-code prefix to split malformed packet into actual nal chunks.

Parameters:

parser

a GstH265Parser

data

The data to parse, must be the beging of the Nal unit

offset

the offset from which to parse data

size

the size of data

nal_length_size

the size in bytes of the HEVC nal length prefix.

nalus

a caller allocated GArray of GstH265NalUnit where to store parsed nal headers

consumed

the size of consumed bytes

Since : 1.22


gst_h265_parser_identify_nalu

GstH265ParserResult
gst_h265_parser_identify_nalu (GstH265Parser * parser,
                               guint8 * data,
                               guint offset,
                               gsize size,
                               GstH265NalUnit * nalu)

Parses data and fills nalu from the next nalu data from data

Parameters:

parser

a GstH265Parser

data

The data to parse

offset

the offset from which to parse data

size

the size of data

nalu

The GstH265NalUnit where to store parsed nal headers


gst_h265_parser_identify_nalu_hevc

GstH265ParserResult
gst_h265_parser_identify_nalu_hevc (GstH265Parser * parser,
                                    guint8 * data,
                                    guint offset,
                                    gsize size,
                                    guint8 nal_length_size,
                                    GstH265NalUnit * nalu)

Parses data and sets nalu.

Parameters:

parser

a GstH265Parser

data

The data to parse, must be the beging of the Nal unit

offset

the offset from which to parse data

size

the size of data

nal_length_size

the size in bytes of the HEVC nal length prefix.

nalu

The GstH265NalUnit where to store parsed nal headers


gst_h265_parser_identify_nalu_unchecked

GstH265ParserResult
gst_h265_parser_identify_nalu_unchecked (GstH265Parser * parser,
                                         guint8 * data,
                                         guint offset,
                                         gsize size,
                                         GstH265NalUnit * nalu)

Parses data and fills nalu from the next nalu data from data.

This differs from gst_h265_parser_identify_nalu in that it doesn't check whether the packet is complete or not.

Note: Only use this function if you already know the provided data is a complete NALU, else use gst_h265_parser_identify_nalu.

Parameters:

parser

a GstH265Parser

data

The data to parse

offset

the offset from which to parse data

size

the size of data

nalu

The GstH265NalUnit where to store parsed nal headers


gst_h265_parser_insert_sei

GstBuffer *
gst_h265_parser_insert_sei (GstH265Parser * parser,
                            GstBuffer * au,
                            GstMemory * sei)

Copy au into new GstBuffer and insert sei into the GstBuffer. The validation for completeness of au and sei is caller's responsibility. Both au and sei must be byte-stream formatted

Parameters:

parser

a GstH265Parser

au

a GstBuffer containing AU data

sei

a GstMemory containing a SEI nal

Returns (GstBuffer *)

a SEI inserted GstBuffer or NULL if cannot figure out proper position to insert a sei

Since : 1.18


gst_h265_parser_insert_sei_hevc

GstBuffer *
gst_h265_parser_insert_sei_hevc (GstH265Parser * parser,
                                 guint8 nal_length_size,
                                 GstBuffer * au,
                                 GstMemory * sei)

Copy au into new GstBuffer and insert sei into the GstBuffer. The validation for completeness of au and sei is caller's responsibility. Nal prefix type of both au and sei must be packetized, and also the size of nal length field must be identical to nal_length_size

Parameters:

parser

a GstH265Parser

nal_length_size

a size of nal length field, allowed range is [1, 4]

au

a GstBuffer containing AU data

sei

a GstMemory containing a SEI nal

Returns (GstBuffer *)

a SEI inserted GstBuffer or NULL if cannot figure out proper position to insert a sei

Since : 1.18


gst_h265_parser_new

GstH265Parser *
gst_h265_parser_new ()

Creates a new GstH265Parser. It should be freed with gst_h265_parser_free after use.

Returns (GstH265Parser *)

a new GstH265Parser


gst_h265_parser_parse_decoder_config_record

GstH265ParserResult
gst_h265_parser_parse_decoder_config_record (GstH265Parser * parser,
                                             guint8 * data,
                                             gsize size,
                                             GstH265DecoderConfigRecord ** config)

Parses HEVCDecoderConfigurationRecord data and fill into config. The caller must free config via gst_h265_decoder_config_record_free

This method does not parse VPS, SPS and PPS and therefore the caller needs to parse each NAL unit via appropriate parsing method.

Parameters:

parser

a GstH265Parser

data

the data to parse

size

the size of data

config

parsed GstH265DecoderConfigRecord data

Since : 1.24


gst_h265_parser_parse_nal

GstH265ParserResult
gst_h265_parser_parse_nal (GstH265Parser * parser,
                           GstH265NalUnit * nalu)

This function should be called in the case one doesn't need to parse a specific structure. It is necessary to do so to make sure parser is up to date.

Parameters:

parser

a GstH265Parser

nalu

The GstH265NalUnit to parse


gst_h265_parser_parse_pps

GstH265ParserResult
gst_h265_parser_parse_pps (GstH265Parser * parser,
                           GstH265NalUnit * nalu,
                           GstH265PPS * pps)

Parses data, and fills the pps structure.

Parameters:

parser

a GstH265Parser

nalu

The GST_H265_NAL_PPS GstH265NalUnit to parse

pps

The GstH265PPS to fill.


gst_h265_parser_parse_sei

GstH265ParserResult
gst_h265_parser_parse_sei (GstH265Parser * parser,
                           GstH265NalUnit * nalu,
                           GArray ** messages)

Parses data, create and fills the messages array.

Parameters:

parser
No description available
nalu

The GST_H265_NAL_*_SEI GstH265NalUnit to parse

messages

The GArray of GstH265SEIMessage to fill. The caller must free it when done.


gst_h265_parser_parse_slice_hdr

GstH265ParserResult
gst_h265_parser_parse_slice_hdr (GstH265Parser * parser,
                                 GstH265NalUnit * nalu,
                                 GstH265SliceHdr * slice)

Parses data, and fills the slice structure. The resulting slice_hdr structure shall be deallocated with gst_h265_slice_hdr_free when it is no longer needed

Parameters:

parser

a GstH265Parser

nalu

The GST_H265_NAL_SLICE GstH265NalUnit to parse

slice

The GstH265SliceHdr to fill.


gst_h265_parser_parse_sps

GstH265ParserResult
gst_h265_parser_parse_sps (GstH265Parser * parser,
                           GstH265NalUnit * nalu,
                           GstH265SPS * sps,
                           gboolean parse_vui_params)

Parses data, and fills the sps structure.

Parameters:

parser

a GstH265Parser

nalu

The GST_H265_NAL_SPS GstH265NalUnit to parse

sps

The GstH265SPS to fill.

parse_vui_params

Whether to parse the vui_params or not


gst_h265_parser_parse_vps

GstH265ParserResult
gst_h265_parser_parse_vps (GstH265Parser * parser,
                           GstH265NalUnit * nalu,
                           GstH265VPS * vps)

Parses data, and fills the vps structure.

Parameters:

parser

a GstH265Parser

nalu

The GST_H265_NAL_VPS GstH265NalUnit to parse

vps

The GstH265VPS to fill.


gst_h265_parser_update_pps

GstH265ParserResult
gst_h265_parser_update_pps (GstH265Parser * parser,
                            GstH265PPS * pps)

Replace internal Sequence Parameter Set struct corresponding to id of pps with pps. nalparser will mark pps as last parsed sps.

Parameters:

parser

a GstH265Parser

pps

a GstH265PPS.

Since : 1.18


gst_h265_parser_update_sps

GstH265ParserResult
gst_h265_parser_update_sps (GstH265Parser * parser,
                            GstH265SPS * sps)

Replace internal Sequence Parameter Set struct corresponding to id of sps with sps. nalparser will mark sps as last parsed sps.

Parameters:

parser

a GstH265Parser

sps

a GstH265SPS.

Since : 1.18


gst_h265_parser_update_vps

GstH265ParserResult
gst_h265_parser_update_vps (GstH265Parser * parser,
                            GstH265VPS * vps)

Replace internal Video Parameter Set struct corresponding to id of vps with vps. nalparser will mark vps as last parsed vps.

Parameters:

parser

a GstH265Parser

vps

a GstH265VPS.

Since : 1.18


gst_h265_profile_from_string

GstH265Profile
gst_h265_profile_from_string (gchar * string)

Returns a GstH265Profile for the string.

Parameters:

string

the descriptive name for GstH265Profile

Returns (GstH265Profile)

the GstH265Profile of string or GST_H265_PROFILE_INVALID on error

Since : 1.18


gst_h265_profile_tier_level_get_profile

GstH265Profile
gst_h265_profile_tier_level_get_profile (GstH265ProfileTierLevel * ptl)

Return the H265 profile defined in ptl.

Parameters:

Returns (GstH265Profile)

a GstH265Profile

Since : 1.14


gst_h265_profile_to_string

gchar *
gst_h265_profile_to_string (GstH265Profile profile)

Returns the descriptive name for the GstH265Profile.

Parameters:

profile

a GstH265Profile

Returns (gchar *)

the name for profile or NULL on error

Since : 1.18


gst_h265_quant_matrix_4x4_get_raster_from_uprightdiagonal

void 
gst_h265_quant_matrix_4x4_get_raster_from_uprightdiagonal (guint8[16]  out_quant,
                                                           const guint8[16]  quant)

Converts quantization matrix quant from uprightdiagonal scan order to raster scan order and store the resulting factors into out_quant.

Note: it is an error to pass the same table in both quant and out_quant arguments.

Parameters:

out_quant

The resulting quantization matrix

quant

The source quantization matrix

Returns (void )
No description available

Since : 1.6


gst_h265_quant_matrix_4x4_get_raster_from_zigzag

void 
gst_h265_quant_matrix_4x4_get_raster_from_zigzag (guint8[16]  out_quant,
                                                  const guint8[16]  quant)

Converts quantization matrix quant from zigzag scan order to raster scan order and store the resulting factors into out_quant.

Note: it is an error to pass the same table in both quant and out_quant arguments.

Parameters:

out_quant

The resulting quantization matrix

quant

The source quantization matrix

Returns (void )
No description available

Since : 1.6


gst_h265_quant_matrix_4x4_get_uprightdiagonal_from_raster

void 
gst_h265_quant_matrix_4x4_get_uprightdiagonal_from_raster (guint8[16]  out_quant,
                                                           const guint8[16]  quant)

Converts quantization matrix quant from raster scan order to uprightdiagonal scan order and store the resulting factors into out_quant.

Note: it is an error to pass the same table in both quant and out_quant arguments.

Parameters:

out_quant

The resulting quantization matrix

quant

The source quantization matrix

Returns (void )
No description available

Since : 1.6


gst_h265_quant_matrix_4x4_get_zigzag_from_raster

void 
gst_h265_quant_matrix_4x4_get_zigzag_from_raster (guint8[16]  out_quant,
                                                  const guint8[16]  quant)

Converts quantization matrix quant from raster scan order to zigzag scan order and store the resulting factors into out_quant.

Note: it is an error to pass the same table in both quant and out_quant arguments.

Parameters:

out_quant

The resulting quantization matrix

quant

The source quantization matrix

Returns (void )
No description available

Since : 1.6


gst_h265_quant_matrix_8x8_get_raster_from_uprightdiagonal

void 
gst_h265_quant_matrix_8x8_get_raster_from_uprightdiagonal (guint8[64]  out_quant,
                                                           const guint8[64]  quant)

Converts quantization matrix quant from uprightdiagonal scan order to raster scan order and store the resulting factors into out_quant.

Note: it is an error to pass the same table in both quant and out_quant arguments.

Parameters:

out_quant

The resulting quantization matrix

quant

The source quantization matrix

Returns (void )
No description available

Since : 1.6


gst_h265_quant_matrix_8x8_get_raster_from_zigzag

void 
gst_h265_quant_matrix_8x8_get_raster_from_zigzag (guint8[64]  out_quant,
                                                  const guint8[64]  quant)

Converts quantization matrix quant from zigzag scan order to raster scan order and store the resulting factors into out_quant.

Note: it is an error to pass the same table in both quant and out_quant arguments.

Parameters:

out_quant

The resulting quantization matrix

quant

The source quantization matrix

Returns (void )
No description available

Since : 1.6


gst_h265_quant_matrix_8x8_get_uprightdiagonal_from_raster

void 
gst_h265_quant_matrix_8x8_get_uprightdiagonal_from_raster (guint8[64]  out_quant,
                                                           const guint8[64]  quant)

Converts quantization matrix quant from raster scan order to uprightdiagonal scan order and store the resulting factors into out_quant.

Note: it is an error to pass the same table in both quant and out_quant arguments.

Parameters:

out_quant

The resulting quantization matrix

quant

The source quantization matrix

Returns (void )
No description available

Since : 1.6


gst_h265_quant_matrix_8x8_get_zigzag_from_raster

void 
gst_h265_quant_matrix_8x8_get_zigzag_from_raster (guint8[64]  out_quant,
                                                  const guint8[64]  quant)

Converts quantization matrix quant from raster scan order to zigzag scan order and store the resulting factors into out_quant.

Note: it is an error to pass the same table in both quant and out_quant arguments.

Parameters:

out_quant

The resulting quantization matrix

quant

The source quantization matrix

Returns (void )
No description available

Since : 1.6


gst_h265_sei_copy

gboolean
gst_h265_sei_copy (GstH265SEIMessage * dest_sei,
                   GstH265SEIMessage * src_sei)

Copies src_sei into dst_sei

Parameters:

dest_sei
No description available
src_sei

The source GstH265SEIMessage to copy from

Returns (gboolean)

TRUE if everything went fine, FALSE otherwise


gst_h265_sei_free

void 
gst_h265_sei_free (GstH265SEIMessage * sei)

sei: The GstH265SEIMessage to free

Parameters:

sei
No description available
Returns (void )
No description available

gst_h265_slice_hdr_copy

gboolean
gst_h265_slice_hdr_copy (GstH265SliceHdr * dst_slice,
                         GstH265SliceHdr * src_slice)

Copies src_slice into dst_slice

Parameters:

dst_slice

The destination GstH265SliceHdr to copy into

src_slice

The source GstH265SliceHdr to copy from

Returns (gboolean)

TRUE if everything went fine, FALSE otherwise


gst_h265_slice_hdr_free

void 
gst_h265_slice_hdr_free (GstH265SliceHdr * slice_hdr)

slice_hdr: The GstH265SliceHdr to free

Parameters:

slice_hdr
No description available
Returns (void )
No description available

gst_h265_slice_type_to_string

gchar *
gst_h265_slice_type_to_string (GstH265SliceType slice_type)

Returns the descriptive name for the GstH265SliceType.

Parameters:

slice_type

a GstH265SliceType

Returns (gchar *)

the name for slice_type or NULL on error

Since : 1.24


Structures

GstH265BufferingPeriod

struct _GstH265BufferingPeriod
{
  GstH265SPS *sps;

  guint8 irap_cpb_params_present_flag;
  guint8 cpb_delay_offset;
  guint8 dpb_delay_offset;
  guint8 concatenation_flag;
  guint8 au_cpb_removal_delay_delta_minus1;

  /* seq->vui_parameters->nal_hrd_parameters_present_flag */
  guint8 nal_initial_cpb_removal_delay[32];
  guint8 nal_initial_cpb_removal_offset[32];
  guint8 nal_initial_alt_cpb_removal_delay[32];
  guint8 nal_initial_alt_cpb_removal_offset [32];

  /* seq->vui_parameters->vcl_hrd_parameters_present_flag */
  guint8 vcl_initial_cpb_removal_delay[32];
  guint8 vcl_initial_cpb_removal_offset[32];
  guint8 vcl_initial_alt_cpb_removal_delay[32];
  guint8 vcl_initial_alt_cpb_removal_offset[32];
};

Fields

sps (GstH265SPS *) –
No description available
irap_cpb_params_present_flag (guint8) –
No description available
cpb_delay_offset (guint8) –
No description available
dpb_delay_offset (guint8) –
No description available
concatenation_flag (guint8) –
No description available
au_cpb_removal_delay_delta_minus1 (guint8) –
No description available
nal_initial_cpb_removal_delay (guint8[32] ) –
No description available
nal_initial_cpb_removal_offset (guint8[32] ) –
No description available
nal_initial_alt_cpb_removal_delay (guint8[32] ) –
No description available
nal_initial_alt_cpb_removal_offset (guint8[32] ) –
No description available
vcl_initial_cpb_removal_delay (guint8[32] ) –
No description available
vcl_initial_cpb_removal_offset (guint8[32] ) –
No description available
vcl_initial_alt_cpb_removal_delay (guint8[32] ) –
No description available
vcl_initial_alt_cpb_removal_offset (guint8[32] ) –
No description available

GstH265ContentLightLevel

struct _GstH265ContentLightLevel
{
  guint16 max_content_light_level;
  guint16 max_pic_average_light_level;
};

The upper bounds for the nominal target brightness light level as specified in CEA-861.3

Fields

max_content_light_level (guint16) –
No description available
max_pic_average_light_level (guint16) –
No description available

GstH265DecoderConfigRecord

struct _GstH265DecoderConfigRecord
{
  /**
   * GstH265DecoderConfigRecord.configuration_version:
   *
   * Indicates configurationVersion, must be 1
   */
  guint8 configuration_version;

  /**
   * GstH265DecoderConfigRecord.general_profile_space:
   *
   * general profile space
   */
  guint8 general_profile_space;

  /**
   * GstH265DecoderConfigRecord.general_tier_flag:
   *
   * general tier flag
   */
  guint8 general_tier_flag;

  /**
   * GstH265DecoderConfigRecord.general_profile_idc:
   *
   * general profile indiction
   */
  guint8 general_profile_idc;

  /**
   * GstH265DecoderConfigRecord.general_profile_compatibility_flags:
   *
   * general profile compatibility flags
   */
  guint8 general_profile_compatibility_flags[32];

  /**
   * GstH265DecoderConfigRecord.general_progressive_source_flag:
   *
   * general_progressive_source_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_progressive_source_flag;

  /**
   * GstH265DecoderConfigRecord.general_interlaced_source_flag:
   *
   * general_interlaced_source_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_interlaced_source_flag;

  /**
   * GstH265DecoderConfigRecord.general_non_packed_constraint_flag:
   *
   * general_non_packed_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_non_packed_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_frame_only_constraint_flag:
   *
   * general_frame_only_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_frame_only_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_max_12bit_constraint_flag:
   *
   * general_max_12bit_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_max_12bit_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_max_10bit_constraint_flag:
   *
   * general_max_10bit_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_max_10bit_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_max_8bit_constraint_flag:
   *
   * general_max_8bit_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_max_8bit_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_max_422chroma_constraint_flag:
   *
   * general_max_422chroma_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_max_422chroma_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_max_420chroma_constraint_flag:
   *
   * general_max_420chroma_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_max_420chroma_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_max_monochrome_constraint_flag:
   *
   * general_max_monochrome_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_max_monochrome_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_intra_constraint_flag:
   *
   * general_intra_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_intra_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_one_picture_only_constraint_flag:
   *
   * general_one_picture_only_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_one_picture_only_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_lower_bit_rate_constraint_flag:
   *
   * general_lower_bit_rate_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_lower_bit_rate_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_max_14bit_constraint_flag:
   *
   * general_max_14bit_constraint_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_max_14bit_constraint_flag;

  /**
   * GstH265DecoderConfigRecord.general_inbld_flag:
   *
   * general_inbld_flag parsed from
   * HEVCDecoderConfigurationRecord.general_constraint_indicator_flags
   */
  guint8 general_inbld_flag;

  /**
   * GstH265DecoderConfigRecord.general_level_idc:
   *
   * general level indication
   */
  guint8 general_level_idc;

  /**
   * GstH265DecoderConfigRecord.min_spatial_segmentation_idc:
   *
   * min spatial segmentation indication
   */
  guint16 min_spatial_segmentation_idc;

  /**
   * GstH265DecoderConfigRecord.parallelism_type:
   *
   * parallelism type
   */
  guint8 parallelism_type;

  /**
   * GstH265DecoderConfigRecord.chroma_format_idc:
   *
   * chroma format indication
   */
  guint8 chroma_format_idc;

  /**
   * GstH265DecoderConfigRecord.bit_depth_luma_minus8:
   *
   * bit depth luma minus 8
   */
  guint8 bit_depth_luma_minus8;

  /**
   * GstH265DecoderConfigRecord.bit_depth_chroma_minus8:
   *
   * bit depth chroma minus 8
   */
  guint8 bit_depth_chroma_minus8;

  /**
   * GstH265DecoderConfigRecord.avg_frame_rate:
   *
   * average frame rate in units of frames per 256 seconds,
   * or 0 when unspecified
   */
  guint16 avg_frame_rate;

  /**
   * GstH265DecoderConfigRecord.constant_frame_rate:
   *
   * constant frame rate.
   * 1: stream to which this configuration record applies is constante frame rate
   * 2: representation of each temporal layer in the stream is constant frame rate
   * 0: unspecified
   */
  guint8 constant_frame_rate;

  /**
   * GstH265DecoderConfigRecord.num_temporal_layers:
   *
   * 0: unknown whether the stream is temporally scalable
   * otherwise: the number of temporal layers
   */
  guint8 num_temporal_layers;

  /**
   * GstH265DecoderConfigRecord.temporal_id_nested:
   *
   * 1: all SPSs that activated when the stream to this configuration record
   *   applies is decoded have sps_temporal_id_nesting_flags equal to 1
   *   and temporal sub-layer up-switching to any higher temporal layer can
   *   be performed at any semple
   * 0: unknown
   */
  guint8 temporal_id_nested;

  /**
   * GstH265DecoderConfigRecord.length_size_minus_one:
   *
   * indicates the length in bytes of nal unit length field.
   * This value shall be one of 0, 1, or 3 corresponding to a length
   * encoded with 1, 2, or 4 bytes, respectively
   */
  guint8 length_size_minus_one;

  /**
   * GstH265DecoderConfigRecord.nalu_array:
   *
   * Array of #GstH265DecoderConfigRecordNalUnitArray
   */
  GArray *nalu_array;

};

Contains HEVCDecoderConfigurationRecord data as defined in ISO/IEC 14496-15

Fields

configuration_version (guint8) –
No description available
general_profile_space (guint8) –
No description available
general_tier_flag (guint8) –
No description available
general_profile_idc (guint8) –
No description available
general_profile_compatibility_flags (guint8[32] ) –
No description available
general_progressive_source_flag (guint8) –
No description available
general_interlaced_source_flag (guint8) –
No description available
general_non_packed_constraint_flag (guint8) –
No description available
general_frame_only_constraint_flag (guint8) –
No description available
general_max_12bit_constraint_flag (guint8) –
No description available
general_max_10bit_constraint_flag (guint8) –
No description available
general_max_8bit_constraint_flag (guint8) –
No description available
general_max_422chroma_constraint_flag (guint8) –
No description available
general_max_420chroma_constraint_flag (guint8) –
No description available
general_max_monochrome_constraint_flag (guint8) –
No description available
general_intra_constraint_flag (guint8) –
No description available
general_one_picture_only_constraint_flag (guint8) –
No description available
general_lower_bit_rate_constraint_flag (guint8) –
No description available
general_max_14bit_constraint_flag (guint8) –
No description available
general_inbld_flag (guint8) –
No description available
general_level_idc (guint8) –
No description available
min_spatial_segmentation_idc (guint16) –
No description available
parallelism_type (guint8) –
No description available
chroma_format_idc (guint8) –
No description available
bit_depth_luma_minus8 (guint8) –
No description available
bit_depth_chroma_minus8 (guint8) –
No description available
avg_frame_rate (guint16) –
No description available
constant_frame_rate (guint8) –
No description available
num_temporal_layers (guint8) –
No description available
temporal_id_nested (guint8) –
No description available
length_size_minus_one (guint8) –
No description available
nalu_array (GArray *) –
No description available

Since : 1.24


GstH265DecoderConfigRecordNalUnitArray

struct _GstH265DecoderConfigRecordNalUnitArray
{
  /**
   * GstH265DecoderConfigRecordNalUnitArray.array_completeness:
   *
   * 1: all NAL units of the given type are in this array and none
   *   are in the stream.
   * 0: additional NAL units of the indicated type may be in the stream
   */
  guint8 array_completeness;

  /**
   * GstH265DecoderConfigRecordNalUnitArray.nal_unit_type:
   *
   * Indicates the type of the NAL units in the following array.
   * Shall be VPS, SPS, PPS, prefix SEI or suffix SEI
   */
  GstH265NalUnitType nal_unit_type;

  /**
   * GstH265DecoderConfigRecordNalUnitArray.nalu:
   *
   * Array of identified #GstH265NalUnit
   */
  GArray *nalu;
};

Contains NAL Unit array data as defined in ISO/IEC 14496-15

Fields

array_completeness (guint8) –
No description available
nal_unit_type (GstH265NalUnitType) –
No description available
nalu (GArray *) –
No description available

Since : 1.24


GstH265HRDParams

struct _GstH265HRDParams
{
  guint8 nal_hrd_parameters_present_flag;
  guint8 vcl_hrd_parameters_present_flag;
  guint8 sub_pic_hrd_params_present_flag;

  guint8 tick_divisor_minus2;
  guint8 du_cpb_removal_delay_increment_length_minus1;
  guint8 sub_pic_cpb_params_in_pic_timing_sei_flag;
  guint8 dpb_output_delay_du_length_minus1;

  guint8 bit_rate_scale;
  guint8 cpb_size_scale;
  guint8 cpb_size_du_scale;

  guint8 initial_cpb_removal_delay_length_minus1;
  guint8 au_cpb_removal_delay_length_minus1;
  guint8 dpb_output_delay_length_minus1;

  guint8 fixed_pic_rate_general_flag [7];
  guint8 fixed_pic_rate_within_cvs_flag [7];
  guint16 elemental_duration_in_tc_minus1 [7];
  guint8 low_delay_hrd_flag [7];
  guint8 cpb_cnt_minus1[7];

  GstH265SubLayerHRDParams sublayer_hrd_params[7];
};

Defines the HRD parameters

Fields

nal_hrd_parameters_present_flag (guint8) –

indicate the presence of NAL HRD parameters

vcl_hrd_parameters_present_flag (guint8) –

indicate the presence of VCL HRD parameters

sub_pic_hrd_params_present_flag (guint8) –

indicate the presence of sub_pic_hrd_params

tick_divisor_minus2 (guint8) –

is used to specify the clock sub-tick

du_cpb_removal_delay_increment_length_minus1 (guint8) –

specifies the length, in bits, of the nal_initial_cpb_removal_delay

sub_pic_cpb_params_in_pic_timing_sei_flag (guint8) –

specifies the length, in bits, of the cpb_delay_offset and the au_cpb_removal_delay_minus1 syntax elements.

dpb_output_delay_du_length_minus1 (guint8) –
No description available
bit_rate_scale (guint8) –

maximum input bitrate

cpb_size_scale (guint8) –

CPB size when operates in access unit level

cpb_size_du_scale (guint8) –

CPB size when operates in sub-picture level

initial_cpb_removal_delay_length_minus1 (guint8) –

specifies the length, in bits, of the nal_initial_cpb_removal_delay, nal_initial_cpb_removal_offset, vcl_initial_cpb_removal_delay and vcl_initial_cpb_removal_offset.

au_cpb_removal_delay_length_minus1 (guint8) –

specifies the length, in bits, of the cpb_delay_offset and the au_cpb_removal_delay_minus1 syntax elements

dpb_output_delay_length_minus1 (guint8) –

specifies the length, in bits, of the dpb_delay_offset and the pic_dpb_output_delay syntax elements

fixed_pic_rate_general_flag (guint8[7] ) –

flag to indicate the presence of constraint on the temporal distance between the HRD output times of consecutive pictures in output order

fixed_pic_rate_within_cvs_flag (guint8[7] ) –

same as fixed_pic_rate_general_flag

elemental_duration_in_tc_minus1 (guint16[7] ) –

temporal distance in clock ticks

low_delay_hrd_flag (guint8[7] ) –

specifies the HRD operational mode

cpb_cnt_minus1 (guint8[7] ) –

specifies the number of alternative CPS specifications.

sublayer_hrd_params (GstH265SubLayerHRDParams[7] ) –

Sublayer HRD parameters.


GstH265MasteringDisplayColourVolume

struct _GstH265MasteringDisplayColourVolume
{
  guint16 display_primaries_x[3];
  guint16 display_primaries_y[3];
  guint16 white_point_x;
  guint16 white_point_y;
  guint32 max_display_mastering_luminance;
  guint32 min_display_mastering_luminance;
};

The colour volume (primaries, white point and luminance range) of display defined by SMPTE ST 2086.

Fields

display_primaries_x (guint16[3] ) –
No description available
display_primaries_y (guint16[3] ) –
No description available
white_point_x (guint16) –
No description available
white_point_y (guint16) –
No description available
max_display_mastering_luminance (guint32) –
No description available
min_display_mastering_luminance (guint32) –
No description available

GstH265NalUnit

struct _GstH265NalUnit
{
  guint8 type;
  guint8 layer_id;
  guint8 temporal_id_plus1;

  /* calculated values */
  guint size;
  guint offset;
  guint sc_offset;
  gboolean valid;

  guint8 *data;
  guint8 header_bytes;
};

Structure defining the Nal unit headers

Fields

type (guint8) –

A GstH265NalUnitType

layer_id (guint8) –

A nal unit layer id

temporal_id_plus1 (guint8) –

A nal unit temporal identifier

size (guint) –

The size of the nal unit starting from offset

offset (guint) –

The offset of the actual start of the nal unit

sc_offset (guint) –

The offset of the start code of the nal unit

valid (gboolean) –

If the nal unit is valid, which mean it has already been parsed

data (guint8 *) –

The data from which the Nalu has been parsed

header_bytes (guint8) –
No description available

GstH265PPS

struct _GstH265PPS
{
  guint id;

  /**
   * _GstH265PPS.sps_id:
   *
   * The ID of the SPS. This is used to store the ID until the SPS is
   * parsed in case its placed after the PPS.
   *
   * Since: 1.22
   */
  guint sps_id;
  GstH265SPS *sps;

  guint8 dependent_slice_segments_enabled_flag;
  guint8 output_flag_present_flag;
  guint8 num_extra_slice_header_bits;
  guint8 sign_data_hiding_enabled_flag;
  guint8 cabac_init_present_flag;
  guint8 num_ref_idx_l0_default_active_minus1;
  guint8 num_ref_idx_l1_default_active_minus1;
  gint8 init_qp_minus26;
  guint8 constrained_intra_pred_flag;
  guint8 transform_skip_enabled_flag;
  guint8 cu_qp_delta_enabled_flag;
  /*if cu_qp_delta_enabled_flag */
  guint8 diff_cu_qp_delta_depth;

  gint8 cb_qp_offset;
  gint8 cr_qp_offset;
  guint8 slice_chroma_qp_offsets_present_flag;
  guint8 weighted_pred_flag;
  guint8 weighted_bipred_flag;
  guint8 transquant_bypass_enabled_flag;
  guint8 tiles_enabled_flag;
  guint8 entropy_coding_sync_enabled_flag;

  guint8 num_tile_columns_minus1;
  guint8 num_tile_rows_minus1;
  guint8 uniform_spacing_flag;
  guint32 column_width_minus1[20];
  guint32 row_height_minus1[22];
  guint8 loop_filter_across_tiles_enabled_flag;

  guint8 loop_filter_across_slices_enabled_flag;
  guint8 deblocking_filter_control_present_flag;
  guint8 deblocking_filter_override_enabled_flag;
  guint8 deblocking_filter_disabled_flag;
  gint8 beta_offset_div2;
  gint8 tc_offset_div2;

  guint8 scaling_list_data_present_flag;

  GstH265ScalingList scaling_list;

  guint8 lists_modification_present_flag;
  guint8 log2_parallel_merge_level_minus2;
  guint8 slice_segment_header_extension_present_flag;

  guint8 pps_extension_flag;

  /* if pps_extension_flag*/
  guint8 pps_range_extension_flag;
  guint8 pps_multilayer_extension_flag;
  guint8 pps_3d_extension_flag;
  guint8 pps_scc_extension_flag;
  guint8 pps_extension_4bits;

  /* if pps_range_extension_flag*/
  GstH265PPSExtensionParams pps_extension_params;
  /* if pps_scc_extension_flag*/
  GstH265PPSSccExtensionParams pps_scc_extension_params;

  /* calculated values */
  guint32 PicWidthInCtbsY;
  guint32 PicHeightInCtbsY;
  gboolean valid;
};

H265 Picture Parameter Set

Fields

id (guint) –
No description available
sps_id (guint) –

The ID of the SPS. This is used to store the ID until the SPS is parsed in case its placed after the PPS.

sps (GstH265SPS *) –
No description available
dependent_slice_segments_enabled_flag (guint8) –
No description available
output_flag_present_flag (guint8) –
No description available
num_extra_slice_header_bits (guint8) –
No description available
sign_data_hiding_enabled_flag (guint8) –
No description available
cabac_init_present_flag (guint8) –
No description available
num_ref_idx_l0_default_active_minus1 (guint8) –
No description available
num_ref_idx_l1_default_active_minus1 (guint8) –
No description available
init_qp_minus26 (gint8) –
No description available
constrained_intra_pred_flag (guint8) –
No description available
transform_skip_enabled_flag (guint8) –
No description available
cu_qp_delta_enabled_flag (guint8) –
No description available
diff_cu_qp_delta_depth (guint8) –
No description available
cb_qp_offset (gint8) –
No description available
cr_qp_offset (gint8) –
No description available
slice_chroma_qp_offsets_present_flag (guint8) –
No description available
weighted_pred_flag (guint8) –
No description available
weighted_bipred_flag (guint8) –
No description available
transquant_bypass_enabled_flag (guint8) –
No description available
tiles_enabled_flag (guint8) –
No description available
entropy_coding_sync_enabled_flag (guint8) –
No description available
num_tile_columns_minus1 (guint8) –
No description available
num_tile_rows_minus1 (guint8) –
No description available
uniform_spacing_flag (guint8) –
No description available
column_width_minus1 (guint32[20] ) –
No description available
row_height_minus1 (guint32[22] ) –
No description available
loop_filter_across_tiles_enabled_flag (guint8) –
No description available
loop_filter_across_slices_enabled_flag (guint8) –
No description available
deblocking_filter_control_present_flag (guint8) –
No description available
deblocking_filter_override_enabled_flag (guint8) –
No description available
deblocking_filter_disabled_flag (guint8) –
No description available
beta_offset_div2 (gint8) –
No description available
tc_offset_div2 (gint8) –
No description available
scaling_list_data_present_flag (guint8) –
No description available
scaling_list (GstH265ScalingList) –
No description available
lists_modification_present_flag (guint8) –
No description available
log2_parallel_merge_level_minus2 (guint8) –
No description available
slice_segment_header_extension_present_flag (guint8) –
No description available
pps_extension_flag (guint8) –
No description available
pps_range_extension_flag (guint8) –
No description available
pps_multilayer_extension_flag (guint8) –
No description available
pps_3d_extension_flag (guint8) –
No description available
pps_scc_extension_flag (guint8) –
No description available
pps_extension_4bits (guint8) –
No description available
pps_extension_params (GstH265PPSExtensionParams) –
No description available
pps_scc_extension_params (GstH265PPSSccExtensionParams) –
No description available
PicWidthInCtbsY (guint32) –
No description available
PicHeightInCtbsY (guint32) –
No description available
valid (gboolean) –
No description available

GstH265PPSExtensionParams

struct _GstH265PPSExtensionParams {
  guint32 log2_max_transform_skip_block_size_minus2;
  guint8 cross_component_prediction_enabled_flag;
  guint8 chroma_qp_offset_list_enabled_flag;
  guint8 diff_cu_chroma_qp_offset_depth;
  guint8 chroma_qp_offset_list_len_minus1;
  gint8 cb_qp_offset_list[6];
  gint8 cr_qp_offset_list[6];
  guint8 log2_sao_offset_scale_luma;
  guint8 log2_sao_offset_scale_chroma;
};

Defines the GstH265SPSExtensionParams

Fields

log2_max_transform_skip_block_size_minus2 (guint32) –

plus 2 specifies the maximum transform block size for which transform_skip_flag may be present in coded pictures referring to the PPS.

cross_component_prediction_enabled_flag (guint8) –

equal to 1 specifies that log2_res_scale_abs_plus1 and res_scale_sign_flag may be present in the transform unit syntax for pictures referring to the PPS.

chroma_qp_offset_list_enabled_flag (guint8) –

equal to 1 specifies that the cu_chroma_qp_offset_flag may be present in the transform unit syntax.

diff_cu_chroma_qp_offset_depth (guint8) –

specifies the difference between the luma coding tree block size and the minimum luma coding block size of coding units that convey cu_chroma_qp_offset_flag.

chroma_qp_offset_list_len_minus1 (guint8) –

plus 1 specifies the number of cb_qp_offset_list[] and cr_qp_offset_list[] syntax elements that are present in the PPS.

cb_qp_offset_list (gint8[6] ) –

specify offsets used in the derivation of qp cb.

cr_qp_offset_list (gint8[6] ) –

specify offsets used in the derivation of qp cr.

log2_sao_offset_scale_luma (guint8) –

the base 2 logarithm of the scaling parameter that is used to scale sample adaptive offset (SAO) offset values for luma samples.

log2_sao_offset_scale_chroma (guint8) –

the base 2 logarithm of the scaling parameter that is used to scale SAO offset values for chroma samples.


GstH265PPSSccExtensionParams

struct _GstH265PPSSccExtensionParams {
  guint8 pps_curr_pic_ref_enabled_flag;
  guint8 residual_adaptive_colour_transform_enabled_flag;
  guint8 pps_slice_act_qp_offsets_present_flag;
  guint8 pps_act_y_qp_offset_plus5;
  guint8 pps_act_cb_qp_offset_plus5;
  guint8 pps_act_cr_qp_offset_plus3;
  guint8 pps_palette_predictor_initializers_present_flag;
  guint8 pps_num_palette_predictor_initializer;
  guint8 monochrome_palette_flag;
  guint8 luma_bit_depth_entry_minus8;
  guint32 chroma_bit_depth_entry_minus8;
  guint32 pps_palette_predictor_initializer[3][128];
};

Fields

pps_curr_pic_ref_enabled_flag (guint8) –

equal to 1 specifies that a picture referring to the PPS may be included in a reference picture list of a slice of the picture itself.

residual_adaptive_colour_transform_enabled_flag (guint8) –

equal to 1 specifies that an adaptive colour transform may be applied to the residual in the decoding process.

pps_slice_act_qp_offsets_present_flag (guint8) –

equal to 1 specifies that slice_act_y_qp_offset, slice_act_cb_qp_offset, slice_act_cr_qp_offset are present in the slice header. pps_act_y_qp_offset_plus5 pps_act_cb_qp_offset_plus5 pps_act_cr_qp_offset_plus3: are used to determine the offsets that are applied to the quantization parameter values qp derived in clause 8.6.2 for the luma, Cb and Cr components, respectively, when tu_residual_act_flag[ xTbY ][ yTbY ] is equal to 1.

pps_act_y_qp_offset_plus5 (guint8) –
No description available
pps_act_cb_qp_offset_plus5 (guint8) –
No description available
pps_act_cr_qp_offset_plus3 (guint8) –
No description available
pps_palette_predictor_initializers_present_flag (guint8) –

equal to 1 specifies that the palette predictor initializers used for the pictures referring to the PPS are derived based on the palette predictor initializers specified by the PPS.

pps_num_palette_predictor_initializer (guint8) –

specifies the number of entries in the picture palette predictor initializer.

monochrome_palette_flag (guint8) –

equal to 1 specifies that the pictures that refer to this PPS are monochrome. Equal to 0 specifies that the pictures that refer to this PPS have multiple components.

luma_bit_depth_entry_minus8 (guint8) –

plus 8 specifies the bit depth of the luma component of the entries of the palette predictor initializer.

chroma_bit_depth_entry_minus8 (guint32) –

plus 8 specifies the bit depth of the chroma components of the entries of the palette predictor initializer.

pps_palette_predictor_initializer (guint32[3][128] ) –

specifies the value of the comp-th component of the i-th palette entry in the PPS that is used to initialize the array PredictorPaletteEntries. Defines the _GstH265PPSSccExtensionParams

Since : 1.18


GstH265Parser

H265 NAL Parser (opaque structure).


GstH265PicTiming

struct _GstH265PicTiming
{
  guint8 pic_struct;
  guint8 source_scan_type;
  guint8 duplicate_flag;

  guint8 au_cpb_removal_delay_minus1;
  guint8 pic_dpb_output_delay;
  guint8 pic_dpb_output_du_delay;
  guint32 num_decoding_units_minus1;
  guint8 du_common_cpb_removal_delay_flag;
  guint8 du_common_cpb_removal_delay_increment_minus1;
  guint32 *num_nalus_in_du_minus1;
  guint8 *du_cpb_removal_delay_increment_minus1;
};

Fields

pic_struct (guint8) –
No description available
source_scan_type (guint8) –
No description available
duplicate_flag (guint8) –
No description available
au_cpb_removal_delay_minus1 (guint8) –
No description available
pic_dpb_output_delay (guint8) –
No description available
pic_dpb_output_du_delay (guint8) –
No description available
num_decoding_units_minus1 (guint32) –
No description available
du_common_cpb_removal_delay_flag (guint8) –
No description available
du_common_cpb_removal_delay_increment_minus1 (guint8) –
No description available
num_nalus_in_du_minus1 (guint32 *) –
No description available
du_cpb_removal_delay_increment_minus1 (guint8 *) –
No description available

GstH265PredWeightTable

struct _GstH265PredWeightTable
{
  guint8 luma_log2_weight_denom;
  gint8 delta_chroma_log2_weight_denom;

  guint8 luma_weight_l0_flag[15];
  guint8  chroma_weight_l0_flag[15];
  gint8 delta_luma_weight_l0[15];
  gint8 luma_offset_l0[15];
  gint8 delta_chroma_weight_l0 [15][2];
  gint16 delta_chroma_offset_l0 [15][2];

  guint8 luma_weight_l1_flag[15];
  guint8 chroma_weight_l1_flag[15];
  gint8 delta_luma_weight_l1[15];
  gint8 luma_offset_l1[15];
  gint8 delta_chroma_weight_l1[15][2];
  gint16 delta_chroma_offset_l1[15][2];
};

Fields

luma_log2_weight_denom (guint8) –
No description available
delta_chroma_log2_weight_denom (gint8) –
No description available
luma_weight_l0_flag (guint8[15] ) –
No description available
chroma_weight_l0_flag (guint8[15] ) –
No description available
delta_luma_weight_l0 (gint8[15] ) –
No description available
luma_offset_l0 (gint8[15] ) –
No description available
delta_chroma_weight_l0 (gint8[15][2] ) –
No description available
delta_chroma_offset_l0 (gint16[15][2] ) –
No description available
luma_weight_l1_flag (guint8[15] ) –
No description available
chroma_weight_l1_flag (guint8[15] ) –
No description available
delta_luma_weight_l1 (gint8[15] ) –
No description available
luma_offset_l1 (gint8[15] ) –
No description available
delta_chroma_weight_l1 (gint8[15][2] ) –
No description available
delta_chroma_offset_l1 (gint16[15][2] ) –
No description available

GstH265ProfileTierLevel

struct _GstH265ProfileTierLevel {
  guint8 profile_space;
  guint8 tier_flag;
  guint8 profile_idc;

  guint8 profile_compatibility_flag[32];

  guint8 progressive_source_flag;
  guint8 interlaced_source_flag;
  guint8 non_packed_constraint_flag;
  guint8 frame_only_constraint_flag;

  guint8 max_12bit_constraint_flag;
  guint8 max_10bit_constraint_flag;
  guint8 max_8bit_constraint_flag;
  guint8 max_422chroma_constraint_flag;
  guint8 max_420chroma_constraint_flag;
  guint8 max_monochrome_constraint_flag;
  guint8 intra_constraint_flag;
  guint8 one_picture_only_constraint_flag;
  guint8 lower_bit_rate_constraint_flag;
  guint8 max_14bit_constraint_flag;

  guint8 level_idc;

  guint8 sub_layer_profile_present_flag[6];
  guint8 sub_layer_level_present_flag[6];

  guint8 sub_layer_profile_space[6];
  guint8 sub_layer_tier_flag[6];
  guint8 sub_layer_profile_idc[6];
  guint8 sub_layer_profile_compatibility_flag[6][32];
  guint8 sub_layer_progressive_source_flag[6];
  guint8 sub_layer_interlaced_source_flag[6];
  guint8 sub_layer_non_packed_constraint_flag[6];
  guint8 sub_layer_frame_only_constraint_flag[6];
  guint8 sub_layer_level_idc[6];
};

Define ProfileTierLevel parameters

Fields

profile_space (guint8) –

specifies the context for the interpretation of general_profile_idc and general_profile_combatibility_flag

tier_flag (guint8) –

the tier context for the interpretation of general_level_idc

profile_idc (guint8) –

profile id

profile_compatibility_flag (guint8[32] ) –

compatibility flags

progressive_source_flag (guint8) –

flag to indicate the type of stream

interlaced_source_flag (guint8) –

flag to indicate the type of stream

non_packed_constraint_flag (guint8) –

indicate the presence of frame packing arrangement sei message

frame_only_constraint_flag (guint8) –

recognize the field_seq_flag

max_12bit_constraint_flag (guint8) –

used to define profile extensions, see Annex A

max_10bit_constraint_flag (guint8) –

used to define profile extensions, see Annex A

max_8bit_constraint_flag (guint8) –

used to define profile extensions, see Annex A

max_422chroma_constraint_flag (guint8) –

used to define profile extensions, see Annex A

max_420chroma_constraint_flag (guint8) –

used to define profile extensions, see Annex A

max_monochrome_constraint_flag (guint8) –

used to define profile extensions, see Annex A

intra_constraint_flag (guint8) –

used to define profile extensions, see Annex A

one_picture_only_constraint_flag (guint8) –

used to define profile extensions, see Annex A

lower_bit_rate_constraint_flag (guint8) –

used to define profile extensions, see Annex A

max_14bit_constraint_flag (guint8) –

used to define profile extensions, see Annex A level idc: indicate the level which the CVS confirms

level_idc (guint8) –
No description available
sub_layer_profile_present_flag (guint8[6] ) –

sublayer profile presence ind

sub_layer_level_present_flag (guint8[6] ) –

sublayer level presence indicator.

sub_layer_profile_space (guint8[6] ) –

profile space for sublayers

sub_layer_tier_flag (guint8[6] ) –

tier flags for sublayers.

sub_layer_profile_idc (guint8[6] ) –

conformant profile indicator for sublayers.

sub_layer_profile_compatibility_flag (guint8[6][32] ) –
No description available
sub_layer_progressive_source_flag (guint8[6] ) –

progressive stream indicator for sublayer

sub_layer_interlaced_source_flag (guint8[6] ) –

interlaced stream indicator for sublayer

sub_layer_non_packed_constraint_flag (guint8[6] ) –

indicate the presence of frame packing arrangement sei message with in sublayers

sub_layer_frame_only_constraint_flag (guint8[6] ) –

recognize the sublayer specific field_seq_flag

sub_layer_level_idc (guint8[6] ) –

indicate the sublayer specific level


GstH265RecoveryPoint

struct _GstH265RecoveryPoint
{
  gint32 recovery_poc_cnt;
  guint8 exact_match_flag;
  guint8 broken_link_flag;
};

Fields

recovery_poc_cnt (gint32) –
No description available
exact_match_flag (guint8) –
No description available
broken_link_flag (guint8) –
No description available

GstH265RefPicListModification

struct _GstH265RefPicListModification
{
  guint8 ref_pic_list_modification_flag_l0;
  guint32 list_entry_l0[15];
  guint8 ref_pic_list_modification_flag_l1;
  guint32 list_entry_l1[15];
};

Fields

ref_pic_list_modification_flag_l0 (guint8) –
No description available
list_entry_l0 (guint32[15] ) –
No description available
ref_pic_list_modification_flag_l1 (guint8) –
No description available
list_entry_l1 (guint32[15] ) –
No description available

GstH265RegisteredUserData

struct _GstH265RegisteredUserData
{
  guint8 country_code;
  guint8 country_code_extension;
  const guint8 *data;
  guint size;
};

The User data registered by Rec. ITU-T T.35 SEI message. country_code: an itu_t_t35_country_code. country_code_extension: an itu_t_t35_country_code_extension_byte. Should be ignored when country_code is not 0xff data: the data of itu_t_t35_payload_byte excluding country_code and country_code_extension size: the size of data in bytes

Fields

country_code (guint8) –
No description available
country_code_extension (guint8) –
No description available
data (guint8 *) –
No description available
size (guint) –
No description available

GstH265SEIMessage

struct _GstH265SEIMessage
{
  GstH265SEIPayloadType payloadType;

  union {
    GstH265BufferingPeriod buffering_period;
    GstH265PicTiming pic_timing;
    GstH265RegisteredUserData registered_user_data;
    GstH265RecoveryPoint recovery_point;
    GstH265TimeCode time_code;
    GstH265MasteringDisplayColourVolume mastering_display_colour_volume;
    GstH265ContentLightLevel content_light_level;
    GstH265UserDataUnregistered user_data_unregistered;
    /* ... could implement more */
  } payload;
};

Fields

payloadType (GstH265SEIPayloadType) –
No description available
payload.buffering_period (GstH265BufferingPeriod) –
No description available
payload.pic_timing (GstH265PicTiming) –
No description available
payload.registered_user_data (GstH265RegisteredUserData) –
No description available
payload.recovery_point (GstH265RecoveryPoint) –
No description available
payload.time_code (GstH265TimeCode) –
No description available
payload.mastering_display_colour_volume (GstH265MasteringDisplayColourVolume) –
No description available
payload.content_light_level (GstH265ContentLightLevel) –
No description available
payload.user_data_unregistered (GstH265UserDataUnregistered) –

User Data Unregistered


GstH265SPS

struct _GstH265SPS
{
  guint8 id;

  /**
   * _GstH265SPS.vps_id:
   *
   * The ID of the VPS. This is used to store the ID until the VPS is
   * parsed in case its placed after the SPS.
   * Since: 1.22
   */
  guint8 vps_id;
  GstH265VPS *vps;

  guint8 max_sub_layers_minus1;
  guint8 temporal_id_nesting_flag;

  GstH265ProfileTierLevel profile_tier_level;

  guint8 chroma_format_idc;
  guint8 separate_colour_plane_flag;
  guint16 pic_width_in_luma_samples;
  guint16 pic_height_in_luma_samples;

  guint8 conformance_window_flag;
  /* if conformance_window_flag */
  guint32 conf_win_left_offset;
  guint32 conf_win_right_offset;
  guint32 conf_win_top_offset;
  guint32 conf_win_bottom_offset;

  guint8 bit_depth_luma_minus8;
  guint8 bit_depth_chroma_minus8;
  guint8 log2_max_pic_order_cnt_lsb_minus4;

  guint8 sub_layer_ordering_info_present_flag;
  guint8 max_dec_pic_buffering_minus1[GST_H265_MAX_SUB_LAYERS];
  guint8 max_num_reorder_pics[GST_H265_MAX_SUB_LAYERS];
  guint8 max_latency_increase_plus1[GST_H265_MAX_SUB_LAYERS];

  guint8 log2_min_luma_coding_block_size_minus3;
  guint8 log2_diff_max_min_luma_coding_block_size;
  guint8 log2_min_transform_block_size_minus2;
  guint8 log2_diff_max_min_transform_block_size;
  guint8 max_transform_hierarchy_depth_inter;
  guint8 max_transform_hierarchy_depth_intra;

  guint8 scaling_list_enabled_flag;
  /* if scaling_list_enabled_flag */
  guint8 scaling_list_data_present_flag;

  GstH265ScalingList scaling_list;

  guint8 amp_enabled_flag;
  guint8 sample_adaptive_offset_enabled_flag;
  guint8 pcm_enabled_flag;
  /* if pcm_enabled_flag */
  guint8 pcm_sample_bit_depth_luma_minus1;
  guint8 pcm_sample_bit_depth_chroma_minus1;
  guint8 log2_min_pcm_luma_coding_block_size_minus3;
  guint8 log2_diff_max_min_pcm_luma_coding_block_size;
  guint8 pcm_loop_filter_disabled_flag;

  guint8 num_short_term_ref_pic_sets;
  GstH265ShortTermRefPicSet short_term_ref_pic_set[65];

  guint8 long_term_ref_pics_present_flag;
  /* if long_term_ref_pics_present_flag */
  guint8 num_long_term_ref_pics_sps;
  guint16 lt_ref_pic_poc_lsb_sps[32];
  guint8 used_by_curr_pic_lt_sps_flag[32];

  guint8 temporal_mvp_enabled_flag;
  guint8 strong_intra_smoothing_enabled_flag;
  guint8 vui_parameters_present_flag;

  /* if vui_parameters_present_flag */
  GstH265VUIParams vui_params;

  guint8 sps_extension_flag;

  /* if sps_extension_present_flag */
  guint8 sps_range_extension_flag;
  guint8 sps_multilayer_extension_flag;
  guint8 sps_3d_extension_flag;
  guint8 sps_scc_extension_flag;
  guint8 sps_extension_4bits;

  /* if sps_range_extension_flag */
  /**
   * _GstH265SPS.sps_extension_params:
   *
   * Since: 1.22
   */
  GstH265SPSExtensionParams sps_extension_params;
  /* if sps_scc_extension_flag */
  GstH265SPSSccExtensionParams sps_scc_extension_params;

  /* calculated values */
  guint8 chroma_array_type;
  gint width, height;
  gint crop_rect_width, crop_rect_height;
  gint crop_rect_x, crop_rect_y;
  gint fps_num, fps_den;
  gboolean valid;
};

H265 Sequence Parameter Set (SPS)

Fields

id (guint8) –

The ID of the sequence parameter set

vps_id (guint8) –

The ID of the VPS. This is used to store the ID until the VPS is parsed in case its placed after the SPS.

vps (GstH265VPS *) –
No description available
max_sub_layers_minus1 (guint8) –
No description available
temporal_id_nesting_flag (guint8) –
No description available
profile_tier_level (GstH265ProfileTierLevel) –
No description available
chroma_format_idc (guint8) –
No description available
separate_colour_plane_flag (guint8) –
No description available
pic_width_in_luma_samples (guint16) –
No description available
pic_height_in_luma_samples (guint16) –
No description available
conformance_window_flag (guint8) –
No description available
conf_win_left_offset (guint32) –
No description available
conf_win_right_offset (guint32) –
No description available
conf_win_top_offset (guint32) –
No description available
conf_win_bottom_offset (guint32) –
No description available
bit_depth_luma_minus8 (guint8) –
No description available
bit_depth_chroma_minus8 (guint8) –
No description available
log2_max_pic_order_cnt_lsb_minus4 (guint8) –
No description available
sub_layer_ordering_info_present_flag (guint8) –
No description available
max_dec_pic_buffering_minus1 (guint8[8] ) –
No description available
max_num_reorder_pics (guint8[8] ) –
No description available
max_latency_increase_plus1 (guint8[8] ) –
No description available
log2_min_luma_coding_block_size_minus3 (guint8) –
No description available
log2_diff_max_min_luma_coding_block_size (guint8) –
No description available
log2_min_transform_block_size_minus2 (guint8) –
No description available
log2_diff_max_min_transform_block_size (guint8) –
No description available
max_transform_hierarchy_depth_inter (guint8) –
No description available
max_transform_hierarchy_depth_intra (guint8) –
No description available
scaling_list_enabled_flag (guint8) –
No description available
scaling_list_data_present_flag (guint8) –
No description available
scaling_list (GstH265ScalingList) –
No description available
amp_enabled_flag (guint8) –
No description available
sample_adaptive_offset_enabled_flag (guint8) –
No description available
pcm_enabled_flag (guint8) –
No description available
pcm_sample_bit_depth_luma_minus1 (guint8) –
No description available
pcm_sample_bit_depth_chroma_minus1 (guint8) –
No description available
log2_min_pcm_luma_coding_block_size_minus3 (guint8) –
No description available
log2_diff_max_min_pcm_luma_coding_block_size (guint8) –
No description available
pcm_loop_filter_disabled_flag (guint8) –
No description available
num_short_term_ref_pic_sets (guint8) –
No description available
short_term_ref_pic_set (GstH265ShortTermRefPicSet[65] ) –
No description available
long_term_ref_pics_present_flag (guint8) –
No description available
num_long_term_ref_pics_sps (guint8) –
No description available
lt_ref_pic_poc_lsb_sps (guint16[32] ) –
No description available
used_by_curr_pic_lt_sps_flag (guint8[32] ) –
No description available
temporal_mvp_enabled_flag (guint8) –
No description available
strong_intra_smoothing_enabled_flag (guint8) –
No description available
vui_parameters_present_flag (guint8) –
No description available
vui_params (GstH265VUIParams) –
No description available
sps_extension_flag (guint8) –
No description available
sps_range_extension_flag (guint8) –
No description available
sps_multilayer_extension_flag (guint8) –
No description available
sps_3d_extension_flag (guint8) –
No description available
sps_scc_extension_flag (guint8) –
No description available
sps_extension_4bits (guint8) –
No description available
sps_extension_params (GstH265SPSExtensionParams) –
No description available
sps_scc_extension_params (GstH265SPSSccExtensionParams) –
No description available
chroma_array_type (guint8) –
No description available
width (gint) –
No description available
height (gint) –
No description available
crop_rect_width (gint) –
No description available
crop_rect_height (gint) –
No description available
crop_rect_x (gint) –
No description available
crop_rect_y (gint) –
No description available
fps_num (gint) –
No description available
fps_den (gint) –
No description available
valid (gboolean) –
No description available

GstH265SPSExtensionParams

struct _GstH265SPSExtensionParams {
  guint8 transform_skip_rotation_enabled_flag;
  guint8 transform_skip_context_enabled_flag;
  guint8 implicit_rdpcm_enabled_flag;
  guint8 explicit_rdpcm_enabled_flag;
  guint8 extended_precision_processing_flag;
  guint8 intra_smoothing_disabled_flag;
  guint8 high_precision_offsets_enabled_flag;
  guint8 persistent_rice_adaptation_enabled_flag;
  guint8 cabac_bypass_alignment_enabled_flag;
};

Defines the GstH265SPSExtensionParams

Fields

transform_skip_rotation_enabled_flag (guint8) –

TRUE specifies that a rotation is applied to the residual data block from intra 4X4 blocks coded using a transform skip operation.

transform_skip_context_enabled_flag (guint8) –

TRUE specifies tspecifies that a particular context is used for the parsing of the sig_coeff_flag for transform blocks with a skipped transform.

implicit_rdpcm_enabled_flag (guint8) –
No description available
explicit_rdpcm_enabled_flag (guint8) –
No description available
extended_precision_processing_flag (guint8) –

TRUE specifies that an extended dynamic range is used for coefficient parsing and inverse transform processing

intra_smoothing_disabled_flag (guint8) –

TRUE specifies that the filtering process of neighbouring samples is unconditionally disabled for intra prediction

high_precision_offsets_enabled_flag (guint8) –

TRUE specifies that weighted prediction offset values are signalled using a bit-depth-dependent precision.

persistent_rice_adaptation_enabled_flag (guint8) –

TRUE specifies that the Rice parameter derivation for the binarization of coeff_abs_level_remaining[] is initialized at the start of each sub-block using mode dependent statistics accumulated from previous sub-blocks.

cabac_bypass_alignment_enabled_flag (guint8) –

TRUE specifies that a context-based adaptive binary arithmetic coding (CABAC) alignment process is used prior to bypass decoding of the syntax elements coeff_sign_flag[] and coeff_abs_level_remaining[]


GstH265SPSSccExtensionParams

struct _GstH265SPSSccExtensionParams {
  guint8 sps_curr_pic_ref_enabled_flag;
  guint8 palette_mode_enabled_flag;
  guint8 palette_max_size;
  guint8 delta_palette_max_predictor_size;
  guint8 sps_palette_predictor_initializers_present_flag;
  guint8 sps_num_palette_predictor_initializer_minus1;
  guint32 sps_palette_predictor_initializer[3][128];
  guint8 motion_vector_resolution_control_idc;
  guint8 intra_boundary_filtering_disabled_flag;
};

Fields

sps_curr_pic_ref_enabled_flag (guint8) –

equal to 1 specifies that a picture in the CVS may be included in a reference picture list of a slice of the picture itself.

palette_mode_enabled_flag (guint8) –

equal to 1 specifies that the decoding process for palette mode may be used for intra blocks. Equal to 0 specifies that the decoding process for palette mode is not applied.

palette_max_size (guint8) –

specifies the maximum allowed palette size.

delta_palette_max_predictor_size (guint8) –

specifies the difference between the maximum allowed palette predictor size and the maximum allowed palette size.

sps_palette_predictor_initializers_present_flag (guint8) –

equal to 1 specifies that the sequence palette predictors are initialized using the sps_palette_predictor_initializer specified in clause 7.3.2.2.3.

sps_num_palette_predictor_initializer_minus1 (guint8) –

plus 1 specifies the number of entries in the sequence palette predictor initializer.

sps_palette_predictor_initializer (guint32[3][128] ) –

specifies the value of the comp-th component of the i-th palette entry in the SPS that is used to initialize the array PredictorPaletteEntries.

motion_vector_resolution_control_idc (guint8) –

controls the presence and inference of the use_integer_mv_flag that specifies the resolution of motion vectors for inter prediction.

intra_boundary_filtering_disabled_flag (guint8) –

equal to 1 specifies that the intra boundary filtering process is unconditionally disabled for intra prediction. Defines the _GstH265SPSSccExtensionParams

Since : 1.18


GstH265ScalingList

struct _GstH265ScalingList {

  gint16 scaling_list_dc_coef_minus8_16x16[6];
  gint16 scaling_list_dc_coef_minus8_32x32[2];

  guint8 scaling_lists_4x4 [6][16];
  guint8 scaling_lists_8x8 [6][64];
  guint8 scaling_lists_16x16 [6][64];
  guint8 scaling_lists_32x32 [2][64];
};

Defines the GstH265ScalingList

Fields

scaling_list_dc_coef_minus8_16x16 (gint16[6] ) –

this plus 8 specifies the DC Coefficient values for 16x16 scaling list

scaling_list_dc_coef_minus8_32x32 (gint16[2] ) –

this plus 8 specifies the DC Coefficient values for 32x32 scaling list

scaling_lists_4x4 (guint8[6][16] ) –

4x4 scaling list

scaling_lists_8x8 (guint8[6][64] ) –

8x8 scaling list

scaling_lists_16x16 (guint8[6][64] ) –

16x16 scaling list guint8 scaling_lists_32x32: 32x32 scaling list

scaling_lists_32x32 (guint8[2][64] ) –
No description available

GstH265ShortTermRefPicSet

struct _GstH265ShortTermRefPicSet
{
  guint8 inter_ref_pic_set_prediction_flag;
  guint8 delta_idx_minus1;
  guint8 delta_rps_sign;
  guint16 abs_delta_rps_minus1;

  /* calculated values */
  guint8 NumDeltaPocs;
  guint8 NumNegativePics;
  guint8 NumPositivePics;
  guint8 UsedByCurrPicS0[16];
  guint8 UsedByCurrPicS1[16];
  gint32 DeltaPocS0[16];
  gint32 DeltaPocS1[16];
  guint8 NumDeltaPocsOfRefRpsIdx;
};

Defines the GstH265ShortTermRefPicSet params

Fields

inter_ref_pic_set_prediction_flag (guint8) –

TRUE specifies that the stRpsIdx-th candidate short-term RPS is predicted from another candidate short-term RPS

delta_idx_minus1 (guint8) –

plus 1 specifies the difference between the value of source and candidate short term RPS.

delta_rps_sign (guint8) –

delta_rps_sign and abs_delta_rps_minus1 together specify the value of the variable deltaRps.

abs_delta_rps_minus1 (guint16) –

delta_rps_sign and abs_delta_rps_minus1 together specify the value of the variable deltaRps

NumDeltaPocs (guint8) –

sum of NumNegativePics and NumPositivePics.

NumNegativePics (guint8) –

Derived value depending on inter_ref_pic_set_prediction_flag. If inter_ref_pic_set_prediction_flag is equal to 0, this specifies the number of entries in the stRpsIdx-th candidate short-term RPS that have poc values less than the poc of the current picture.

NumPositivePics (guint8) –

Derived value depending on inter_ref_pic_set_prediction_flag. If inter_ref_pic_set_prediction_flag is equal to 0, this specifies the number of entires in the stRpsIdx-th candidate short-term RPS that have poc values greater than the poc value of the current picture.

UsedByCurrPicS0 (guint8[16] ) –

Derived value depending on inter_ref_pic_set_prediction_flag. If inter_ref_pic_set_prediction_flag is equal to 0, equal to zero specifies that the i-th entry in the stRpsIdx-th candidate short-term RPS that has poc value less than of the current picture is not used for reference by the current picture

UsedByCurrPicS1 (guint8[16] ) –

Derived value depending on inter_ref_pic_set_prediction_flag. If inter_ref_pic_set_prediction_flag is equal to 0, equal to zero specifies that the i-th entry in the current candidate short-term RPS that has poc value greater than that of the current picture is not used for reference by the current picture.

DeltaPocS0 (gint32[16] ) –

Derived value depending on inter_ref_pic_set_prediction_flag. See 7.4.8 Short-term reference picture set semantics

DeltaPocS1 (gint32[16] ) –

Derived value depending on inter_ref_pic_set_prediction_flag. See 7.4.8 Short-term reference picture set semantics

NumDeltaPocsOfRefRpsIdx (guint8) –

The value of NumDeltaPocs[RefRpsIdx]. If inter_ref_pic_set_prediction_flag is equal to 0, this value should be ignored (Since: 1.18)


GstH265SliceHdr

struct _GstH265SliceHdr
{
  guint8 first_slice_segment_in_pic_flag;
  guint8 no_output_of_prior_pics_flag;

  GstH265PPS *pps;

  guint8 dependent_slice_segment_flag;
  guint32 segment_address;

  guint8 type;

  guint8 pic_output_flag;
  guint8 colour_plane_id;
  guint16 pic_order_cnt_lsb;

  guint8  short_term_ref_pic_set_sps_flag;
  GstH265ShortTermRefPicSet short_term_ref_pic_sets;
  guint8 short_term_ref_pic_set_idx;

  guint8 num_long_term_sps;
  guint8 num_long_term_pics;
  guint8 lt_idx_sps[16];
  guint32 poc_lsb_lt[16];
  guint8 used_by_curr_pic_lt_flag[16];
  guint8 delta_poc_msb_present_flag[16];
  guint32 delta_poc_msb_cycle_lt[16];

  guint8 temporal_mvp_enabled_flag;
  guint8 sao_luma_flag;
  guint8 sao_chroma_flag;
  guint8 num_ref_idx_active_override_flag;
  guint8 num_ref_idx_l0_active_minus1;
  guint8 num_ref_idx_l1_active_minus1;

  GstH265RefPicListModification ref_pic_list_modification;

  guint8 mvd_l1_zero_flag;
  guint8 cabac_init_flag;
  guint8 collocated_from_l0_flag;
  guint8 collocated_ref_idx;

  GstH265PredWeightTable pred_weight_table;

  guint8 five_minus_max_num_merge_cand;
  guint8 use_integer_mv_flag;

  gint8 qp_delta;
  gint8 cb_qp_offset;
  gint8 cr_qp_offset;
  gint8 slice_act_y_qp_offset;
  gint8 slice_act_cb_qp_offset;
  gint8 slice_act_cr_qp_offset;

  guint8 cu_chroma_qp_offset_enabled_flag;

  guint8 deblocking_filter_override_flag;
  guint8 deblocking_filter_disabled_flag;
  gint8 beta_offset_div2;
  gint8 tc_offset_div2;

  guint8 loop_filter_across_slices_enabled_flag;

  guint32 num_entry_point_offsets;
  guint8 offset_len_minus1;
  guint32 *entry_point_offset_minus1;

  /* calculated values */

  gint NumPocTotalCurr;
  /* Size of the slice_header() in bits */
  guint header_size;
  /* Number of emulation prevention bytes (EPB) in this slice_header() */
  guint n_emulation_prevention_bytes;

  /* Size of short_term_ref_pic_set() after emulation preventation bytes are
   * removed, in bits */
  guint short_term_ref_pic_set_size;

  /**
   * _GstH265SliceHdr.long_term_ref_pic_set_size:
   *
   * The calculated size of the branch `if( long_term_ref_pics_present_flag )`
   * inside `slice_segment_header()` syntax in bits.
   *
   * Since: 1.22
   */
  guint long_term_ref_pic_set_size;
};

Fields

first_slice_segment_in_pic_flag (guint8) –

equal to 1 if this slice segment is the first slice segment of the picture in decoding order

no_output_of_prior_pics_flag (guint8) –

affects the output of previously-decoded pictures in the decoded picture buffer after the decoding of an IDR or a BLA picture that is not the first picture in the bitstream as specified in Annex C

pps (GstH265PPS *) –

a GstH265PPS

dependent_slice_segment_flag (guint8) –

equal to 1 if the value of each slice segment header syntax element that is not present is inferred to be equal to the value of corresponding slice segment header syntax element in the slice header.

segment_address (guint32) –

the address of the first CTB in the slice segment

type (guint8) –

slice type (B, P, or I)

pic_output_flag (guint8) –

affects the decoded picture output and removal processes as specified in Annex C.

colour_plane_id (guint8) –

specifies the colour plane associated with the current slice RBSP when separate_colour_plane_flag is equal to 1

pic_order_cnt_lsb (guint16) –

the picture order count modulo MaxPicOrderCntLsb for the current picture

short_term_ref_pic_set_sps_flag (guint8) –

equal to 1 specifies that the short-term RPS of the current picture is derived based on the active SPS.

short_term_ref_pic_sets (GstH265ShortTermRefPicSet) –

a GstH265ShortTermRefPicSet structure

short_term_ref_pic_set_idx (guint8) –

the index of st_ref_pic_set syntax structure that is used for derivation of the short-term RPS of the current picture.

num_long_term_sps (guint8) –

the number of entries in the long-term RPS of current picture that are derived based on the syntax in active SPS.

num_long_term_pics (guint8) –

the number of entries in the long-term RPS of the current picture that are directly signalled in the slice header.

lt_idx_sps (guint8[16] ) –

the index of candidate long-term reference pictures specified in the active SPS.

poc_lsb_lt (guint32[16] ) –

the value of the picture order count modulo MaxPicOrderCntLsb of the each entry in the long-term RPS of the current picture.

used_by_curr_pic_lt_flag (guint8[16] ) –

equal to 0 if the entry in the long-term RPS of the current picture is not used for reference by the current picture.

delta_poc_msb_present_flag (guint8[16] ) –

equal to 1 if i-th delta_poc_msb_cycle_lt[] is present.

delta_poc_msb_cycle_lt (guint32[16] ) –

used to determine the value of the most significant bits of the picture order count value of the i-th entry in the long-term RPS of the current picture.

temporal_mvp_enabled_flag (guint8) –

whether temporal motion vector predictors can be used for inter prediction.

sao_luma_flag (guint8) –

equal to 1 if SAO is enabled for the luma component in the current slice.

sao_chroma_flag (guint8) –

equal to 1 if SAO is enabled for the chroma component in the current slice.

num_ref_idx_active_override_flag (guint8) –

equal to 1 specifies that the syntax elements num_ref_idx_l0_active_minus1 and num_ref_idx_l1_active_minus1 are present.

num_ref_idx_l0_active_minus1 (guint8) –

the maximum reference index for reference picture list 0 that may be used to decode the slice.

num_ref_idx_l1_active_minus1 (guint8) –

the maximum reference index for reference picture list 1 that may be used to decode the slice.

mvd_l1_zero_flag (guint8) –

equal to 1 if the mvd_coding sytanx structure is not parsed

cabac_init_flag (guint8) –

specifies the method for determining the initialization table used in the initialization process for context variables.

collocated_from_l0_flag (guint8) –

equal to 1 specifies that the collocated picture used for temporal motion vector prediction is derived from reference picture list 0.

collocated_ref_idx (guint8) –

the reference index of the collocated picture used for temporal motion vector prediction.

five_minus_max_num_merge_cand (guint8) –

specifies the maximum number of merging motion vector prediction (MVP) candidates supported in the slice.

use_integer_mv_flag (guint8) –

equal to 1 specifies that the resolution of motion vectors for inter prediction in the current slice is integer. (Since: 1.18)

qp_delta (gint8) –

specifies the inital value of QPy to be used for the coding blocks in the slice.

cb_qp_offset (gint8) –

a difference to be added to the value of pps_cb_qp_offset.

cr_qp_offset (gint8) –

a difference to be added to the value of pps_cr_qp_offset.

slice_act_y_qp_offset (gint8) –

specify offsets to the quantization parameter values qP derived in clause 8.6.2 for luma components. (Since: 1.18)

slice_act_cb_qp_offset (gint8) –

specify offsets to the quantization parameter values qP derived in clause 8.6.2 for Cb components. (Since: 1.18)

slice_act_cr_qp_offset (gint8) –

specify offsets to the quantization parameter values qP derived in clause 8.6.2 for Cr components. (Since: 1.18)

cu_chroma_qp_offset_enabled_flag (guint8) –

equal to 1 if the cu_chroma_qp_offset_flag may be present in the transform unit syntax. (Since: 1.18)

deblocking_filter_override_flag (guint8) –

equal to 1 if deblocking paramertes are present in the slice header.

deblocking_filter_disabled_flag (guint8) –

equal to 1 specifies that the operation of the deblocking filter is not applied for the current slice.

beta_offset_div2 (gint8) –

deblocking parameter offset for beta divided by 2 for the current slice.

tc_offset_div2 (gint8) –

deblocking parameter offset for tC divided by 2 for the current slice.

loop_filter_across_slices_enabled_flag (guint8) –

equal to 1 specifies that in-loop filtering operation may be performed across the left and upper boundaries of the current slice.

num_entry_point_offsets (guint32) –

specifies the number of entry_point_offset_minus1 syntax elements in the slice header.

offset_len_minus1 (guint8) –

specifies the length of the entry_point_minus1 syntax elements in bits.

entry_point_offset_minus1 (guint32 *) –

the entry point offset in bytes.

NumPocTotalCurr (gint) –

calculated NumPocTotalCurr which is used for decoding process for reference picture set

header_size (guint) –

the calculated size of the slice_header() in bits.

n_emulation_prevention_bytes (guint) –

number of emulation prevention bytes (EPB) in this slice_header()

short_term_ref_pic_set_size (guint) –

the calculated size of short_term_ref_pic_set() in bits. (Since: 1.18)

long_term_ref_pic_set_size (guint) –

The calculated size of the branch if( long_term_ref_pics_present_flag ) inside slice_segment_header() syntax in bits.


GstH265SubLayerHRDParams

struct _GstH265SubLayerHRDParams
{
  guint32 bit_rate_value_minus1[32];
  guint32 cpb_size_value_minus1[32];

  guint32 cpb_size_du_value_minus1[32];
  guint32 bit_rate_du_value_minus1[32];

  guint8 cbr_flag[32];
};

Defines the Sublayer HRD parameters

Fields

bit_rate_value_minus1 (guint32[32] ) –

togeter with bit_rate_scale, it specifies the maximum input bitrate when the CPB operates at the access unit level

cpb_size_value_minus1 (guint32[32] ) –

is used together with cpb_size_scale to specify the CPB size when the CPB operates at the access unit level

cpb_size_du_value_minus1 (guint32[32] ) –

is used together with cpb_size_du_scale to specify the CPB size when the CPB operates at sub-picture level

bit_rate_du_value_minus1 (guint32[32] ) –

together with bit_rate_scale, it specifies the maximum input bit rate when the CPB operates at the sub-picture level

cbr_flag (guint8[32] ) –

indicate whether HSS operates in intermittent bit rate mode or constant bit rate mode.


GstH265TimeCode

struct _GstH265TimeCode
{
  guint8 num_clock_ts;
  guint8 clock_timestamp_flag[3];
  guint8 units_field_based_flag[3];
  guint8 counting_type[3];
  guint8 full_timestamp_flag[3];
  guint8 discontinuity_flag[3];
  guint8 cnt_dropped_flag[3];
  guint16 n_frames[3];
  guint8 seconds_flag[3];
  guint8 seconds_value[3];
  guint8 minutes_flag[3];
  guint8 minutes_value[3];
  guint8 hours_flag[3];
  guint8 hours_value[3];
  guint8 time_offset_length[3];
  guint32 time_offset_value[3];
};

The time code SEI message provides time code information similar to that defined by SMPTE ST 12-1 (2014) for field(s) or frame(s) of the current picture.

Fields

num_clock_ts (guint8) –
No description available
clock_timestamp_flag (guint8[3] ) –
No description available
units_field_based_flag (guint8[3] ) –
No description available
counting_type (guint8[3] ) –
No description available
full_timestamp_flag (guint8[3] ) –
No description available
discontinuity_flag (guint8[3] ) –
No description available
cnt_dropped_flag (guint8[3] ) –
No description available
n_frames (guint16[3] ) –
No description available
seconds_flag (guint8[3] ) –
No description available
seconds_value (guint8[3] ) –
No description available
minutes_flag (guint8[3] ) –
No description available
minutes_value (guint8[3] ) –
No description available
hours_flag (guint8[3] ) –
No description available
hours_value (guint8[3] ) –
No description available
time_offset_length (guint8[3] ) –
No description available
time_offset_value (guint32[3] ) –
No description available

GstH265UserDataUnregistered

struct _GstH265UserDataUnregistered
{
  guint8 uuid[16];
  const guint8 *data;
  guint size;
};

The User data unregistered SEI message syntax.

Fields

uuid (guint8[16] ) –

an uuid_iso_iec_11578.

data (guint8 *) –

the data of user_data_payload_byte

size (guint) –

the size of data in bytes

Since : 1.24


GstH265VPS

struct _GstH265VPS {
  guint8 id;

  guint8 base_layer_internal_flag;
  guint8 base_layer_available_flag;

  guint8 max_layers_minus1;
  guint8 max_sub_layers_minus1;
  guint8 temporal_id_nesting_flag;

  GstH265ProfileTierLevel profile_tier_level;

  guint8 sub_layer_ordering_info_present_flag;
  guint8 max_dec_pic_buffering_minus1[GST_H265_MAX_SUB_LAYERS];
  guint8 max_num_reorder_pics[GST_H265_MAX_SUB_LAYERS];
  guint32 max_latency_increase_plus1[GST_H265_MAX_SUB_LAYERS];

  guint8 max_layer_id;
  guint16 num_layer_sets_minus1;

  guint8 timing_info_present_flag;
  guint32 num_units_in_tick;
  guint32 time_scale;
  guint8 poc_proportional_to_timing_flag;
  guint32 num_ticks_poc_diff_one_minus1;

  guint16 num_hrd_parameters;

  /* FIXME: following HRD related info should be an array */
  guint16 hrd_layer_set_idx;
  guint8 cprms_present_flag;
  GstH265HRDParams hrd_params;

  guint8 vps_extension;

  gboolean valid;
};

Defines the VPS parameters

Fields

id (guint8) –

vps id base_layer_internal_flag and base_layer_available_flag: specify availability of base layer

base_layer_internal_flag (guint8) –
No description available
base_layer_available_flag (guint8) –
No description available
max_layers_minus1 (guint8) –

should be zero, but can be other values in future

max_sub_layers_minus1 (guint8) –

specifies the maximum number of temporal sub-layers

temporal_id_nesting_flag (guint8) –

specifies whether inter prediction is additionally restricted

profile_tier_level (GstH265ProfileTierLevel) –

ProfileTierLevel info

sub_layer_ordering_info_present_flag (guint8) –

indicates the presence of vps_max_dec_pic_buffering_minus1, vps_max_num_reorder_pics and vps_max_latency_increase_plus1

max_dec_pic_buffering_minus1 (guint8[8] ) –

specifies the maximum required size of the decoded picture buffer

max_num_reorder_pics (guint8[8] ) –

indicates the maximum allowed number of pictures that can precede any picture in the CVS in decoding order

max_latency_increase_plus1 (guint32[8] ) –

is used to compute the value of VpsMaxLatencyPictures

max_layer_id (guint8) –

specifies the maximum allowed value of nuh_layer_id

num_layer_sets_minus1 (guint16) –

specifies the number of layer sets

timing_info_present_flag (guint8) –

indicate the presence of num_units_in_tick, time_scale, poc_proportional_to_timing_flag and num_hrd_parameters

num_units_in_tick (guint32) –

number of time units in a tick

time_scale (guint32) –

number of time units that pass in one second

poc_proportional_to_timing_flag (guint8) –

indicate whether the picture order count is proportional to output timin

num_ticks_poc_diff_one_minus1 (guint32) –

specifies the number of clock ticks corresponding to a difference of picture order count values equal to 1

num_hrd_parameters (guint16) –

number of hrd_parameters present

hrd_layer_set_idx (guint16) –

index to the list of layer hrd params.

cprms_present_flag (guint8) –
No description available
hrd_params (GstH265HRDParams) –

the GstH265HRDParams list

vps_extension (guint8) –
No description available
valid (gboolean) –
No description available

GstH265VUIParams

struct _GstH265VUIParams
{
  /**
   * _GstH265VUIParams.parsed:
   *
   * %TRUE indicate that VUI parameters have been parsed.
   *
   * Since: 1.22
   */
  gboolean parsed;
  guint8 aspect_ratio_info_present_flag;
  guint8 aspect_ratio_idc;
  /* if aspect_ratio_idc == 255 */
  guint16 sar_width;
  guint16 sar_height;

  guint8 overscan_info_present_flag;
  /* if overscan_info_present_flag */
  guint8 overscan_appropriate_flag;

  guint8 video_signal_type_present_flag;
  guint8 video_format;
  guint8 video_full_range_flag;
  guint8 colour_description_present_flag;
  guint8 colour_primaries;
  guint8 transfer_characteristics;
  guint8 matrix_coefficients;

  guint8 chroma_loc_info_present_flag;
  guint8 chroma_sample_loc_type_top_field;
  guint8 chroma_sample_loc_type_bottom_field;

  guint8 neutral_chroma_indication_flag;
  guint8 field_seq_flag;
  guint8 frame_field_info_present_flag;
  guint8 default_display_window_flag;
  guint32 def_disp_win_left_offset;
  guint32 def_disp_win_right_offset;
  guint32 def_disp_win_top_offset;
  guint32 def_disp_win_bottom_offset;

  guint8 timing_info_present_flag;
  /* if timing_info_present_flag */
  guint32 num_units_in_tick;
  guint32 time_scale;
  guint8 poc_proportional_to_timing_flag;
  /* if poc_proportional_to_timing_flag */
  guint32 num_ticks_poc_diff_one_minus1;
  guint8 hrd_parameters_present_flag;
  /*if hrd_parameters_present_flat */
  GstH265HRDParams hrd_params;

  guint8 bitstream_restriction_flag;
  /*  if bitstream_restriction_flag */
  guint8 tiles_fixed_structure_flag;
  guint8 motion_vectors_over_pic_boundaries_flag;
  guint8 restricted_ref_pic_lists_flag;
  guint16 min_spatial_segmentation_idc;
  guint8 max_bytes_per_pic_denom;
  guint8 max_bits_per_min_cu_denom;
  guint8 log2_max_mv_length_horizontal;
  guint8 log2_max_mv_length_vertical;

  /* calculated values */
  guint par_n;
  guint par_d;
};

The structure representing the VUI parameters.

Fields

parsed (gboolean) –

TRUE indicate that VUI parameters have been parsed.

aspect_ratio_info_present_flag (guint8) –

TRUE specifies that aspect_ratio_idc is present. FALSE specifies that aspect_ratio_idc is not present aspect_ratio_idc specifies the value of the sample aspect ratio of the luma samples sar_width indicates the horizontal size of the sample aspect ratio sar_height indicates the vertical size of the sample aspect ratio

aspect_ratio_idc (guint8) –
No description available
sar_width (guint16) –
No description available
sar_height (guint16) –
No description available
overscan_info_present_flag (guint8) –

TRUE overscan_appropriate_flag is present FALSE otherwise

overscan_appropriate_flag (guint8) –

TRUE indicates that the cropped decoded pictures output are suitable for display using overscan. FALSE the cropped decoded pictures output contain visually important information

video_signal_type_present_flag (guint8) –

TRUE specifies that video_format, video_full_range_flag and colour_description_present_flag are present.

video_format (guint8) –

indicates the representation of the picture

video_full_range_flag (guint8) –

indicates the black level and range of the luma and chroma signals

colour_description_present_flag (guint8) –

TRUE specifies that colour_primaries, transfer_characteristics and matrix_coefficients are present

colour_primaries (guint8) –

indicates the chromaticity coordinates of the source primaries

transfer_characteristics (guint8) –

indicates the opto-electronic transfer characteristic

matrix_coefficients (guint8) –

describes the matrix coefficients used in deriving luma and chroma signals

chroma_loc_info_present_flag (guint8) –

TRUE specifies that chroma_sample_loc_type_top_field and chroma_sample_loc_type_bottom_field are present, FALSE otherwise

chroma_sample_loc_type_top_field (guint8) –

specify the location of chroma for top field chroma_sample_loc_type_bottom_field specify the location of chroma for bottom field

chroma_sample_loc_type_bottom_field (guint8) –
No description available
neutral_chroma_indication_flag (guint8) –

TRUE indicate that the value of chroma samples is equla to 1<<(BitDepthchrom-1).

field_seq_flag (guint8) –

TRUE indicate field and FALSE indicate frame

frame_field_info_present_flag (guint8) –

TRUE indicate picture timing SEI messages are present for every picture and include the pic_struct, source_scan_type, and duplicate_flag syntax elements.

default_display_window_flag (guint8) –

TRUE indicate that the default display window parameters present def_disp_win_left_offset:left offset of display rect def_disp_win_right_offset: right offset of display rect def_disp_win_top_offset: top offset of display rect def_disp_win_bottom_offset: bottom offset of display rect

def_disp_win_left_offset (guint32) –
No description available
def_disp_win_right_offset (guint32) –
No description available
def_disp_win_top_offset (guint32) –
No description available
def_disp_win_bottom_offset (guint32) –
No description available
timing_info_present_flag (guint8) –

TRUE specifies that num_units_in_tick, time_scale and fixed_frame_rate_flag are present in the bitstream

num_units_in_tick (guint32) –

is the number of time units of a clock operating at the frequency time_scale Hz

time_scale (guint32) –

is the number of time units that pass in one second

poc_proportional_to_timing_flag (guint8) –

TRUE indicates that the picture order count value for each picture in the CVS that is not the first picture in the CVS, in decoding order, is proportional to the output time of the picture relative to the output time of the first picture in the CVS.

num_ticks_poc_diff_one_minus1 (guint32) –

plus 1 specifies the number of clock ticks corresponding to a difference of picture order count values equal to 1

hrd_parameters_present_flag (guint8) –

TRUE if hrd parameters present in the bitstream

hrd_params (GstH265HRDParams) –
No description available
bitstream_restriction_flag (guint8) –

TRUE specifies that the following coded video sequence bitstream restriction parameters are present

tiles_fixed_structure_flag (guint8) –

TRUE indicates that each PPS that is active in the CVS has the same value of the syntax elements num_tile_columns_minus1, num_tile_rows_minus1, uniform_spacing_flag, column_width_minus1, row_height_minus1 and loop_filter_across_tiles_enabled_flag, when present

motion_vectors_over_pic_boundaries_flag (guint8) –

FALSE indicates that no sample outside the picture boundaries and no sample at a fractional sample position, TRUE indicates that one or more samples outside picture boundaries may be used in inter prediction

restricted_ref_pic_lists_flag (guint8) –
No description available
min_spatial_segmentation_idc (guint16) –

when not equal to 0, establishes a bound on the maximum possible size of distinct coded spatial segmentation regions in the pictures of the CVS

max_bytes_per_pic_denom (guint8) –

indicates a number of bytes not exceeded by the sum of the sizes of the VCL NAL units associated with any coded picture in the coded video sequence.

max_bits_per_min_cu_denom (guint8) –

indicates an upper bound for the number of coded bits of coding_unit data for any coding block in any picture of the CVS

log2_max_mv_length_horizontal (guint8) –

indicate the maximum absolute value of a decoded horizontal motion vector component

log2_max_mv_length_vertical (guint8) –

indicate the maximum absolute value of a decoded vertical motion vector component

par_n (guint) –
No description available
par_d (guint) –
No description available

Enumerations

GstH265Level

typedef enum
{
  GST_H265_LEVEL_L1 = 30,
  GST_H265_LEVEL_L2 = 60,
  GST_H265_LEVEL_L2_1 = 63,
  GST_H265_LEVEL_L3 = 90,
  GST_H265_LEVEL_L3_1 = 93,
  GST_H265_LEVEL_L4 = 120,
  GST_H265_LEVEL_L4_1 = 123,
  GST_H265_LEVEL_L5 = 150,
  GST_H265_LEVEL_L5_1 = 153,
  GST_H265_LEVEL_L5_2 = 156,
  GST_H265_LEVEL_L6 = 180,
  GST_H265_LEVEL_L6_1 = 183,
  GST_H265_LEVEL_L6_2 = 186,
} GstH265Level;

H.265 level

Members

GST_H265_LEVEL_L1 (30) –

Level 1

GST_H265_LEVEL_L2 (60) –

Level 2

GST_H265_LEVEL_L2_1 (63) –

Level 2.1

GST_H265_LEVEL_L3 (90) –

Level 3

GST_H265_LEVEL_L3_1 (93) –

Level 3.1

GST_H265_LEVEL_L4 (120) –

Level 4

GST_H265_LEVEL_L4_1 (123) –

Level 4.1

GST_H265_LEVEL_L5 (150) –

Level 5

GST_H265_LEVEL_L5_1 (153) –

Level 5.1

GST_H265_LEVEL_L5_2 (156) –

Level 5.2

GST_H265_LEVEL_L6 (180) –

Level 6

GST_H265_LEVEL_L6_1 (183) –

Level 6.1

GST_H265_LEVEL_L6_2 (186) –

Level 6.2

Since : 1.24


GstH265NalUnitType

typedef enum
{
  GST_H265_NAL_SLICE_TRAIL_N    = 0,
  GST_H265_NAL_SLICE_TRAIL_R    = 1,
  GST_H265_NAL_SLICE_TSA_N      = 2,
  GST_H265_NAL_SLICE_TSA_R      = 3,
  GST_H265_NAL_SLICE_STSA_N     = 4,
  GST_H265_NAL_SLICE_STSA_R     = 5,
  GST_H265_NAL_SLICE_RADL_N     = 6,
  GST_H265_NAL_SLICE_RADL_R     = 7,
  GST_H265_NAL_SLICE_RASL_N     = 8,
  GST_H265_NAL_SLICE_RASL_R     = 9,
  GST_H265_NAL_SLICE_BLA_W_LP   = 16,
  GST_H265_NAL_SLICE_BLA_W_RADL = 17,
  GST_H265_NAL_SLICE_BLA_N_LP   = 18,
  GST_H265_NAL_SLICE_IDR_W_RADL = 19,
  GST_H265_NAL_SLICE_IDR_N_LP   = 20,
  GST_H265_NAL_SLICE_CRA_NUT    = 21,
  GST_H265_NAL_VPS              = 32,
  GST_H265_NAL_SPS              = 33,
  GST_H265_NAL_PPS              = 34,
  GST_H265_NAL_AUD              = 35,
  GST_H265_NAL_EOS              = 36,
  GST_H265_NAL_EOB              = 37,
  GST_H265_NAL_FD               = 38,
  GST_H265_NAL_PREFIX_SEI       = 39,
  GST_H265_NAL_SUFFIX_SEI       = 40
} GstH265NalUnitType;

Indicates the type of H265 Nal Units

Members

GST_H265_NAL_SLICE_TRAIL_N (0) –

Slice nal of a non-TSA, non-STSA trailing picture

GST_H265_NAL_SLICE_TRAIL_R (1) –

Slice nal of a non-TSA, non-STSA trailing picture

GST_H265_NAL_SLICE_TSA_N (2) –

Slice nal of a TSA picture

GST_H265_NAL_SLICE_TSA_R (3) –

Slice nal of a TSA picture

GST_H265_NAL_SLICE_STSA_N (4) –

Slice nal of a STSA picture

GST_H265_NAL_SLICE_STSA_R (5) –

Slice nal of a STSA picture

GST_H265_NAL_SLICE_RADL_N (6) –

Slice nal of a RADL picture

GST_H265_NAL_SLICE_RADL_R (7) –

Slice nal of a RADL piicture

GST_H265_NAL_SLICE_RASL_N (8) –

Slice nal of a RASL picture

GST_H265_NAL_SLICE_RASL_R (9) –

Slice nal of a RASL picture

GST_H265_NAL_SLICE_BLA_W_LP (16) –

Slice nal of a BLA picture

GST_H265_NAL_SLICE_BLA_W_RADL (17) –

Slice nal of a BLA picture

GST_H265_NAL_SLICE_BLA_N_LP (18) –

Slice nal of a BLA picture

GST_H265_NAL_SLICE_IDR_W_RADL (19) –

Slice nal of an IDR picture

GST_H265_NAL_SLICE_IDR_N_LP (20) –

Slice nal of an IDR picture

GST_H265_NAL_SLICE_CRA_NUT (21) –

Slice nal of a CRA picture

GST_H265_NAL_VPS (32) –

Video parameter set(VPS) nal unit

GST_H265_NAL_SPS (33) –

Sequence parameter set (SPS) nal unit

GST_H265_NAL_PPS (34) –

Picture parameter set (PPS) nal unit

GST_H265_NAL_AUD (35) –

Access unit (AU) delimiter nal unit

GST_H265_NAL_EOS (36) –

End of sequence (EOS) nal unit

GST_H265_NAL_EOB (37) –

End of bitstream (EOB) nal unit

GST_H265_NAL_FD (38) –

Filler data (FD) nal lunit

GST_H265_NAL_PREFIX_SEI (39) –

Supplemental enhancement information prefix nal unit

GST_H265_NAL_SUFFIX_SEI (40) –

Suppliemental enhancement information suffix nal unit


GstH265ParserResult

typedef enum
{
  GST_H265_PARSER_OK,
  GST_H265_PARSER_BROKEN_DATA,
  GST_H265_PARSER_BROKEN_LINK,
  GST_H265_PARSER_ERROR,
  GST_H265_PARSER_NO_NAL,
  GST_H265_PARSER_NO_NAL_END
} GstH265ParserResult;

The result of parsing H265 data.

Members

GST_H265_PARSER_OK (0) –

The parsing succeeded

GST_H265_PARSER_BROKEN_DATA (1) –

The data to parse is broken

GST_H265_PARSER_BROKEN_LINK (2) –

The link to structure needed for the parsing couldn't be found

GST_H265_PARSER_ERROR (3) –

An error accured when parsing

GST_H265_PARSER_NO_NAL (4) –

No nal found during the parsing

GST_H265_PARSER_NO_NAL_END (5) –

Start of the nal found, but not the end.


GstH265Profile

typedef enum {
  GST_H265_PROFILE_INVALID              = -1,
  GST_H265_PROFILE_MAIN                 = 1,
  GST_H265_PROFILE_MAIN_10              = 2,
  GST_H265_PROFILE_MAIN_STILL_PICTURE   = 3,
  GST_H265_PROFILE_MONOCHROME,
  GST_H265_PROFILE_MONOCHROME_12,
  GST_H265_PROFILE_MONOCHROME_16,
  GST_H265_PROFILE_MAIN_12,
  GST_H265_PROFILE_MAIN_422_10,
  GST_H265_PROFILE_MAIN_422_12,
  GST_H265_PROFILE_MAIN_444,
  GST_H265_PROFILE_MAIN_444_10,
  GST_H265_PROFILE_MAIN_444_12,
  GST_H265_PROFILE_MAIN_INTRA,
  GST_H265_PROFILE_MAIN_10_INTRA,
  GST_H265_PROFILE_MAIN_12_INTRA,
  GST_H265_PROFILE_MAIN_422_10_INTRA,
  GST_H265_PROFILE_MAIN_422_12_INTRA,
  GST_H265_PROFILE_MAIN_444_INTRA,
  GST_H265_PROFILE_MAIN_444_10_INTRA,
  GST_H265_PROFILE_MAIN_444_12_INTRA,
  GST_H265_PROFILE_MAIN_444_16_INTRA,
  GST_H265_PROFILE_MAIN_444_STILL_PICTURE,
  GST_H265_PROFILE_MAIN_444_16_STILL_PICTURE,
  GST_H265_PROFILE_MONOCHROME_10,
  GST_H265_PROFILE_HIGH_THROUGHPUT_444,
  GST_H265_PROFILE_HIGH_THROUGHPUT_444_10,
  GST_H265_PROFILE_HIGH_THROUGHPUT_444_14,
  GST_H265_PROFILE_HIGH_THROUGHPUT_444_16_INTRA,
  GST_H265_PROFILE_SCREEN_EXTENDED_MAIN,
  GST_H265_PROFILE_SCREEN_EXTENDED_MAIN_10,
  GST_H265_PROFILE_SCREEN_EXTENDED_MAIN_444,
  GST_H265_PROFILE_SCREEN_EXTENDED_MAIN_444_10,
  GST_H265_PROFILE_SCREEN_EXTENDED_HIGH_THROUGHPUT_444,
  GST_H265_PROFILE_SCREEN_EXTENDED_HIGH_THROUGHPUT_444_10,
  GST_H265_PROFILE_SCREEN_EXTENDED_HIGH_THROUGHPUT_444_14,
  GST_H265_PROFILE_MULTIVIEW_MAIN,
  GST_H265_PROFILE_SCALABLE_MAIN,
  GST_H265_PROFILE_SCALABLE_MAIN_10,
  GST_H265_PROFILE_SCALABLE_MONOCHROME,
  GST_H265_PROFILE_SCALABLE_MONOCHROME_12,
  GST_H265_PROFILE_SCALABLE_MONOCHROME_16,
  GST_H265_PROFILE_SCALABLE_MAIN_444,
  GST_H265_PROFILE_3D_MAIN,

  /* end of the profiles */
  GST_H265_PROFILE_MAX
} GstH265Profile;

H.265 Profiles.

Members

GST_H265_PROFILE_INVALID (-1) –
No description available
GST_H265_PROFILE_MAIN (1) –

Main profile (A.3.2)

GST_H265_PROFILE_MAIN_10 (2) –

Main 10 profile (A.3.3)

GST_H265_PROFILE_MAIN_STILL_PICTURE (3) –

Main Still Picture profile (A.3.4)

GST_H265_PROFILE_MONOCHROME (4) –

Monochrome profile (A.3.4)

GST_H265_PROFILE_MONOCHROME_12 (5) –

Monochrome 12-bits profile (A.3.4)

GST_H265_PROFILE_MONOCHROME_16 (6) –

Monochrome 16-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_12 (7) –

Main profile 12-bits (A.3.4)

GST_H265_PROFILE_MAIN_422_10 (8) –

Main 4:2:2 profile 10-bits (A.3.4)

GST_H265_PROFILE_MAIN_422_12 (9) –

Main 4:2:2 profile 12-bits (A.3.4)

GST_H265_PROFILE_MAIN_444 (10) –

Main 4:4:4 profile (A.3.4)

GST_H265_PROFILE_MAIN_444_10 (11) –

Main 4:4:4 10-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_444_12 (12) –

Main 4:4:4 12-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_INTRA (13) –

Main Intra profile (A.3.4)

GST_H265_PROFILE_MAIN_10_INTRA (14) –

Main Intra 10-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_12_INTRA (15) –

Main Intra 12-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_422_10_INTRA (16) –

Main Intra 4:2:2 10-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_422_12_INTRA (17) –

Main Intra 4:2:2 12-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_444_INTRA (18) –

Main Intra 4:4:4 profile (A.3.4)

GST_H265_PROFILE_MAIN_444_10_INTRA (19) –

Main Intra 4:4:4 10-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_444_12_INTRA (20) –

Main Intra 4:4:4 12-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_444_16_INTRA (21) –

Main Intra 4:4:4 16-bits profile (A.3.4)

GST_H265_PROFILE_MAIN_444_STILL_PICTURE (22) –

Main 4:4:4 Still Picture profile (A.3.4)

GST_H265_PROFILE_MAIN_444_16_STILL_PICTURE (23) –

Main 4:4:4 16-bits Still Picture profile (A.3.4)

GST_H265_PROFILE_MONOCHROME_10 (24) –

Monochrome 10-bits profile (A.3.5) (Since: 1.18)

GST_H265_PROFILE_HIGH_THROUGHPUT_444 (25) –

High Throughput 4:4:4 profile (A.3.6) (Since: 1.18)

GST_H265_PROFILE_HIGH_THROUGHPUT_444_10 (26) –

High Throughput 4:4:4 10-bits profile (A.3.6) (Since: 1.18)

GST_H265_PROFILE_HIGH_THROUGHPUT_444_14 (27) –

High Throughput 4:4:4 14-bits profile (A.3.6) (Since: 1.18)

GST_H265_PROFILE_HIGH_THROUGHPUT_444_16_INTRA (28) –

High Throughput 4:4:4 16-bits Intra profile (A.3.6) (Since: 1.18)

GST_H265_PROFILE_SCREEN_EXTENDED_MAIN (29) –

Screen-Extended Main profile (A.3.7) (Since: 1.18)

GST_H265_PROFILE_SCREEN_EXTENDED_MAIN_10 (30) –

Screen-Extended Main 10-bits profile (A.3.7) (Since: 1.18)

GST_H265_PROFILE_SCREEN_EXTENDED_MAIN_444 (31) –

Screen-Extended Main 4:4:4 profile (A.3.7) (Since: 1.18)

GST_H265_PROFILE_SCREEN_EXTENDED_MAIN_444_10 (32) –

Screen-Extended Main 4:4:4 10-bits profile (A.3.7) (Since: 1.18)

GST_H265_PROFILE_SCREEN_EXTENDED_HIGH_THROUGHPUT_444 (33) –

Screen-Extended High Throughput 4:4:4 profile (A.3.7) (Since: 1.18)

GST_H265_PROFILE_SCREEN_EXTENDED_HIGH_THROUGHPUT_444_10 (34) –

Screen-Extended High Throughput 4:4:4 10-bits profile (A.3.7) (Since: 1.18)

GST_H265_PROFILE_SCREEN_EXTENDED_HIGH_THROUGHPUT_444_14 (35) –

Screen-Extended High Throughput 4:4:4 14-bits profile (A.3.7) (Since: 1.18)

GST_H265_PROFILE_MULTIVIEW_MAIN (36) –

Multiview Main profile (G.11.1) (Since: 1.18)

GST_H265_PROFILE_SCALABLE_MAIN (37) –

Scalable Main profile (H.11.1) (Since: 1.18)

GST_H265_PROFILE_SCALABLE_MAIN_10 (38) –

Scalable Main 10-bits profile (H.11.1) (Since: 1.18)

GST_H265_PROFILE_SCALABLE_MONOCHROME (39) –

Scalable Monochrome profile (H.11.1) (Since: 1.18)

GST_H265_PROFILE_SCALABLE_MONOCHROME_12 (40) –

Scalable Monochrome 12-bits profile (H.11.1) (Since: 1.18)

GST_H265_PROFILE_SCALABLE_MONOCHROME_16 (41) –

Scalable Monochrome 16-bits profile (H.11.1) (Since: 1.18)

GST_H265_PROFILE_SCALABLE_MAIN_444 (42) –

Scalable Main 4:4:4 profile (H.11.1) (Since: 1.18)

GST_H265_PROFILE_3D_MAIN (43) –

3D Main 4:4:4 profile (I.11.1) (Since: 1.18)

GST_H265_PROFILE_MAX (44) –
No description available

GstH265ProfileIDC

typedef enum {
  GST_H265_PROFILE_IDC_MAIN                   = 1,
  GST_H265_PROFILE_IDC_MAIN_10                = 2,
  GST_H265_PROFILE_IDC_MAIN_STILL_PICTURE     = 3,
  GST_H265_PROFILE_IDC_FORMAT_RANGE_EXTENSION = 4,
  GST_H265_PROFILE_IDC_HIGH_THROUGHPUT        = 5,
  GST_H265_PROFILE_IDC_MULTIVIEW_MAIN         = 6,
  GST_H265_PROFILE_IDC_SCALABLE_MAIN          = 7,
  GST_H265_PROFILE_IDC_3D_MAIN                = 8,
  GST_H265_PROFILE_IDC_SCREEN_CONTENT_CODING  = 9,
  GST_H265_PROFILE_IDC_SCALABLE_FORMAT_RANGE_EXTENSION = 10,
  GST_H265_PROFILE_IDC_HIGH_THROUGHPUT_SCREEN_CONTENT_CODING_EXTENSION = 11,
} GstH265ProfileIDC;

Valid values for the profile_idc field. This is different from GstH265Profile as an extension idc can be used to encode a whole variety of profiles.

Members

GST_H265_PROFILE_IDC_MAIN (1) –

Main profile (A.3.2)

GST_H265_PROFILE_IDC_MAIN_10 (2) –

Main 10 profile (A.3.3)

GST_H265_PROFILE_IDC_MAIN_STILL_PICTURE (3) –

Main Still Picture profile (A.3.4)

GST_H265_PROFILE_IDC_FORMAT_RANGE_EXTENSION (4) –

Format range extensions profile (A.3.5)

GST_H265_PROFILE_IDC_HIGH_THROUGHPUT (5) –

High throughput profiles (A.3.6)

GST_H265_PROFILE_IDC_MULTIVIEW_MAIN (6) –

Multiview Main profiles (G.11.1) (Since: 1.18)

GST_H265_PROFILE_IDC_SCALABLE_MAIN (7) –

Scalable Main and Scalable Main 10 profile (H.11.1) (Since: 1.18)

GST_H265_PROFILE_IDC_3D_MAIN (8) –

3D Main profile (I.11.1) (Since: 1.18)

GST_H265_PROFILE_IDC_SCREEN_CONTENT_CODING (9) –

Screen content coding extensions profiles (A.3.7)

GST_H265_PROFILE_IDC_SCALABLE_FORMAT_RANGE_EXTENSION (10) –

Scalable Format range extensions profiles (H.11.1) (Since: 1.18)

GST_H265_PROFILE_IDC_HIGH_THROUGHPUT_SCREEN_CONTENT_CODING_EXTENSION (11) –

High throughput screen content coding extensions profiles (A.3.8) (Since: 1.18)


GstH265QuantMatrixSize

typedef enum
{
  GST_H265_QUANT_MATIX_4X4   = 0,
  GST_H265_QUANT_MATIX_8X8   = 1,
  GST_H265_QUANT_MATIX_16X16 = 2,
  GST_H265_QUANT_MATIX_32X32 = 3
} GstH265QuantMatrixSize;

Members

GST_H265_QUANT_MATIX_4X4 (0) –
No description available
GST_H265_QUANT_MATIX_8X8 (1) –
No description available
GST_H265_QUANT_MATIX_16X16 (2) –
No description available
GST_H265_QUANT_MATIX_32X32 (3) –
No description available

GstH265SEIPayloadType

typedef enum
{
  GST_H265_SEI_BUF_PERIOD = 0,
  GST_H265_SEI_PIC_TIMING = 1,
  GST_H265_SEI_REGISTERED_USER_DATA = 4,
  GST_H265_SEI_USER_DATA_UNREGISTERED = 5,
  GST_H265_SEI_RECOVERY_POINT = 6,
  GST_H265_SEI_TIME_CODE = 136,
  GST_H265_SEI_MASTERING_DISPLAY_COLOUR_VOLUME = 137,
  GST_H265_SEI_CONTENT_LIGHT_LEVEL = 144,
      /* and more...  */
} GstH265SEIPayloadType;

The type of SEI message.

Members

GST_H265_SEI_BUF_PERIOD (0) –

Buffering Period SEI Message

GST_H265_SEI_PIC_TIMING (1) –

Picture Timing SEI Message

GST_H265_SEI_REGISTERED_USER_DATA (4) –

Registered user data (D.2.5)

GST_H265_SEI_USER_DATA_UNREGISTERED (5) –

User data unregistered (D.2.7)

(Since: 1.24)
GST_H265_SEI_RECOVERY_POINT (6) –

Recovery Point SEI Message (D.3.8)

GST_H265_SEI_TIME_CODE (136) –

Time code SEI message (D.2.27) (Since: 1.16)

GST_H265_SEI_MASTERING_DISPLAY_COLOUR_VOLUME (137) –

Mastering display colour volume information SEI message (D.2.28) (Since: 1.18)

GST_H265_SEI_CONTENT_LIGHT_LEVEL (144) –

Content light level information SEI message (D.2.35) (Since: 1.18) ...


GstH265SEIPicStructType

typedef enum
{
  GST_H265_SEI_PIC_STRUCT_FRAME                         = 0,
  GST_H265_SEI_PIC_STRUCT_TOP_FIELD                     = 1,
  GST_H265_SEI_PIC_STRUCT_BOTTOM_FIELD                  = 2,
  GST_H265_SEI_PIC_STRUCT_TOP_BOTTOM                    = 3,
  GST_H265_SEI_PIC_STRUCT_BOTTOM_TOP                    = 4,
  GST_H265_SEI_PIC_STRUCT_TOP_BOTTOM_TOP                = 5,
  GST_H265_SEI_PIC_STRUCT_BOTTOM_TOP_BOTTOM             = 6,
  GST_H265_SEI_PIC_STRUCT_FRAME_DOUBLING                = 7,
  GST_H265_SEI_PIC_STRUCT_FRAME_TRIPLING                = 8,
  GST_H265_SEI_PIC_STRUCT_TOP_PAIRED_PREVIOUS_BOTTOM    = 9,
  GST_H265_SEI_PIC_STRUCT_BOTTOM_PAIRED_PREVIOUS_TOP    = 10,
  GST_H265_SEI_PIC_STRUCT_TOP_PAIRED_NEXT_BOTTOM        = 11,
  GST_H265_SEI_PIC_STRUCT_BOTTOM_PAIRED_NEXT_TOP        = 12
} GstH265SEIPicStructType;

SEI pic_struct type

Members

GST_H265_SEI_PIC_STRUCT_FRAME (0) –

Picture is a frame

GST_H265_SEI_PIC_STRUCT_TOP_FIELD (1) –

Top field of frame

GST_H265_SEI_PIC_STRUCT_BOTTOM_FIELD (2) –

Botom field of frame

GST_H265_SEI_PIC_STRUCT_TOP_BOTTOM (3) –

Top bottom field of frame

GST_H265_SEI_PIC_STRUCT_BOTTOM_TOP (4) –

bottom top field of frame

GST_H265_SEI_PIC_STRUCT_TOP_BOTTOM_TOP (5) –

top bottom top field of frame

GST_H265_SEI_PIC_STRUCT_BOTTOM_TOP_BOTTOM (6) –

bottom top bottom field of frame

GST_H265_SEI_PIC_STRUCT_FRAME_DOUBLING (7) –

indicates that the frame should be displayed two times consecutively

GST_H265_SEI_PIC_STRUCT_FRAME_TRIPLING (8) –

indicates that the frame should be displayed three times consecutively

GST_H265_SEI_PIC_STRUCT_TOP_PAIRED_PREVIOUS_BOTTOM (9) –

top field paired with previous bottom field in output order

GST_H265_SEI_PIC_STRUCT_BOTTOM_PAIRED_PREVIOUS_TOP (10) –

bottom field paried with previous top field in output order

GST_H265_SEI_PIC_STRUCT_TOP_PAIRED_NEXT_BOTTOM (11) –

top field paired with next bottom field in output order

GST_H265_SEI_PIC_STRUCT_BOTTOM_PAIRED_NEXT_TOP (12) –

bottom field paired with next top field in output order


GstH265SliceType

typedef enum
{
  GST_H265_B_SLICE    = 0,
  GST_H265_P_SLICE    = 1,
  GST_H265_I_SLICE    = 2
} GstH265SliceType;

Type of Picture slice

Members

GST_H265_B_SLICE (0) –
No description available
GST_H265_P_SLICE (1) –
No description available
GST_H265_I_SLICE (2) –
No description available

The results of the search are