300 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			300 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /*
 | ||
|  | ** Copyright (c) 2019-2021 The Khronos Group Inc. | ||
|  | ** | ||
|  | ** SPDX-License-Identifier: Apache-2.0 | ||
|  | */ | ||
|  | 
 | ||
|  | #ifndef VULKAN_VIDEO_CODEC_H264STD_H_
 | ||
|  | #define VULKAN_VIDEO_CODEC_H264STD_H_ 1
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #include "vk_video/vulkan_video_codecs_common.h"
 | ||
|  | 
 | ||
|  | // Vulkan 0.9 provisional Vulkan video H.264 encode and decode std specification version number
 | ||
|  | #define VK_STD_VULKAN_VIDEO_CODEC_H264_API_VERSION_0_9 VK_MAKE_VIDEO_STD_VERSION(0, 9, 0) // Patch version should always be set to 0
 | ||
|  | 
 | ||
|  | // Format must be in the form XX.XX where the first two digits are the major and the second two, the minor.
 | ||
|  | #define VK_STD_VULKAN_VIDEO_CODEC_H264_SPEC_VERSION   VK_STD_VULKAN_VIDEO_CODEC_H264_API_VERSION_0_9
 | ||
|  | #define VK_STD_VULKAN_VIDEO_CODEC_H264_EXTENSION_NAME "VK_STD_vulkan_video_codec_h264"
 | ||
|  | 
 | ||
|  | // *************************************************
 | ||
|  | // Video H.264 common definitions:
 | ||
|  | // *************************************************
 | ||
|  | 
 | ||
