mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-05 06:58:49 +00:00
vkformat: invert srgb and multiplane && planes > 1 checks
The primary format for RGB includes sRGB transfer but was not actually being used. The !(no_multiplane && planes > 1) check for YUV resulted in those formats never being used. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5288>
This commit is contained in:
parent
8a9d630e3b
commit
4d3b03e8e8
2 changed files with 9 additions and 7 deletions
|
@ -646,8 +646,8 @@ gst_vulkan_format_from_video_info_2 (GstVulkanPhysicalDevice * physical_device,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GST_VIDEO_INFO_IS_RGB (info)) {
|
if (GST_VIDEO_INFO_IS_RGB (info)) {
|
||||||
if (basics_primary && GST_VIDEO_INFO_COLORIMETRY (info).transfer !=
|
if (basics_primary && (GST_VIDEO_INFO_COLORIMETRY (info).transfer ==
|
||||||
GST_VIDEO_TRANSFER_SRGB) {
|
GST_VIDEO_TRANSFER_SRGB)) {
|
||||||
if (fmts)
|
if (fmts)
|
||||||
fmts[0] = vk_formats_map[i].vkfrmt;
|
fmts[0] = vk_formats_map[i].vkfrmt;
|
||||||
if (n_imgs)
|
if (n_imgs)
|
||||||
|
@ -655,7 +655,7 @@ gst_vulkan_format_from_video_info_2 (GstVulkanPhysicalDevice * physical_device,
|
||||||
if (usage)
|
if (usage)
|
||||||
*usage = _get_usage (feats_primary);
|
*usage = _get_usage (feats_primary);
|
||||||
} else if (basics_secondary
|
} else if (basics_secondary
|
||||||
&& GST_VIDEO_INFO_COLORIMETRY (info).transfer ==
|
&& GST_VIDEO_INFO_COLORIMETRY (info).transfer !=
|
||||||
GST_VIDEO_TRANSFER_SRGB) {
|
GST_VIDEO_TRANSFER_SRGB) {
|
||||||
if (fmts)
|
if (fmts)
|
||||||
fmts[0] = vk_formats_map[i].vkfrmts[0];
|
fmts[0] = vk_formats_map[i].vkfrmts[0];
|
||||||
|
@ -667,8 +667,8 @@ gst_vulkan_format_from_video_info_2 (GstVulkanPhysicalDevice * physical_device,
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (basics_primary && !(no_multiplane
|
if (basics_primary && !no_multiplane
|
||||||
&& GST_VIDEO_INFO_N_PLANES (info) > 1)) {
|
&& GST_VIDEO_INFO_N_PLANES (info) > 1) {
|
||||||
if (fmts)
|
if (fmts)
|
||||||
fmts[0] = vk_formats_map[i].vkfrmt;
|
fmts[0] = vk_formats_map[i].vkfrmt;
|
||||||
if (n_imgs)
|
if (n_imgs)
|
||||||
|
|
|
@ -69,11 +69,13 @@ GST_START_TEST (test_format_from_video_info_2)
|
||||||
|
|
||||||
fail_unless (gst_video_info_set_format (&vinfo, GST_VIDEO_FORMAT_RGBA, 620,
|
fail_unless (gst_video_info_set_format (&vinfo, GST_VIDEO_FORMAT_RGBA, 620,
|
||||||
480));
|
480));
|
||||||
|
fail_unless (GST_VIDEO_INFO_COLORIMETRY (&vinfo).transfer ==
|
||||||
|
GST_VIDEO_TRANSFER_SRGB);
|
||||||
|
|
||||||
fail_unless (gst_vulkan_format_from_video_info_2 (phy_dev, &vinfo,
|
fail_unless (gst_vulkan_format_from_video_info_2 (phy_dev, &vinfo,
|
||||||
VK_IMAGE_TILING_LINEAR, TRUE, vk_fmts, &n_imgs, &supported_usage));
|
VK_IMAGE_TILING_LINEAR, TRUE, vk_fmts, &n_imgs, &supported_usage));
|
||||||
|
|
||||||
fail_unless (n_imgs == 1 && vk_fmts[0] == VK_FORMAT_R8G8B8A8_UNORM);
|
fail_unless (n_imgs == 1 && vk_fmts[0] == VK_FORMAT_R8G8B8A8_SRGB);
|
||||||
|
|
||||||
fail_unless (gst_video_info_set_format (&vinfo, GST_VIDEO_FORMAT_RGBA, 620,
|
fail_unless (gst_video_info_set_format (&vinfo, GST_VIDEO_FORMAT_RGBA, 620,
|
||||||
480));
|
480));
|
||||||
|
@ -83,7 +85,7 @@ GST_START_TEST (test_format_from_video_info_2)
|
||||||
fail_unless (gst_vulkan_format_from_video_info_2 (phy_dev, &vinfo,
|
fail_unless (gst_vulkan_format_from_video_info_2 (phy_dev, &vinfo,
|
||||||
VK_IMAGE_TILING_LINEAR, TRUE, vk_fmts, &n_imgs, &supported_usage));
|
VK_IMAGE_TILING_LINEAR, TRUE, vk_fmts, &n_imgs, &supported_usage));
|
||||||
|
|
||||||
fail_unless (n_imgs == 1 && vk_fmts[0] == VK_FORMAT_R8G8B8A8_SRGB);
|
fail_unless (n_imgs == 1 && vk_fmts[0] == VK_FORMAT_R8G8B8A8_UNORM);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_END_TEST;
|
GST_END_TEST;
|
||||||
|
|
Loading…
Reference in a new issue