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:
- 
gst_h265_parser_identify_nalu to identify the following nalu in non-HEVC bitstreams 
- 
gst_h265_parser_identify_nalu_hevc to identify the nalu in HEVC bitstreams 
Then, depending on the GstH265NalUnitType of the newly parsed GstH265NalUnit, you should call the differents functions to parse the structure:
- 
From GST_H265_NAL_SLICE_TRAIL_N to GST_H265_NAL_SLICE_CRA_NUT: gst_h265_parser_parse_slice_hdr 
- 
GST_H265_NAL_*_SEI: gst_h265_parser_parse_sei
- 
Any other: gst_h265_parser_parse_nal 
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
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
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
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
–
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
–
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
–
nalu
–
sps
–
parse_vui_params
–
gst_h265_parse_vps
GstH265ParserResult gst_h265_parse_vps (GstH265NalUnit * nalu, GstH265VPS * vps)
Parses data, and fills the vps structure.
gst_h265_parser_free
void gst_h265_parser_free (GstH265Parser * parser)
Frees parser
Parameters:
parser
–
the GstH265Parser to free
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
–
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
–
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
–
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
–
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
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
–
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
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.
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
–
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.
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
–
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
–
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
–
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
–
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
–
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.
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.
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.
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
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:
ptl
–
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
–
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
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
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
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
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
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
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
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
Since : 1.6
gst_h265_sei_copy
gboolean gst_h265_sei_copy (GstH265SEIMessage * dest_sei, GstH265SEIMessage * src_sei)
Copies src_sei into dst_sei
gst_h265_sei_free
void gst_h265_sei_free (GstH265SEIMessage * sei)
sei: The GstH265SEIMessage to free
Parameters:
sei
–
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
gst_h265_slice_hdr_free
void gst_h265_slice_hdr_free (GstH265SliceHdr * slice_hdr)
slice_hdr: The GstH265SliceHdr to free
Parameters:
slice_hdr
–
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
–
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 *)
		–
	irap_cpb_params_present_flag
		(guint8)
		–
	cpb_delay_offset
		(guint8)
		–
	dpb_delay_offset
		(guint8)
		–
	concatenation_flag
		(guint8)
		–
	au_cpb_removal_delay_delta_minus1
		(guint8)
		–
	nal_initial_cpb_removal_delay
		(guint8[32] )
		–
	nal_initial_cpb_removal_offset
		(guint8[32] )
		–
	nal_initial_alt_cpb_removal_delay
		(guint8[32] )
		–
	nal_initial_alt_cpb_removal_offset
		(guint8[32] )
		–
	vcl_initial_cpb_removal_delay
		(guint8[32] )
		–
	vcl_initial_cpb_removal_offset
		(guint8[32] )
		–
	vcl_initial_alt_cpb_removal_delay
		(guint8[32] )
		–
	vcl_initial_alt_cpb_removal_offset
		(guint8[32] )
		–
	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)
		–
	max_pic_average_light_level
		(guint16)
		–
	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)
		–
	general_profile_space
		(guint8)
		–
	general_tier_flag
		(guint8)
		–
	general_profile_idc
		(guint8)
		–
	general_profile_compatibility_flags
		(guint8[32] )
		–
	general_progressive_source_flag
		(guint8)
		–
	general_interlaced_source_flag
		(guint8)
		–
	general_non_packed_constraint_flag
		(guint8)
		–
	general_frame_only_constraint_flag
		(guint8)
		–
	general_max_12bit_constraint_flag
		(guint8)
		–
	general_max_10bit_constraint_flag
		(guint8)
		–
	general_max_8bit_constraint_flag
		(guint8)
		–
	general_max_422chroma_constraint_flag
		(guint8)
		–
	general_max_420chroma_constraint_flag
		(guint8)
		–
	general_max_monochrome_constraint_flag
		(guint8)
		–
	general_intra_constraint_flag
		(guint8)
		–
	general_one_picture_only_constraint_flag
		(guint8)
		–
	general_lower_bit_rate_constraint_flag
		(guint8)
		–
	general_max_14bit_constraint_flag
		(guint8)
		–
	general_inbld_flag
		(guint8)
		–
	general_level_idc
		(guint8)
		–
	min_spatial_segmentation_idc
		(guint16)
		–
	parallelism_type
		(guint8)
		–
	chroma_format_idc
		(guint8)
		–
	bit_depth_luma_minus8
		(guint8)
		–
	bit_depth_chroma_minus8
		(guint8)
		–
	avg_frame_rate
		(guint16)
		–
	constant_frame_rate
		(guint8)
		–
	num_temporal_layers
		(guint8)
		–
	temporal_id_nested
		(guint8)
		–
	length_size_minus_one
		(guint8)
		–
	nalu_array
		(GArray *)
		–
	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)
		–
	nal_unit_type
		(GstH265NalUnitType)
		–
	nalu
		(GArray *)
		–
	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)
		–
	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] )
		–
	display_primaries_y
		(guint16[3] )
		–
	white_point_x
		(guint16)
		–
	white_point_y
		(guint16)
		–
	max_display_mastering_luminance
		(guint32)
		–
	min_display_mastering_luminance
		(guint32)
		–
	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)
		–
	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)
		–
	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)
		–
	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 *)
		–
	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
		(guint8)
		–
	init_qp_minus26
		(gint8)
		–
	constrained_intra_pred_flag
		(guint8)
		–
	transform_skip_enabled_flag
		(guint8)
		–
	cu_qp_delta_enabled_flag
		(guint8)
		–
	diff_cu_qp_delta_depth
		(guint8)
		–
	cb_qp_offset
		(gint8)
		–
	cr_qp_offset
		(gint8)
		–
	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
		(guint8)
		–
	column_width_minus1
		(guint32[20] )
		–
	row_height_minus1
		(guint32[22] )
		–
	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
		(guint8)
		–
	beta_offset_div2
		(gint8)
		–
	tc_offset_div2
		(gint8)
		–
	scaling_list_data_present_flag
		(guint8)
		–
	scaling_list
		(GstH265ScalingList)
		–
	lists_modification_present_flag
		(guint8)
		–
	log2_parallel_merge_level_minus2
		(guint8)
		–
	slice_segment_header_extension_present_flag
		(guint8)
		–
	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
		(guint8)
		–
	pps_extension_params
		(GstH265PPSExtensionParams)
		–
	pps_scc_extension_params
		(GstH265PPSSccExtensionParams)
		–
	PicWidthInCtbsY
		(guint32)
		–
	PicHeightInCtbsY
		(guint32)
		–
	valid
		(gboolean)
		–
	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)
		–
	pps_act_cb_qp_offset_plus5
		(guint8)
		–
	pps_act_cr_qp_offset_plus3
		(guint8)
		–
	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)
		–
	source_scan_type
		(guint8)
		–
	duplicate_flag
		(guint8)
		–
	au_cpb_removal_delay_minus1
		(guint8)
		–
	pic_dpb_output_delay
		(guint8)
		–
	pic_dpb_output_du_delay
		(guint8)
		–
	num_decoding_units_minus1
		(guint32)
		–
	du_common_cpb_removal_delay_flag
		(guint8)
		–
	du_common_cpb_removal_delay_increment_minus1
		(guint8)
		–
	num_nalus_in_du_minus1
		(guint32 *)
		–
	du_cpb_removal_delay_increment_minus1
		(guint8 *)
		–
	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)
		–
	delta_chroma_log2_weight_denom
		(gint8)
		–
	luma_weight_l0_flag
		(guint8[15] )
		–
	chroma_weight_l0_flag
		(guint8[15] )
		–
	delta_luma_weight_l0
		(gint8[15] )
		–
	luma_offset_l0
		(gint8[15] )
		–
	delta_chroma_weight_l0
		(gint8[15][2] )
		–
	delta_chroma_offset_l0
		(gint16[15][2] )
		–
	luma_weight_l1_flag
		(guint8[15] )
		–
	chroma_weight_l1_flag
		(guint8[15] )
		–
	delta_luma_weight_l1
		(gint8[15] )
		–
	luma_offset_l1
		(gint8[15] )
		–
	delta_chroma_weight_l1
		(gint8[15][2] )
		–
	delta_chroma_offset_l1
		(gint16[15][2] )
		–
	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)
		–
	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] )
		–
	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)
		–
	exact_match_flag
		(guint8)
		–
	broken_link_flag
		(guint8)
		–
	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)
		–
	list_entry_l0
		(guint32[15] )
		–
	ref_pic_list_modification_flag_l1
		(guint8)
		–
	list_entry_l1
		(guint32[15] )
		–
	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)
		–
	country_code_extension
		(guint8)
		–
	data
		(guint8 *)
		–
	size
		(guint)
		–
	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)
		–
	payload.buffering_period
		(GstH265BufferingPeriod)
		–
	payload.pic_timing
		(GstH265PicTiming)
		–
	payload.registered_user_data
		(GstH265RegisteredUserData)
		–
	payload.recovery_point
		(GstH265RecoveryPoint)
		–
	payload.time_code
		(GstH265TimeCode)
		–
	payload.mastering_display_colour_volume
		(GstH265MasteringDisplayColourVolume)
		–
	payload.content_light_level
		(GstH265ContentLightLevel)
		–
	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 *)
		–
	max_sub_layers_minus1
		(guint8)
		–
	temporal_id_nesting_flag
		(guint8)
		–
	profile_tier_level
		(GstH265ProfileTierLevel)
		–
	chroma_format_idc
		(guint8)
		–
	separate_colour_plane_flag
		(guint8)
		–
	pic_width_in_luma_samples
		(guint16)
		–
	pic_height_in_luma_samples
		(guint16)
		–
	conformance_window_flag
		(guint8)
		–
	conf_win_left_offset
		(guint32)
		–
	conf_win_right_offset
		(guint32)
		–
	conf_win_top_offset
		(guint32)
		–
	conf_win_bottom_offset
		(guint32)
		–
	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
		(guint8[8] )
		–
	max_num_reorder_pics
		(guint8[8] )
		–
	max_latency_increase_plus1
		(guint8[8] )
		–
	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
		(guint8)
		–
	scaling_list_data_present_flag
		(guint8)
		–
	scaling_list
		(GstH265ScalingList)
		–
	amp_enabled_flag
		(guint8)
		–
	sample_adaptive_offset_enabled_flag
		(guint8)
		–
	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
		(guint8)
		–
	short_term_ref_pic_set
		(GstH265ShortTermRefPicSet[65] )
		–
	long_term_ref_pics_present_flag
		(guint8)
		–
	num_long_term_ref_pics_sps
		(guint8)
		–
	lt_ref_pic_poc_lsb_sps
		(guint16[32] )
		–
	used_by_curr_pic_lt_sps_flag
		(guint8[32] )
		–
	temporal_mvp_enabled_flag
		(guint8)
		–
	strong_intra_smoothing_enabled_flag
		(guint8)
		–
	vui_parameters_present_flag
		(guint8)
		–
	vui_params
		(GstH265VUIParams)
		–
	sps_extension_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
		(guint8)
		–
	sps_extension_params
		(GstH265SPSExtensionParams)
		–
	sps_scc_extension_params
		(GstH265SPSSccExtensionParams)
		–
	chroma_array_type
		(guint8)
		–
	width
		(gint)
		–
	height
		(gint)
		–
	crop_rect_width
		(gint)
		–
	crop_rect_height
		(gint)
		–
	crop_rect_x
		(gint)
		–
	crop_rect_y
		(gint)
		–
	fps_num
		(gint)
		–
	fps_den
		(gint)
		–
	valid
		(gboolean)
		–
	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)
		–
	explicit_rdpcm_enabled_flag
		(guint8)
		–
	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.
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] )
		–
	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 *)
		–
	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.