|  | typedef enum StdVideoH264ChromaFormatIdc { | ||
|  |     std_video_h264_chroma_format_idc_monochrome  = 0, | ||
|  |     std_video_h264_chroma_format_idc_420         = 1, | ||
|  |     std_video_h264_chroma_format_idc_422         = 2, | ||
|  |     std_video_h264_chroma_format_idc_444         = 3, | ||
|  | } StdVideoH264ChromaFormatIdc; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264ProfileIdc { | ||
|  |     std_video_h264_profile_idc_baseline             = 66, /* Only constrained baseline is supported */ | ||
|  |     std_video_h264_profile_idc_main                 = 77, | ||
|  |     std_video_h264_profile_idc_high                 = 100, | ||
|  |     std_video_h264_profile_idc_high_444_predictive  = 244, | ||
|  |     std_video_h264_profile_idc_invalid              = 0x7FFFFFFF | ||
|  | } StdVideoH264ProfileIdc; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264Level { | ||
|  |     std_video_h264_level_1_0 = 0, | ||
|  |     std_video_h264_level_1_1 = 1, | ||
|  |     std_video_h264_level_1_2 = 2, | ||
|  |     std_video_h264_level_1_3 = 3, | ||
|  |     std_video_h264_level_2_0 = 4, | ||
|  |     std_video_h264_level_2_1 = 5, | ||
|  |     std_video_h264_level_2_2 = 6, | ||
|  |     std_video_h264_level_3_0 = 7, | ||
|  |     std_video_h264_level_3_1 = 8, | ||
|  |     std_video_h264_level_3_2 = 9, | ||
|  |     std_video_h264_level_4_0 = 10, | ||
|  |     std_video_h264_level_4_1 = 11, | ||
|  |     std_video_h264_level_4_2 = 12, | ||
|  |     std_video_h264_level_5_0 = 13, | ||
|  |     std_video_h264_level_5_1 = 14, | ||
|  |     std_video_h264_level_5_2 = 15, | ||
|  |     std_video_h264_level_6_0 = 16, | ||
|  |     std_video_h264_level_6_1 = 17, | ||
|  |     std_video_h264_level_6_2 = 18, | ||
|  |     std_video_h264_level_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264Level; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264PocType { | ||
|  |     std_video_h264_poc_type_0 = 0, | ||
|  |     std_video_h264_poc_type_1 = 1, | ||
|  |     std_video_h264_poc_type_2 = 2, | ||
|  |     std_video_h264_poc_type_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264PocType; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264AspectRatioIdc { | ||
|  |     std_video_h264_aspect_ratio_idc_unspecified = 0, | ||
|  |     std_video_h264_aspect_ratio_idc_square = 1, | ||
|  |     std_video_h264_aspect_ratio_idc_12_11 = 2, | ||
|  |     std_video_h264_aspect_ratio_idc_10_11 = 3, | ||
|  |     std_video_h264_aspect_ratio_idc_16_11 = 4, | ||
|  |     std_video_h264_aspect_ratio_idc_40_33 = 5, | ||
|  |     std_video_h264_aspect_ratio_idc_24_11 = 6, | ||
|  |     std_video_h264_aspect_ratio_idc_20_11 = 7, | ||
|  |     std_video_h264_aspect_ratio_idc_32_11 = 8, | ||
|  |     std_video_h264_aspect_ratio_idc_80_33 = 9, | ||
|  |     std_video_h264_aspect_ratio_idc_18_11 = 10, | ||
|  |     std_video_h264_aspect_ratio_idc_15_11 = 11, | ||
|  |     std_video_h264_aspect_ratio_idc_64_33 = 12, | ||
|  |     std_video_h264_aspect_ratio_idc_160_99 = 13, | ||
|  |     std_video_h264_aspect_ratio_idc_4_3 = 14, | ||
|  |     std_video_h264_aspect_ratio_idc_3_2 = 15, | ||
|  |     std_video_h264_aspect_ratio_idc_2_1 = 16, | ||
|  |     std_video_h264_aspect_ratio_idc_extended_sar = 255, | ||
|  |     std_video_h264_aspect_ratio_idc_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264AspectRatioIdc; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264WeightedBiPredIdc { | ||
|  |     std_video_h264_default_weighted_b_slices_prediction_idc = 0, | ||
|  |     std_video_h264_explicit_weighted_b_slices_prediction_idc = 1, | ||
|  |     std_video_h264_implicit_weighted_b_slices_prediction_idc = 2, | ||
|  |     std_video_h264_invalid_weighted_b_slices_prediction_idc = 0x7FFFFFFF | ||
|  | } StdVideoH264WeightedBiPredIdc; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264ModificationOfPicNumsIdc { | ||
|  |     std_video_h264_modification_of_pic_nums_idc_short_term_subtract = 0, | ||
|  |     std_video_h264_modification_of_pic_nums_idc_short_term_add = 1, | ||
|  |     std_video_h264_modification_of_pic_nums_idc_long_term = 2, | ||
|  |     std_video_h264_modification_of_pic_nums_idc_end = 3, | ||
|  |     std_video_h264_modification_of_pic_nums_idc_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264ModificationOfPicNumsIdc; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264MemMgmtControlOp { | ||
|  |     std_video_h264_mem_mgmt_control_op_end = 0, | ||
|  |     std_video_h264_mem_mgmt_control_op_unmark_short_term = 1, | ||
|  |     std_video_h264_mem_mgmt_control_op_unmark_long_term = 2, | ||
|  |     std_video_h264_mem_mgmt_control_op_mark_long_term = 3, | ||
|  |     std_video_h264_mem_mgmt_control_op_set_max_long_term_index = 4, | ||
|  |     std_video_h264_mem_mgmt_control_op_unmark_all = 5, | ||
|  |     std_video_h264_mem_mgmt_control_op_mark_current_as_long_term = 6, | ||
|  |     std_video_h264_mem_mgmt_control_op_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264MemMgmtControlOp; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264CabacInitIdc { | ||
|  |     std_video_h264_cabac_init_idc_0 = 0, | ||
|  |     std_video_h264_cabac_init_idc_1 = 1, | ||
|  |     std_video_h264_cabac_init_idc_2 = 2, | ||
|  |     std_video_h264_cabac_init_idc_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264CabacInitIdc; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264DisableDeblockingFilterIdc { | ||
|  |     std_video_h264_disable_deblocking_filter_idc_disabled = 0, | ||
|  |     std_video_h264_disable_deblocking_filter_idc_enabled = 1, | ||
|  |     std_video_h264_disable_deblocking_filter_idc_partial = 2, | ||
|  |     std_video_h264_disable_deblocking_filter_idc_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264DisableDeblockingFilterIdc; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264PictureType { | ||
|  |     std_video_h264_picture_type_i = 0, | ||
|  |     std_video_h264_picture_type_p = 1, | ||
|  |     std_video_h264_picture_type_b = 2, | ||
|  |     std_video_h264_picture_type_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264PictureType; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264SliceType { | ||
|  |     std_video_h264_slice_type_i = 0, | ||
|  |     std_video_h264_slice_type_p = 1, | ||
|  |     std_video_h264_slice_type_b = 2, | ||
|  |     std_video_h264_slice_type_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264SliceType; | ||
|  | 
 | ||
|  | typedef enum StdVideoH264NonVclNaluType { | ||
|  |     std_video_h264_non_vcl_nalu_type_sps = 0, | ||
|  |     std_video_h264_non_vcl_nalu_type_pps = 1, | ||
|  |     std_video_h264_non_vcl_nalu_type_aud = 2, | ||
|  |     std_video_h264_non_vcl_nalu_type_prefix = 3, | ||
|  |     std_video_h264_non_vcl_nalu_type_end_of_sequence = 4, | ||
|  |     std_video_h264_non_vcl_nalu_type_end_of_stream = 5, | ||
|  |     std_video_h264_non_vcl_nalu_type_precoded = 6, | ||
|  |     std_video_h264_non_vcl_nalu_type_invalid = 0x7FFFFFFF | ||
|  | } StdVideoH264NonVclNaluType; | ||
|  | 
 | ||
|  | typedef struct StdVideoH264SpsVuiFlags { | ||
|  |     uint32_t aspect_ratio_info_present_flag:1; | ||
|  |     uint32_t overscan_info_present_flag:1; | ||
|  |     uint32_t overscan_appropriate_flag:1; | ||
|  |     uint32_t video_signal_type_present_flag:1; | ||
|  |     uint32_t video_full_range_flag:1; | ||
|  |     uint32_t color_description_present_flag:1; | ||
|  |     uint32_t chroma_loc_info_present_flag:1; | ||
|  |     uint32_t timing_info_present_flag:1; | ||
|  |     uint32_t fixed_frame_rate_flag:1; | ||
|  |     uint32_t bitstream_restriction_flag:1; | ||
|  |     uint32_t nal_hrd_parameters_present_flag:1; | ||
|  |     uint32_t vcl_hrd_parameters_present_flag:1; | ||
|  | } StdVideoH264SpsVuiFlags; | ||
|  | 
 | ||
|  | typedef struct StdVideoH264HrdParameters { | ||
|  |     uint8_t                    cpb_cnt_minus1; | ||
|  |     uint8_t                    bit_rate_scale; | ||
|  |     uint8_t                    cpb_size_scale; | ||
|  |     uint32_t                   bit_rate_value_minus1[32]; | ||
|  |     uint32_t                   cpb_size_value_minus1[32]; | ||
|  |     uint8_t                    cbr_flag[32]; | ||
|  |     uint32_t                   initial_cpb_removal_delay_length_minus1; | ||
|  |     uint32_t                   cpb_removal_delay_length_minus1; | ||
|  |     uint32_t                   dpb_output_delay_length_minus1; | ||
|  |     uint32_t                   time_offset_length; | ||
|  | } StdVideoH264HrdParameters; | ||
|  | 
 | ||
|  | typedef struct StdVideoH264SequenceParameterSetVui { | ||
|  |     StdVideoH264AspectRatioIdc  aspect_ratio_idc; | ||
|  |     uint16_t                    sar_width; | ||
|  |     uint16_t                    sar_height; | ||
|  |     uint8_t                     video_format; | ||
|  |     uint8_t                     color_primaries; | ||
|  |     uint8_t                     transfer_characteristics; | ||
|  |     uint8_t                     matrix_coefficients; | ||
|  |     uint32_t                    num_units_in_tick; | ||
|  |     uint32_t                    time_scale; | ||
|  |     StdVideoH264HrdParameters   hrd_parameters; | ||
|  |     uint8_t                     num_reorder_frames; | ||
|  |     uint8_t                     max_dec_frame_buffering; | ||
|  |     StdVideoH264SpsVuiFlags     flags; | ||
|  | } StdVideoH264SequenceParameterSetVui; | ||
|  | 
 | ||
|  | typedef struct StdVideoH264SpsFlags { | ||
|  |     uint32_t constraint_set0_flag:1; | ||
|  |     uint32_t constraint_set1_flag:1; | ||
|  |     uint32_t constraint_set2_flag:1; | ||
|  |     uint32_t constraint_set3_flag:1; | ||
|  |     uint32_t constraint_set4_flag:1; | ||
|  |     uint32_t constraint_set5_flag:1; | ||
|  |     uint32_t direct_8x8_inference_flag:1; | ||
|  |     uint32_t mb_adaptive_frame_field_flag:1; | ||
|  |     uint32_t frame_mbs_only_flag:1; | ||
|  |     uint32_t delta_pic_order_always_zero_flag:1; | ||
|  |     uint32_t residual_colour_transform_flag:1; | ||
|  |     uint32_t gaps_in_frame_num_value_allowed_flag:1; | ||
|  |     uint32_t first_picture_after_seek_flag:1; // where is this being documented?
 | ||
|  |     uint32_t qpprime_y_zero_transform_bypass_flag:1; | ||
|  |     uint32_t frame_cropping_flag:1; | ||
|  |     uint32_t scaling_matrix_present_flag:1; | ||
|  |     uint32_t vui_parameters_present_flag:1; | ||
|  | } StdVideoH264SpsFlags; | ||
|  | 
 | ||
|  | typedef struct StdVideoH264ScalingLists | ||
|  | { | ||
|  |     // scaling_list_present_mask has one bit for each
 | ||
|  |     // seq_scaling_list_present_flag[i] for SPS OR
 | ||
|  |     // pic_scaling_list_present_flag[i] for PPS,
 | ||
|  |     // bit 0 - 5 are for each entry of ScalingList4x4
 | ||
|  |     // bit 6 - 7 are for each entry plus 6 for ScalingList8x8
 | ||
|  |     uint8_t scaling_list_present_mask; | ||
|  |     // use_default_scaling_matrix_mask has one bit for each
 | ||
|  |     // UseDefaultScalingMatrix4x4Flag[ i ] and
 | ||
|  |     // UseDefaultScalingMatrix8x8Flag[ i - 6 ] for SPS OR PPS
 | ||
|  |     // bit 0 - 5 are for each entry of ScalingList4x4
 | ||
|  |     // bit 6 - 7 are for each entry plus 6 for ScalingList8x8
 | ||
|  |     uint8_t use_default_scaling_matrix_mask; | ||
|  |     uint8_t ScalingList4x4[6][16]; | ||
|  |     uint8_t ScalingList8x8[2][64]; | ||
|  | } StdVideoH264ScalingLists; | ||
|  | 
 | ||
|  | typedef struct StdVideoH264SequenceParameterSet | ||
|  | { | ||
|  |     StdVideoH264ProfileIdc               profile_idc; | ||
|  |     StdVideoH264Level                    level_idc; | ||
|  |     uint8_t                              seq_parameter_set_id; | ||
|  |     StdVideoH264ChromaFormatIdc          chroma_format_idc; | ||
|  |     uint8_t                              bit_depth_luma_minus8; | ||
|  |     uint8_t                              bit_depth_chroma_minus8; | ||
|  |     uint8_t                              log2_max_frame_num_minus4; | ||
|  |     StdVideoH264PocType                  pic_order_cnt_type; | ||
|  |     uint8_t                              log2_max_pic_order_cnt_lsb_minus4; | ||
|  |     int32_t                              offset_for_non_ref_pic; | ||
|  |     int32_t                              offset_for_top_to_bottom_field; | ||
|  |     uint8_t                              num_ref_frames_in_pic_order_cnt_cycle; | ||
|  |     uint8_t                              max_num_ref_frames; | ||
|  |     uint32_t                             pic_width_in_mbs_minus1; | ||
|  |     uint32_t                             pic_height_in_map_units_minus1; | ||
|  |     uint32_t                             frame_crop_left_offset; | ||
|  |     uint32_t                             frame_crop_right_offset; | ||
|  |     uint32_t                             frame_crop_top_offset; | ||
|  |     uint32_t                             frame_crop_bottom_offset; | ||
|  |     StdVideoH264SpsFlags                 flags; | ||
|  |     int32_t                              offset_for_ref_frame[255]; // The number of valid values are defined by the num_ref_frames_in_pic_order_cnt_cycle
 | ||
|  |     StdVideoH264ScalingLists*            pScalingLists;             // Must be a valid pointer if scaling_matrix_present_flag is set
 | ||
|  |     StdVideoH264SequenceParameterSetVui* pSequenceParameterSetVui;  // Must be a valid pointer if StdVideoH264SpsFlags:vui_parameters_present_flag is set
 | ||
|  | } StdVideoH264SequenceParameterSet; | ||
|  | 
 | ||
|  | typedef struct StdVideoH264PpsFlags { | ||
|  |     uint32_t transform_8x8_mode_flag:1; | ||
|  |     uint32_t redundant_pic_cnt_present_flag:1; | ||
|  |     uint32_t constrained_intra_pred_flag:1; | ||
|  |     uint32_t deblocking_filter_control_present_flag:1; | ||
|  |     uint32_t weighted_bipred_idc_flag:1; | ||
|  |     uint32_t weighted_pred_flag:1; | ||
|  |     uint32_t pic_order_present_flag:1; | ||
|  |     uint32_t entropy_coding_mode_flag:1; | ||
|  |     uint32_t scaling_matrix_present_flag:1; | ||
|  | } StdVideoH264PpsFlags; | ||
|  | 
 | ||
|  | typedef struct StdVideoH264PictureParameterSet | ||
|  | { | ||
|  |     uint8_t                       seq_parameter_set_id; | ||
|  |     uint8_t                       pic_parameter_set_id; | ||
|  |     uint8_t                       num_ref_idx_l0_default_active_minus1; | ||
|  |     uint8_t                       num_ref_idx_l1_default_active_minus1; | ||
|  |     StdVideoH264WeightedBiPredIdc weighted_bipred_idc; | ||
|  |     int8_t                        pic_init_qp_minus26; | ||
|  |     int8_t                        pic_init_qs_minus26; | ||
|  |     int8_t                        chroma_qp_index_offset; | ||
|  |     int8_t                        second_chroma_qp_index_offset; | ||
|  |     StdVideoH264PpsFlags          flags; | ||
|  |     StdVideoH264ScalingLists*     pScalingLists; // Must be a valid pointer if  StdVideoH264PpsFlags::scaling_matrix_present_flag is set.
 | ||
|  | } StdVideoH264PictureParameterSet; | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #endif // VULKAN_VIDEO_CODEC_H264STD_H_
 |