40 if (
ctx->session_params)
41 vk->DestroyVideoSessionParametersKHR(
s->hwctx->act_dev,
65 if (
ctx->codec->picture_priv_data_size > 0) {
74 vkf, vkfc->format[0], 0);
79 if (!
ctx->common.layered_dpb) {
84 rvkf,
ctx->pic_format, 1);
103 vk->DestroyImageView(
ctx->s.hwctx->act_dev, vp->
in.
view,
104 ctx->s.hwctx->alloc);
107 vk->DestroyImageView(
ctx->s.hwctx->act_dev, vp->
dpb.
view,
108 ctx->s.hwctx->alloc);
116 VkVideoEncodeRateControlInfoKHR *rc_info,
117 VkVideoEncodeRateControlLayerInfoKHR *rc_layer )
121 *rc_info = (VkVideoEncodeRateControlInfoKHR) {
122 .sType = VK_STRUCTURE_TYPE_VIDEO_ENCODE_RATE_CONTROL_INFO_KHR,
123 .rateControlMode =
ctx->opts.rc_mode,
126 if (
ctx->opts.rc_mode > VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR) {
127 *rc_layer = (VkVideoEncodeRateControlLayerInfoKHR) {
128 .sType = VK_STRUCTURE_TYPE_VIDEO_ENCODE_RATE_CONTROL_LAYER_INFO_KHR,
134 rc_info->layerCount++;
135 rc_info->pLayers = rc_layer;
138 return ctx->codec->init_pic_rc(avctx, pic, rc_info, rc_layer);
147 const size_t size_align =
ctx->caps.minBitstreamBufferSizeAlignment;
153 int err, max_pkt_size;
159 VkCommandBuffer cmd_buf;
160 VkImageMemoryBarrier2 img_bar[37];
164 VkVideoBeginCodingInfoKHR encode_start;
166 .sType = VK_STRUCTURE_TYPE_VIDEO_END_CODING_INFO_KHR,
169 VkVideoEncodeRateControlLayerInfoKHR rc_layer;
170 VkVideoEncodeRateControlInfoKHR rc_info;
171 VkVideoEncodeQualityLevelInfoKHR q_info;
172 VkVideoCodingControlInfoKHR encode_ctrl;
174 VkVideoReferenceSlotInfoKHR ref_slot[37];
175 VkVideoEncodeInfoKHR encode_info;
178 max_pkt_size =
FFALIGN(3 *
ctx->base.surface_width *
ctx->base.surface_height + (1 << 16),
179 ctx->caps.minBitstreamBufferSizeAlignment);
182 VK_BUFFER_USAGE_VIDEO_ENCODE_DST_BIT_KHR,
183 &
ctx->profile_list, max_pkt_size,
184 VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT |
185 VK_MEMORY_PROPERTY_HOST_CACHED_BIT);
192 err =
init_pic_rc(avctx, base_pic, &rc_info, &rc_layer);
196 q_info = (VkVideoEncodeQualityLevelInfoKHR) {
197 .sType = VK_STRUCTURE_TYPE_VIDEO_ENCODE_QUALITY_LEVEL_INFO_KHR,
199 .qualityLevel =
ctx->opts.quality,
201 encode_ctrl = (VkVideoCodingControlInfoKHR) {
202 .sType = VK_STRUCTURE_TYPE_VIDEO_CODING_CONTROL_INFO_KHR,
204 .
flags = VK_VIDEO_CODING_CONTROL_ENCODE_QUALITY_LEVEL_BIT_KHR |
205 VK_VIDEO_CODING_CONTROL_ENCODE_RATE_CONTROL_BIT_KHR |
206 VK_VIDEO_CODING_CONTROL_RESET_BIT_KHR,
209 for (
int i = 0;
i <
ctx->caps.maxDpbSlots;
i++) {
212 ctx->slots[
i] = base_pic;
219 vp->
dpb_res = (VkVideoPictureResourceInfoKHR) {
220 .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
222 .codedOffset = { 0 },
223 .codedExtent = (VkExtent2D){
ctx->base.surface_width,
224 ctx->base.surface_height },
225 .baseArrayLayer =
ctx->common.layered_dpb ? slot_index : 0,
226 .imageViewBinding = vp->
dpb.
view,
229 vp->
dpb_slot = (VkVideoReferenceSlotInfoKHR) {
230 .sType = VK_STRUCTURE_TYPE_VIDEO_REFERENCE_SLOT_INFO_KHR,
232 .slotIndex = slot_index,
233 .pPictureResource = &vp->
dpb_res,
236 encode_info = (VkVideoEncodeInfoKHR) {
237 .sType = VK_STRUCTURE_TYPE_VIDEO_ENCODE_INFO_KHR,
240 .srcPictureResource = (VkVideoPictureResourceInfoKHR) {
241 .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
243 .codedOffset = { 0, 0 },
247 .imageViewBinding = vp->
in.
view,
249 .pSetupReferenceSlot = &vp->
dpb_slot,
250 .referenceSlotCount = 0,
251 .pReferenceSlots = ref_slot,
252 .dstBuffer = sd_buf->
buf,
253 .dstBufferOffset = 0,
254 .dstBufferRange = sd_buf->
size,
255 .precedingExternallyEncodedBytes = 0,
259 for (
int j = 0; j < base_pic->
nb_refs[
i]; j++) {
262 ref_slot[encode_info.referenceSlotCount++] = rvp->
dpb_slot;
268 ref_slot[encode_info.referenceSlotCount] = vp->
dpb_slot;
269 ref_slot[encode_info.referenceSlotCount].slotIndex = -1;
272 err =
ctx->codec->init_pic_params(avctx, base_pic,
277 encode_start = (VkVideoBeginCodingInfoKHR) {
278 .sType = VK_STRUCTURE_TYPE_VIDEO_BEGIN_CODING_INFO_KHR,
280 .videoSession =
ctx->common.session,
281 .videoSessionParameters =
ctx->session_params,
282 .referenceSlotCount = encode_info.referenceSlotCount + 1,
283 .pReferenceSlots = ref_slot,
288 uint8_t *hdr_dst = sd_buf->
mapped_mem + encode_info.dstBufferOffset;
289 size_t data_size = encode_info.dstBufferRange;
290 err =
ctx->codec->write_sequence_headers(avctx, base_pic, hdr_dst, &data_size);
293 encode_info.dstBufferOffset += data_size;
294 encode_info.dstBufferRange -= data_size;
298 if (
ctx->codec->write_extra_headers) {
299 uint8_t *hdr_dst = sd_buf->
mapped_mem + encode_info.dstBufferOffset;
300 size_t data_size = encode_info.dstBufferRange;
301 err =
ctx->codec->write_extra_headers(avctx, base_pic, hdr_dst, &data_size);
304 encode_info.dstBufferOffset += data_size;
305 encode_info.dstBufferRange -= data_size;
309 if (
ctx->codec->write_filler) {
310 uint8_t *hdr_dst = sd_buf->
mapped_mem + encode_info.dstBufferOffset;
311 size_t data_size = encode_info.dstBufferRange;
313 uint32_t
offset = encode_info.dstBufferOffset;
314 size_t offset_align =
ctx->caps.minBitstreamBufferOffsetAlignment;
319 while (filler_data < ctx->codec->filler_header_size)
320 filler_data += offset_align;
322 filler_data -=
ctx->codec->filler_header_size;
324 err =
ctx->codec->write_filler(avctx, filler_data,
325 hdr_dst, &data_size);
329 encode_info.dstBufferOffset += data_size;
330 encode_info.dstBufferRange -= data_size;
337 encode_info.dstBufferRange -= size_align;
338 encode_info.dstBufferRange =
FFALIGN(encode_info.dstBufferRange,
353 VK_PIPELINE_STAGE_2_ALL_COMMANDS_BIT,
354 VK_PIPELINE_STAGE_2_VIDEO_ENCODE_BIT_KHR);
359 img_bar[nb_img_bar] = (VkImageMemoryBarrier2) {
360 .sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER_2,
362 .srcStageMask = VK_PIPELINE_STAGE_2_ALL_COMMANDS_BIT,
363 .srcAccessMask = vkf->access[0],
364 .dstStageMask = VK_PIPELINE_STAGE_2_VIDEO_ENCODE_BIT_KHR,
365 .dstAccessMask = VK_ACCESS_2_VIDEO_ENCODE_READ_BIT_KHR,
366 .oldLayout = vkf->layout[0],
367 .newLayout = VK_IMAGE_LAYOUT_VIDEO_ENCODE_SRC_KHR,
368 .srcQueueFamilyIndex = vkf->queue_family[0],
369 .dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED,
370 .image = vkf->img[0],
371 .subresourceRange = (VkImageSubresourceRange) {
378 &img_bar[nb_img_bar], &nb_img_bar);
380 if (!
ctx->common.layered_dpb) {
385 VK_PIPELINE_STAGE_2_ALL_COMMANDS_BIT,
386 VK_PIPELINE_STAGE_2_VIDEO_ENCODE_BIT_KHR);
392 for (
int j = 0; j < base_pic->
nb_refs[
i]; j++) {
395 VK_PIPELINE_STAGE_2_ALL_COMMANDS_BIT,
396 VK_PIPELINE_STAGE_2_VIDEO_ENCODE_BIT_KHR);
403 VK_PIPELINE_STAGE_2_VIDEO_ENCODE_BIT_KHR,
404 VK_PIPELINE_STAGE_2_VIDEO_ENCODE_BIT_KHR);
410 vk->CmdPipelineBarrier2(cmd_buf, &(VkDependencyInfo) {
411 .sType = VK_STRUCTURE_TYPE_DEPENDENCY_INFO,
412 .pImageMemoryBarriers = img_bar,
413 .imageMemoryBarrierCount = nb_img_bar,
417 vk->CmdBeginVideoCodingKHR(cmd_buf, &encode_start);
420 if (!
ctx->session_reset) {
421 vk->CmdControlVideoCodingKHR(cmd_buf, &encode_ctrl);
422 ctx->session_reset++;
426 vk->CmdBeginQuery(cmd_buf,
ctx->enc_pool.query_pool, exec->
query_idx + 0, 0);
427 vk->CmdEncodeVideoKHR(cmd_buf, &encode_info);
428 vk->CmdEndQuery(cmd_buf,
ctx->enc_pool.query_pool, exec->
query_idx + 0);
431 vk->CmdEndVideoCodingKHR(cmd_buf, &
encode_end);
469 uint32_t *query_data;
474 if (
ret == VK_NOT_READY) {
480 if (
ret != VK_NOT_READY &&
ret != VK_SUCCESS) {
486 if (query_data[2] != VK_QUERY_RESULT_STATUS_COMPLETE_KHR) {
492 if (!(sd_buf->
flags & VK_MEMORY_PROPERTY_HOST_COHERENT_BIT)) {
494 VkMappedMemoryRange invalidate_buf;
500 if (
ctx->s.props.properties.limits.nonCoherentAtomSize >
501 ctx->caps.minBitstreamBufferOffsetAlignment && offs &&
502 (
FFALIGN(offs,
ctx->s.props.properties.limits.nonCoherentAtomSize) != offs)) {
503 offs -=
ctx->s.props.properties.limits.nonCoherentAtomSize;
504 offs =
FFALIGN(
FFMAX(offs, 0),
ctx->s.props.properties.limits.nonCoherentAtomSize);
507 invalidate_buf = (VkMappedMemoryRange) {
508 .sType = VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE,
509 .memory = sd_buf->
mem,
511 .size = VK_WHOLE_SIZE,
514 vk->FlushMappedMemoryRanges(
ctx->s.hwctx->act_dev, 1, &invalidate_buf);
573 hwfc->
tiling = VK_IMAGE_TILING_OPTIMAL;
574 hwfc->
usage = VK_IMAGE_USAGE_SAMPLED_BIT |
575 VK_IMAGE_USAGE_VIDEO_ENCODE_DPB_BIT_KHR;
577 if (
ctx->common.layered_dpb)
587 if (
ctx->common.layered_dpb) {
589 if (!
ctx->common.layered_frame)
593 ctx->common.layered_frame, 0);
598 &
ctx->common.layered_view,
599 &
ctx->common.layered_aspect,
614 ctx->explicit_qp =
ctx->opts.qp;
623 if (
ctx->explicit_qp >= 0) {
624 ctx->opts.rc_mode = VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR;
630 ctx->opts.rc_mode = VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR;
632 if (
ctx->enc_caps.rateControlModes & VK_VIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR)
633 ctx->opts.rc_mode = VK_VIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR;
634 else if (
ctx->enc_caps.rateControlModes & VK_VIDEO_ENCODE_RATE_CONTROL_MODE_CBR_BIT_KHR)
635 ctx->opts.rc_mode = VK_VIDEO_ENCODE_RATE_CONTROL_MODE_CBR_BIT_KHR;
637 ctx->opts.rc_mode = VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DEFAULT_KHR;
639 ctx->explicit_qp = 18;
640 ctx->opts.rc_mode = VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR;
644 }
else if (
ctx->opts.rc_mode != VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR &&
650 if (
ctx->opts.rc_mode && !(
ctx->enc_caps.rateControlModes &
ctx->opts.rc_mode)) {
651 static const char *rc_modes[] = {
652 [VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DEFAULT_KHR] =
"default",
653 [VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR] =
"cqp",
654 [VK_VIDEO_ENCODE_RATE_CONTROL_MODE_CBR_BIT_KHR] =
"cbr",
655 [VK_VIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR] =
"vbr",
660 for (
int i = VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR;
661 i <= VK_VIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR;
i <<= 1) {
662 if (!(
ctx->enc_caps.rateControlModes &
i))
680 size_t data_len =
sizeof(
data);
682 err =
ctx->codec->write_sequence_headers(avctx,
NULL,
data, &data_len);
685 "for extradata: %d.\n", err);
705 void *codec_caps,
void *quality_pnext)
715 VkVideoFormatPropertiesKHR *ret_info;
716 uint32_t nb_out_fmts = 0;
718 VkPhysicalDeviceVideoEncodeQualityLevelInfoKHR quality_info;
720 VkQueryPoolVideoEncodeFeedbackCreateInfoKHR query_create;
722 VkVideoSessionCreateInfoKHR session_create = {
723 .sType = VK_STRUCTURE_TYPE_VIDEO_SESSION_CREATE_INFO_KHR,
725 VkPhysicalDeviceVideoFormatInfoKHR fmt_info = {
726 .sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VIDEO_FORMAT_INFO_KHR,
727 .pNext = &
ctx->profile_list,
732 "required to associate the encoding device.\n");
741 s->hwfc =
s->frames->hwctx;
744 s->hwctx =
s->device->hwctx;
751 s->hwctx->nb_enabled_dev_extensions);
755 VK_KHR_VIDEO_ENCODE_QUEUE_EXTENSION_NAME);
759 VK_KHR_VIDEO_MAINTENANCE_1_EXTENSION_NAME);
774 VK_QUEUE_VIDEO_ENCODE_BIT_KHR,
788 ctx->usage_info = (VkVideoEncodeUsageInfoKHR) {
789 .sType = VK_STRUCTURE_TYPE_VIDEO_ENCODE_USAGE_INFO_KHR,
790 .videoUsageHints =
ctx->opts.usage,
791 .videoContentHints =
ctx->opts.content,
792 .tuningMode =
ctx->opts.tune,
796 ctx->profile.sType = VK_STRUCTURE_TYPE_VIDEO_PROFILE_INFO_KHR;
797 ctx->profile.pNext = &
ctx->usage_info;
801 ctx->profile.chromaBitDepth =
ctx->profile.lumaBitDepth;
808 ctx->profile_list.sType = VK_STRUCTURE_TYPE_VIDEO_PROFILE_LIST_INFO_KHR;
809 ctx->profile_list.profileCount = 1;
810 ctx->profile_list.pProfiles = &
ctx->profile;
813 ctx->enc_caps.sType = VK_STRUCTURE_TYPE_VIDEO_ENCODE_CAPABILITIES_KHR;
814 ctx->enc_caps.pNext = codec_caps;
815 ctx->caps.sType = VK_STRUCTURE_TYPE_VIDEO_CAPABILITIES_KHR;
816 ctx->caps.pNext = &
ctx->enc_caps;
818 ret = vk->GetPhysicalDeviceVideoCapabilitiesKHR(
s->hwctx->phys_dev,
821 if (
ret == VK_ERROR_VIDEO_PROFILE_OPERATION_NOT_SUPPORTED_KHR) {
823 "%s profile \"%s\" not supported!\n",
827 }
else if (
ret == VK_ERROR_VIDEO_PROFILE_FORMAT_NOT_SUPPORTED_KHR) {
829 "format (%s) not supported!\n",
832 }
else if (
ret == VK_ERROR_FEATURE_NOT_PRESENT ||
833 ret == VK_ERROR_FORMAT_NOT_SUPPORTED) {
835 }
else if (
ret != VK_SUCCESS) {
844 query_create = (VkQueryPoolVideoEncodeFeedbackCreateInfoKHR) {
845 .sType = VK_STRUCTURE_TYPE_QUERY_POOL_VIDEO_ENCODE_FEEDBACK_CREATE_INFO_KHR,
846 .pNext = &
ctx->profile,
847 .encodeFeedbackFlags =
ctx->enc_caps.supportedEncodeFeedbackFlags &
848 (~VK_VIDEO_ENCODE_FEEDBACK_BITSTREAM_HAS_OVERRIDES_BIT_KHR),
851 1, VK_QUERY_TYPE_VIDEO_ENCODE_FEEDBACK_KHR, 0,
856 if (
ctx->opts.quality >
ctx->enc_caps.maxQualityLevels) {
859 ctx->opts.quality,
ctx->enc_caps.maxQualityLevels);
864 quality_info = (VkPhysicalDeviceVideoEncodeQualityLevelInfoKHR) {
865 .sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VIDEO_ENCODE_QUALITY_LEVEL_INFO_KHR,
866 .pVideoProfile = &
ctx->profile,
867 .qualityLevel =
ctx->opts.quality,
869 ctx->quality_props = (VkVideoEncodeQualityLevelPropertiesKHR) {
870 .sType = VK_STRUCTURE_TYPE_VIDEO_ENCODE_QUALITY_LEVEL_PROPERTIES_KHR,
871 .pNext = quality_pnext,
873 ret = vk->GetPhysicalDeviceVideoEncodeQualityLevelPropertiesKHR(
s->hwctx->phys_dev,
875 &
ctx->quality_props);
876 if (
ret != VK_SUCCESS)
884 ctx->caps.minCodedExtent.width,
ctx->caps.maxCodedExtent.width);
886 ctx->caps.minCodedExtent.height,
ctx->caps.maxCodedExtent.height);
888 ctx->caps.pictureAccessGranularity.width);
890 ctx->caps.pictureAccessGranularity.height);
892 ctx->caps.minBitstreamBufferOffsetAlignment);
894 ctx->caps.minBitstreamBufferSizeAlignment);
896 ctx->caps.maxDpbSlots);
898 ctx->caps.maxActiveReferencePictures);
899 av_log(avctx,
AV_LOG_VERBOSE,
" Codec header version: %i.%i.%i (driver), %i.%i.%i (compiled)\n",
903 ctx->enc_caps.maxQualityLevels);
905 ctx->enc_caps.encodeInputPictureGranularity.width);
907 ctx->enc_caps.encodeInputPictureGranularity.height);
911 ctx->caps.
flags & VK_VIDEO_CAPABILITY_PROTECTED_CONTENT_BIT_KHR ?
913 ctx->caps.
flags & VK_VIDEO_CAPABILITY_SEPARATE_REFERENCE_IMAGES_BIT_KHR ?
914 " separate_references" :
"");
931 av_log(avctx,
AV_LOG_ERROR,
"Input of %ix%i too large for encoder limits: %ix%i max\n",
933 ctx->caps.minCodedExtent.width,
ctx->caps.minCodedExtent.height);
937 fmt_info.imageUsage = VK_IMAGE_USAGE_VIDEO_ENCODE_DPB_BIT_KHR |
938 VK_IMAGE_USAGE_VIDEO_ENCODE_DST_BIT_KHR;
940 ctx->common.layered_dpb = !(
ctx->caps.
flags & VK_VIDEO_CAPABILITY_SEPARATE_REFERENCE_IMAGES_BIT_KHR);
943 ret = vk->GetPhysicalDeviceVideoFormatPropertiesKHR(
s->hwctx->phys_dev,
946 if (
ret == VK_ERROR_FORMAT_NOT_SUPPORTED ||
947 (!nb_out_fmts &&
ret == VK_SUCCESS)) {
949 }
else if (
ret != VK_SUCCESS) {
955 ret_info =
av_mallocz(
sizeof(*ret_info)*nb_out_fmts);
959 for (
int i = 0;
i < nb_out_fmts;
i++)
960 ret_info[
i].sType = VK_STRUCTURE_TYPE_VIDEO_FORMAT_PROPERTIES_KHR;
962 ret = vk->GetPhysicalDeviceVideoFormatPropertiesKHR(
s->hwctx->phys_dev,
964 &nb_out_fmts, ret_info);
965 if (
ret == VK_ERROR_FORMAT_NOT_SUPPORTED ||
966 (!nb_out_fmts &&
ret == VK_SUCCESS)) {
969 }
else if (
ret != VK_SUCCESS) {
977 for (
i = 0;
i < nb_out_fmts;
i++)
980 for (
i = 0;
i < nb_out_fmts;
i++) {
982 ctx->pic_format = ret_info[
i].format;
989 if (
i == nb_out_fmts) {
996 session_create.pVideoProfile = &
ctx->profile;
997 session_create.
flags = 0x0;
998 session_create.queueFamilyIndex =
ctx->qf_enc.queue_family;
999 session_create.maxCodedExtent =
ctx->caps.maxCodedExtent;
1000 session_create.maxDpbSlots =
ctx->caps.maxDpbSlots;
1001 session_create.maxActiveReferencePictures =
ctx->caps.maxActiveReferencePictures;
1002 session_create.pictureFormat =
ctx->pic_format;
1003 session_create.referencePictureFormat = session_create.pictureFormat;
1004 session_create.pStdHeaderVersion = &vk_desc->
ext_props;
1028 void *codec_params_pnext)
1034 VkVideoEncodeQualityLevelInfoKHR q_info;
1035 VkVideoSessionParametersCreateInfoKHR session_params_create;
1037 q_info = (VkVideoEncodeQualityLevelInfoKHR) {
1038 .sType = VK_STRUCTURE_TYPE_VIDEO_ENCODE_QUALITY_LEVEL_INFO_KHR,
1039 .pNext = codec_params_pnext,
1040 .qualityLevel =
ctx->opts.quality,
1042 session_params_create = (VkVideoSessionParametersCreateInfoKHR) {
1043 .sType = VK_STRUCTURE_TYPE_VIDEO_SESSION_PARAMETERS_CREATE_INFO_KHR,
1045 .videoSession =
ctx->common.session,
1046 .videoSessionParametersTemplate = VK_NULL_HANDLE,
1050 ret = vk->CreateVideoSessionParametersKHR(
s->hwctx->act_dev, &session_params_create,
1051 s->hwctx->alloc, &
ctx->session_params);
1052 if (
ret != VK_SUCCESS) {
1053 av_log(avctx,
AV_LOG_ERROR,
"Unable to create Vulkan video session parameters: %s!\n",