mirror of
https://github.com/KhronosGroup/OpenCL-CTS.git
synced 2026-03-21 06:49:02 +00:00
Corrected procedure to collect proper size of image from VkImageCreateInfo (#2289)
Fixes #2155 according to issue description Additional remark: The image size was previously calculated based on the memory size, which seems unusual. Due to Vulkan's configuration capabilities, the size of memory allocated for a specific texture may differ from what would be expected based on the texture dimensions. Thus, calculating the image dimensions back from the memory size of a Vulkan texture can be challenging.
This commit is contained in:
@@ -232,12 +232,11 @@ struct ConsistencyExternalImageTest : public VulkanTestBase
|
||||
|
||||
const VulkanMemoryTypeList& memoryTypeList =
|
||||
vkImage2D.getMemoryTypeList();
|
||||
uint64_t totalImageMemSize = vkImage2D.getSize();
|
||||
|
||||
log_info("Memory type index: %u\n", (uint32_t)memoryTypeList[0]);
|
||||
log_info("Memory type property: %d\n",
|
||||
memoryTypeList[0].getMemoryTypeProperty());
|
||||
log_info("Image size : %ld\n", totalImageMemSize);
|
||||
log_info("Image size : %ld\n", vkImage2D.getSize());
|
||||
|
||||
VulkanDeviceMemory* vkDeviceMem =
|
||||
new VulkanDeviceMemory(*vkDevice, vkImage2D, memoryTypeList[0],
|
||||
@@ -298,14 +297,12 @@ struct ConsistencyExternalImageTest : public VulkanTestBase
|
||||
const VkImageCreateInfo VulkanImageCreateInfo =
|
||||
vkImage2D.getVkImageCreateInfo();
|
||||
|
||||
errNum = getCLImageInfoFromVkImageInfo(&VulkanImageCreateInfo,
|
||||
totalImageMemSize, &img_format,
|
||||
&image_desc);
|
||||
if (errNum != CL_SUCCESS)
|
||||
{
|
||||
log_error("getCLImageInfoFromVkImageInfo failed!!!");
|
||||
return TEST_FAIL;
|
||||
}
|
||||
auto layout = vkImage2D.getSubresourceLayout();
|
||||
errNum = getCLImageInfoFromVkImageInfo(
|
||||
device, &VulkanImageCreateInfo, &img_format, &image_desc,
|
||||
vulkanImageTiling == VULKAN_IMAGE_TILING_LINEAR ? &layout
|
||||
: nullptr);
|
||||
test_error_fail(errNum, "getCLImageInfoFromVkImageInfo failed!!!");
|
||||
|
||||
clMemWrapper image;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user