27     .queue_flags      = VK_QUEUE_VIDEO_DECODE_BIT_KHR,
 
   28     .decode_op        = VK_VIDEO_CODEC_OPERATION_DECODE_H264_BIT_KHR,
 
   30         .extensionName = VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_EXTENSION_NAME,
 
   31         .specVersion   = VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_SPEC_VERSION,
 
   55                              VkVideoReferenceSlotInfoKHR *ref_slot,       
 
   56                              VkVideoPictureResourceInfoKHR *
ref,          
 
   57                              VkVideoDecodeH264DpbSlotInfoKHR *vkh264_ref, 
 
   58                              StdVideoDecodeH264ReferenceInfo *h264_ref,   
 
   60                              int is_field, 
int picture_structure,
 
   73     *h264_ref = (StdVideoDecodeH264ReferenceInfo) {
 
   76         .flags = (StdVideoDecodeH264ReferenceInfoFlags) {
 
   77             .top_field_flag    = is_field ? !!(picture_structure & 
PICT_TOP_FIELD)    : 0,
 
   91     *vkh264_ref = (VkVideoDecodeH264DpbSlotInfoKHR) {
 
   92         .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_H264_DPB_SLOT_INFO_KHR,
 
   93         .pStdReferenceInfo = h264_ref,
 
   96     *
ref = (VkVideoPictureResourceInfoKHR) {
 
   97         .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
 
   98         .codedOffset = (VkOffset2D){ 0, 0 },
 
  100         .baseArrayLayer = 
ctx->common.layered_dpb ? dpb_slot_index : 0,
 
  101         .imageViewBinding = vkpic->
view.
ref[0],
 
  104     *ref_slot = (VkVideoReferenceSlotInfoKHR) {
 
  105         .sType = VK_STRUCTURE_TYPE_VIDEO_REFERENCE_SLOT_INFO_KHR,
 
  107         .slotIndex = dpb_slot_index,
 
  108         .pPictureResource = 
ref,
 
  120     case 10: 
return STD_VIDEO_H264_LEVEL_IDC_1_0;
 
  121     case 11: 
return STD_VIDEO_H264_LEVEL_IDC_1_1;
 
  122     case 12: 
return STD_VIDEO_H264_LEVEL_IDC_1_2;
 
  123     case 13: 
return STD_VIDEO_H264_LEVEL_IDC_1_3;
 
  124     case 20: 
return STD_VIDEO_H264_LEVEL_IDC_2_0;
 
  125     case 21: 
return STD_VIDEO_H264_LEVEL_IDC_2_1;
 
  126     case 22: 
return STD_VIDEO_H264_LEVEL_IDC_2_2;
 
  127     case 30: 
return STD_VIDEO_H264_LEVEL_IDC_3_0;
 
  128     case 31: 
return STD_VIDEO_H264_LEVEL_IDC_3_1;
 
  129     case 32: 
return STD_VIDEO_H264_LEVEL_IDC_3_2;
 
  130     case 40: 
return STD_VIDEO_H264_LEVEL_IDC_4_0;
 
  131     case 41: 
return STD_VIDEO_H264_LEVEL_IDC_4_1;
 
  132     case 42: 
return STD_VIDEO_H264_LEVEL_IDC_4_2;
 
  133     case 50: 
return STD_VIDEO_H264_LEVEL_IDC_5_0;
 
  134     case 51: 
return STD_VIDEO_H264_LEVEL_IDC_5_1;
 
  135     case 52: 
return STD_VIDEO_H264_LEVEL_IDC_5_2;
 
  136     case 60: 
return STD_VIDEO_H264_LEVEL_IDC_6_0;
 
  137     case 61: 
return STD_VIDEO_H264_LEVEL_IDC_6_1;
 
  139     case 62: 
return STD_VIDEO_H264_LEVEL_IDC_6_2;
 
  144                     StdVideoH264ScalingLists *vksps_scaling,
 
  145                     StdVideoH264HrdParameters *vksps_vui_header,
 
  146                     StdVideoH264SequenceParameterSetVui *vksps_vui,
 
  147                     StdVideoH264SequenceParameterSet *vksps)
 
  149     *vksps_scaling = (StdVideoH264ScalingLists) {
 
  150         .scaling_list_present_mask = 
sps->scaling_matrix_present_mask,
 
  151         .use_default_scaling_matrix_mask = 0, 
 
  154     for (
int i = 0; 
i < STD_VIDEO_H264_SCALING_LIST_4X4_NUM_LISTS; 
i++)
 
  155         for (
int j = 0; j < STD_VIDEO_H264_SCALING_LIST_4X4_NUM_ELEMENTS; j++)
 
  158     for (
int i = 0; 
i < STD_VIDEO_H264_SCALING_LIST_8X8_NUM_LISTS; 
i++)
 
  159         for (
int j = 0; j < STD_VIDEO_H264_SCALING_LIST_8X8_NUM_ELEMENTS; j++)
 
  160             vksps_scaling->ScalingList8x8[
i][j] =
 
  163     *vksps_vui_header = (StdVideoH264HrdParameters) {
 
  164         .cpb_cnt_minus1 = 
sps->cpb_cnt - 1,
 
  165         .bit_rate_scale = 
sps->bit_rate_scale,
 
  166         .initial_cpb_removal_delay_length_minus1 = 
sps->initial_cpb_removal_delay_length - 1,
 
  167         .cpb_removal_delay_length_minus1 = 
sps->cpb_removal_delay_length - 1,
 
  168         .dpb_output_delay_length_minus1 = 
sps->dpb_output_delay_length - 1,
 
  169         .time_offset_length = 
sps->time_offset_length,
 
  172     for (
int i = 0; 
i < 
sps->cpb_cnt; 
i++) {
 
  173         vksps_vui_header->bit_rate_value_minus1[
i] = 
sps->bit_rate_value[
i] - 1;
 
  174         vksps_vui_header->cpb_size_value_minus1[
i] = 
sps->cpb_size_value[
i] - 1;
 
  175         vksps_vui_header->cbr_flag[
i] = (
sps->cpr_flag >> 
i) & 0x1;
 
  178     *vksps_vui = (StdVideoH264SequenceParameterSetVui) {
 
  179         .aspect_ratio_idc = 
sps->vui.aspect_ratio_idc,
 
  180         .sar_width = 
sps->vui.sar.num,
 
  181         .sar_height = 
sps->vui.sar.den,
 
  182         .video_format = 
sps->vui.video_format,
 
  183         .colour_primaries = 
sps->vui.colour_primaries,
 
  184         .transfer_characteristics = 
sps->vui.transfer_characteristics,
 
  185         .matrix_coefficients = 
sps->vui.matrix_coeffs,
 
  186         .num_units_in_tick = 
sps->num_units_in_tick,
 
  187         .time_scale = 
sps->time_scale,
 
  188         .pHrdParameters = vksps_vui_header,
 
  189         .max_num_reorder_frames = 
sps->num_reorder_frames,
 
  190         .max_dec_frame_buffering = 
sps->max_dec_frame_buffering,
 
  191         .flags = (StdVideoH264SpsVuiFlags) {
 
  192             .aspect_ratio_info_present_flag = 
sps->vui.aspect_ratio_info_present_flag,
 
  193             .overscan_info_present_flag = 
sps->vui.overscan_info_present_flag,
 
  194             .overscan_appropriate_flag = 
sps->vui.overscan_appropriate_flag,
 
  195             .video_signal_type_present_flag = 
sps->vui.video_signal_type_present_flag,
 
  196             .video_full_range_flag = 
sps->vui.video_full_range_flag,
 
  197             .color_description_present_flag = 
sps->vui.colour_description_present_flag,
 
  198             .chroma_loc_info_present_flag = 
sps->vui.chroma_location,
 
  199             .timing_info_present_flag = 
sps->timing_info_present_flag,
 
  200             .fixed_frame_rate_flag = 
sps->fixed_frame_rate_flag,
 
  201             .bitstream_restriction_flag = 
sps->bitstream_restriction_flag,
 
  202             .nal_hrd_parameters_present_flag = 
sps->nal_hrd_parameters_present_flag,
 
  203             .vcl_hrd_parameters_present_flag = 
sps->vcl_hrd_parameters_present_flag,
 
  207     *vksps = (StdVideoH264SequenceParameterSet) {
 
  208         .profile_idc = 
sps->profile_idc,
 
  210         .seq_parameter_set_id = 
sps->sps_id,
 
  211         .chroma_format_idc = 
sps->chroma_format_idc,
 
  212         .bit_depth_luma_minus8 = 
sps->bit_depth_luma - 8,
 
  213         .bit_depth_chroma_minus8 = 
sps->bit_depth_chroma - 8,
 
  214         .log2_max_frame_num_minus4 = 
sps->log2_max_frame_num - 4,
 
  215         .pic_order_cnt_type = 
sps->poc_type,
 
  216         .log2_max_pic_order_cnt_lsb_minus4 = 
sps->poc_type ? 0 : 
sps->log2_max_poc_lsb - 4,
 
  217         .offset_for_non_ref_pic = 
sps->offset_for_non_ref_pic,
 
  218         .offset_for_top_to_bottom_field = 
sps->offset_for_top_to_bottom_field,
 
  219         .num_ref_frames_in_pic_order_cnt_cycle = 
sps->poc_cycle_length,
 
  220         .max_num_ref_frames = 
sps->ref_frame_count,
 
  221         .pic_width_in_mbs_minus1 = 
sps->mb_width - 1,
 
  222         .pic_height_in_map_units_minus1 = (
sps->mb_height/(2 - 
sps->frame_mbs_only_flag)) - 1,
 
  223         .frame_crop_left_offset = 
sps->crop_left,
 
  224         .frame_crop_right_offset = 
sps->crop_right,
 
  225         .frame_crop_top_offset = 
sps->crop_top,
 
  226         .frame_crop_bottom_offset = 
sps->crop_bottom,
 
  227         .flags = (StdVideoH264SpsFlags) {
 
  228             .constraint_set0_flag = (
sps->constraint_set_flags >> 0) & 0x1,
 
  229             .constraint_set1_flag = (
sps->constraint_set_flags >> 1) & 0x1,
 
  230             .constraint_set2_flag = (
sps->constraint_set_flags >> 2) & 0x1,
 
  231             .constraint_set3_flag = (
sps->constraint_set_flags >> 3) & 0x1,
 
  232             .constraint_set4_flag = (
sps->constraint_set_flags >> 4) & 0x1,
 
  233             .constraint_set5_flag = (
sps->constraint_set_flags >> 5) & 0x1,
 
  234             .direct_8x8_inference_flag = 
sps->direct_8x8_inference_flag,
 
  235             .mb_adaptive_frame_field_flag = 
sps->mb_aff,
 
  236             .frame_mbs_only_flag = 
sps->frame_mbs_only_flag,
 
  237             .delta_pic_order_always_zero_flag = 
sps->delta_pic_order_always_zero_flag,
 
  238             .separate_colour_plane_flag = 
sps->residual_color_transform_flag,
 
  239             .gaps_in_frame_num_value_allowed_flag = 
sps->gaps_in_frame_num_allowed_flag,
 
  240             .qpprime_y_zero_transform_bypass_flag = 
sps->transform_bypass,
 
  241             .frame_cropping_flag = 
sps->crop,
 
  242             .seq_scaling_matrix_present_flag = 
sps->scaling_matrix_present,
 
  243             .vui_parameters_present_flag = 
sps->vui_parameters_present_flag,
 
  245         .pOffsetForRefFrame = 
sps->offset_for_ref_frame,
 
  246         .pScalingLists = vksps_scaling,
 
  247         .pSequenceParameterSetVui = vksps_vui,
 
  252                     StdVideoH264ScalingLists *vkpps_scaling,
 
  253                     StdVideoH264PictureParameterSet *vkpps)
 
  255     *vkpps_scaling = (StdVideoH264ScalingLists) {
 
  256         .scaling_list_present_mask = 
pps->pic_scaling_matrix_present_mask,
 
  257         .use_default_scaling_matrix_mask = 0, 
 
  260     for (
int i = 0; 
i < STD_VIDEO_H264_SCALING_LIST_4X4_NUM_LISTS; 
i++)
 
  261         for (
int j = 0; j < STD_VIDEO_H264_SCALING_LIST_4X4_NUM_ELEMENTS; j++)
 
  264     for (
int i = 0; 
i < STD_VIDEO_H264_SCALING_LIST_8X8_NUM_LISTS; 
i++)
 
  265         for (
int j = 0; j < STD_VIDEO_H264_SCALING_LIST_8X8_NUM_ELEMENTS; j++)
 
  266             vkpps_scaling->ScalingList8x8[
i][j] =
 
  269     *vkpps = (StdVideoH264PictureParameterSet) {
 
  270         .seq_parameter_set_id = 
pps->sps_id,
 
  271         .pic_parameter_set_id = 
pps->pps_id,
 
  272         .num_ref_idx_l0_default_active_minus1 = 
pps->ref_count[0] - 1,
 
  273         .num_ref_idx_l1_default_active_minus1 = 
pps->ref_count[1] - 1,
 
  274         .weighted_bipred_idc = 
pps->weighted_bipred_idc,
 
  275         .pic_init_qp_minus26 = 
pps->init_qp - 26,
 
  276         .pic_init_qs_minus26 = 
pps->init_qs - 26,
 
  277         .chroma_qp_index_offset = 
pps->chroma_qp_index_offset[0],
 
  278         .second_chroma_qp_index_offset = 
pps->chroma_qp_index_offset[1],
 
  279         .flags = (StdVideoH264PpsFlags) {
 
  280             .transform_8x8_mode_flag = 
pps->transform_8x8_mode,
 
  281             .redundant_pic_cnt_present_flag = 
pps->redundant_pic_cnt_present,
 
  282             .constrained_intra_pred_flag = 
pps->constrained_intra_pred,
 
  283             .deblocking_filter_control_present_flag = 
pps->deblocking_filter_parameters_present,
 
  284             .weighted_pred_flag = 
pps->weighted_pred,
 
  285             .bottom_field_pic_order_in_frame_present_flag = 
pps->pic_order_present,
 
  286             .entropy_coding_mode_flag = 
pps->cabac,
 
  287             .pic_scaling_matrix_present_flag = 
pps->pic_scaling_matrix_present_flag,
 
  289         .pScalingLists = vkpps_scaling,
 
  303     StdVideoH264SequenceParameterSetVui vksps_vui[
MAX_SPS_COUNT];
 
  310     VkVideoDecodeH264SessionParametersAddInfoKHR h264_params_info = {
 
  311         .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_H264_SESSION_PARAMETERS_ADD_INFO_KHR,
 
  317     VkVideoDecodeH264SessionParametersCreateInfoKHR h264_params = {
 
  318         .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_H264_SESSION_PARAMETERS_CREATE_INFO_KHR,
 
  319         .pParametersAddInfo = &h264_params_info,
 
  321     VkVideoSessionParametersCreateInfoKHR session_params_create = {
 
  322         .sType = VK_STRUCTURE_TYPE_VIDEO_SESSION_PARAMETERS_CREATE_INFO_KHR,
 
  323         .pNext = &h264_params,
 
  324         .videoSession = 
ctx->common.session,
 
  325         .videoSessionParametersTemplate = VK_NULL_HANDLE,
 
  330         if (
h->ps.sps_list[
i]) {
 
  331             const SPS *sps_l = 
h->ps.sps_list[
i];
 
  332             int idx = h264_params_info.stdSPSCount;
 
  333             set_sps(sps_l, &vksps_scaling[idx], &vksps_vui_header[idx], &vksps_vui[idx], &vksps[idx]);
 
  334             h264_params_info.stdSPSCount++;
 
  340         if (
h->ps.pps_list[
i]) {
 
  341             const PPS *pps_l = 
h->ps.pps_list[
i];
 
  342             int idx = h264_params_info.stdPPSCount;
 
  343             set_pps(pps_l, pps_l->
sps, &vkpps_scaling[idx], &vkpps[idx]);
 
  344             h264_params_info.stdPPSCount++;
 
  348     h264_params.maxStdSPSCount = h264_params_info.stdSPSCount;
 
  349     h264_params.maxStdPPSCount = h264_params_info.stdPPSCount;
 
  356            h264_params_info.stdSPSCount, h264_params_info.stdPPSCount);
 
  367     int dpb_slot_index = 0;
 
  377         if (pic == &
h->DPB[slot]) {
 
  378             dpb_slot_index = slot;
 
  385                             h->DPB[dpb_slot_index].field_picture,
 
  386                             h->DPB[dpb_slot_index].reference,
 
  392     for (
int i = 0; 
i < 
h->short_ref_count; 
i++) {
 
  395             if (
h->short_ref[
i] == &
h->DPB[slot]) {
 
  396                 dpb_slot_index = slot;
 
  403                                 h->DPB[dpb_slot_index].field_picture,
 
  404                                 h->DPB[dpb_slot_index].reference,
 
  412          i < h->short_ref_count + 
h->long_ref_count; 
r++) {
 
  417         for (
unsigned slot = 0; slot < 16; slot++) {
 
  418             if (
h->long_ref[
r] == &
h->DPB[slot]) {
 
  419                 dpb_slot_index = slot;
 
  426                                 h->DPB[dpb_slot_index].field_picture,
 
  427                                 h->DPB[dpb_slot_index].reference,
 
  434     hp->
h264pic = (StdVideoDecodeH264PictureInfo) {
 
  435         .seq_parameter_set_id = pic->
pps->
sps_id,
 
  436         .pic_parameter_set_id = pic->
pps->
pps_id,
 
  441         .flags = (StdVideoDecodeH264PictureInfoFlags) {
 
  444             .IdrPicFlag = 
h->picture_idr,
 
  445             .bottom_field_flag = 
h->picture_structure != 
PICT_FRAME &&
 
  447             .is_reference = 
h->nal_ref_idc != 0,
 
  453         .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_H264_PICTURE_INFO_KHR,
 
  454         .pStdPictureInfo = &hp->
h264pic,
 
  458         .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_INFO_KHR,
 
  461         .pSetupReferenceSlot = &vp->
ref_slot,
 
  462         .referenceSlotCount = 
h->short_ref_count + 
h->long_ref_count,
 
  464         .dstPictureResource = (VkVideoPictureResourceInfoKHR) {
 
  465             .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
 
  466             .codedOffset = (VkOffset2D){ 0, 0 },
 
  467             .codedExtent = (VkExtent2D){ pic->
f->
width, pic->
f->
height },
 
  469             .imageViewBinding = vp->
view.
out[0],
 
  496         hp->
h264pic.flags.is_intra = 0;
 
  513 #ifdef VK_KHR_video_maintenance2 
  514     StdVideoH264ScalingLists vksps_scaling;
 
  515     StdVideoH264HrdParameters vksps_vui_header;
 
  516     StdVideoH264SequenceParameterSetVui vksps_vui;
 
  517     StdVideoH264SequenceParameterSet vksps;
 
  518     StdVideoH264ScalingLists vkpps_scaling;
 
  519     StdVideoH264PictureParameterSet vkpps;
 
  520     VkVideoDecodeH264InlineSessionParametersInfoKHR h264_params;
 
  524                 &vksps_vui_header, &vksps_vui, &vksps);
 
  525         set_pps(
h->ps.pps, 
h->ps.sps, &vkpps_scaling, &vkpps);
 
  526         h264_params = (VkVideoDecodeH264InlineSessionParametersInfoKHR) {
 
  527             .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_H264_INLINE_SESSION_PARAMETERS_INFO_KHR,
 
  575     .
p.
name                = 
"h264_vulkan",