ref_pic_list_modification
		(GstH265RefPicListModification)
		–
	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.
pred_weight_table
		(GstH265PredWeightTable)
		–
	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)
		–
	clock_timestamp_flag
		(guint8[3] )
		–
	units_field_based_flag
		(guint8[3] )
		–
	counting_type
		(guint8[3] )
		–
	full_timestamp_flag
		(guint8[3] )
		–
	discontinuity_flag
		(guint8[3] )
		–
	cnt_dropped_flag
		(guint8[3] )
		–
	n_frames
		(guint16[3] )
		–
	seconds_flag
		(guint8[3] )
		–
	seconds_value
		(guint8[3] )
		–
	minutes_flag
		(guint8[3] )
		–
	minutes_value
		(guint8[3] )
		–
	hours_flag
		(guint8[3] )
		–
	hours_value
		(guint8[3] )
		–
	time_offset_length
		(guint8[3] )
		–
	time_offset_value
		(guint32[3] )
		–
	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)
		–
	base_layer_available_flag
		(guint8)
		–
	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)
		–
	hrd_params
		(GstH265HRDParams)
		–
	the GstH265HRDParams list
vps_extension
		(guint8)
		–
	valid
		(gboolean)
		–
	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
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)
		–
	sar_width
		(guint16)
		–
	sar_height
		(guint16)
		–
	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)
		–
	neutral_chroma_indication_flag
		(guint8)
		–
	TRUE indicate that the value of chroma samples is equla to 1<<(BitDepthchrom-1).
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)
		–
	def_disp_win_right_offset
		(guint32)
		–
	def_disp_win_top_offset
		(guint32)
		–
	def_disp_win_bottom_offset
		(guint32)
		–
	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_params
		(GstH265HRDParams)
		–
	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)
		–
	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)
		–
	par_d
		(guint)
		–
	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)
		–
	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)
		–
	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)
		–
	GST_H265_QUANT_MATIX_8X8
		(1)
		–
	GST_H265_QUANT_MATIX_16X16
		(2)
		–
	GST_H265_QUANT_MATIX_32X32
		(3)
		–
	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)
		–
	GST_H265_P_SLICE
		(1)
		–
	GST_H265_I_SLICE
		(2)
		–
	The results of the search are