mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-03 14:08:56 +00:00
vkvideoutils: add VkVideoDecodeUsageInfoKHR in profile
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4850>
This commit is contained in:
parent
fd1b1332b7
commit
f896e2a347
2 changed files with 8 additions and 3 deletions
|
@ -220,7 +220,11 @@ gst_vulkan_video_profile_from_caps (GstVulkanVideoProfile * profile,
|
||||||
|
|
||||||
structure = gst_caps_get_structure (caps, 0);
|
structure = gst_caps_get_structure (caps, 0);
|
||||||
|
|
||||||
|
profile->usage.sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_USAGE_INFO_KHR;
|
||||||
|
profile->usage.videoUsageHints = VK_VIDEO_DECODE_USAGE_DEFAULT_KHR;
|
||||||
|
|
||||||
profile->profile.sType = VK_STRUCTURE_TYPE_VIDEO_PROFILE_INFO_KHR;
|
profile->profile.sType = VK_STRUCTURE_TYPE_VIDEO_PROFILE_INFO_KHR;
|
||||||
|
profile->profile.pNext = &profile->usage;
|
||||||
|
|
||||||
mime = gst_structure_get_name (structure);
|
mime = gst_structure_get_name (structure);
|
||||||
for (i = 0; i < G_N_ELEMENTS (video_codecs_map); i++) {
|
for (i = 0; i < G_N_ELEMENTS (video_codecs_map); i++) {
|
||||||
|
@ -236,7 +240,7 @@ gst_vulkan_video_profile_from_caps (GstVulkanVideoProfile * profile,
|
||||||
STD_VIDEO_H264_PROFILE_IDC_INVALID;
|
STD_VIDEO_H264_PROFILE_IDC_INVALID;
|
||||||
profile->codec.h264.pictureLayout =
|
profile->codec.h264.pictureLayout =
|
||||||
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_FLAG_BITS_MAX_ENUM_KHR;
|
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_FLAG_BITS_MAX_ENUM_KHR;
|
||||||
profile->profile.pNext = &profile->codec;
|
profile->usage.pNext = &profile->codec;
|
||||||
|
|
||||||
profile_str = gst_structure_get_string (structure, "profile");
|
profile_str = gst_structure_get_string (structure, "profile");
|
||||||
for (j = 0; profile_str && j < G_N_ELEMENTS (h264_profile_map); j++) {
|
for (j = 0; profile_str && j < G_N_ELEMENTS (h264_profile_map); j++) {
|
||||||
|
@ -261,7 +265,7 @@ gst_vulkan_video_profile_from_caps (GstVulkanVideoProfile * profile,
|
||||||
profile->codec.h265.sType = video_codecs_map[i].stype;
|
profile->codec.h265.sType = video_codecs_map[i].stype;
|
||||||
profile->codec.h265.stdProfileIdc =
|
profile->codec.h265.stdProfileIdc =
|
||||||
STD_VIDEO_H265_PROFILE_IDC_INVALID;
|
STD_VIDEO_H265_PROFILE_IDC_INVALID;
|
||||||
profile->profile.pNext = &profile->codec;
|
profile->usage.pNext = &profile->codec;
|
||||||
|
|
||||||
profile_str = gst_structure_get_string (structure, "profile");
|
profile_str = gst_structure_get_string (structure, "profile");
|
||||||
for (j = 0; profile_str && j < G_N_ELEMENTS (h265_profile_map); j++) {
|
for (j = 0; profile_str && j < G_N_ELEMENTS (h265_profile_map); j++) {
|
||||||
|
@ -274,7 +278,7 @@ gst_vulkan_video_profile_from_caps (GstVulkanVideoProfile * profile,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
profile->profile.pNext = NULL;
|
profile->usage.pNext = NULL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,6 +37,7 @@ struct _GstVulkanVideoProfile
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
#if GST_VULKAN_HAVE_VIDEO_EXTENSIONS
|
#if GST_VULKAN_HAVE_VIDEO_EXTENSIONS
|
||||||
VkVideoProfileInfoKHR profile;
|
VkVideoProfileInfoKHR profile;
|
||||||
|
VkVideoDecodeUsageInfoKHR usage;
|
||||||
union {
|
union {
|
||||||
VkVideoDecodeH264ProfileInfoKHR h264;
|
VkVideoDecodeH264ProfileInfoKHR h264;
|
||||||
VkVideoDecodeH265ProfileInfoKHR h265;
|
VkVideoDecodeH265ProfileInfoKHR h265;
|
||||||
|
|
Loading…
Reference in a new issue