From d64ace66e828365ef6110c6da4b7361461c52c25 Mon Sep 17 00:00:00 2001 From: Jeremy Kniager Date: Mon, 29 Apr 2019 14:30:06 -0600 Subject: [PATCH] vulkaninfo: Add VK_EXT_ycbcr_image_arrays Added output for the following structures from extension VK_EXT_ycbcr_image_arrays: VkPhysicalDeviceYcbcrImageArraysFeaturesEXT Change-Id: I0f10ae006e99fff5192729ac32bafae2d9170d0c --- vulkaninfo/vulkaninfo.c | 27 ++++++++++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/vulkaninfo/vulkaninfo.c b/vulkaninfo/vulkaninfo.c index 407be34..13e8137 100644 --- a/vulkaninfo/vulkaninfo.c +++ b/vulkaninfo/vulkaninfo.c @@ -1094,7 +1094,9 @@ static void AppGpuInit(struct AppGpu *gpu, struct AppInstance *inst, uint32_t id {.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PRIORITY_FEATURES_EXT, .mem_size = sizeof(VkPhysicalDeviceMemoryPriorityFeaturesEXT)}, {.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BUFFER_ADDRESS_FEATURES_EXT, - .mem_size = sizeof(VkPhysicalDeviceBufferAddressFeaturesEXT)}}; + .mem_size = sizeof(VkPhysicalDeviceBufferAddressFeaturesEXT)}, + {.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_YCBCR_IMAGE_ARRAYS_FEATURES_EXT, + .mem_size = sizeof(VkPhysicalDeviceYcbcrImageArraysFeaturesEXT)}}; uint32_t chain_info_len = ARRAY_SIZE(chain_info); @@ -3160,6 +3162,7 @@ static void AppGpuDumpFeatures(const struct AppGpu *gpu, FILE *out) { "\t\t\t\t\t\t
memoryPriority = %" PRIuLEAST32 "
\n", memory_priority_features->memoryPriority); + fprintf(out, "\t\t\t\t\t\n"); } else if (human_readable_output) { printf("\nVkPhysicalDeviceMemoryPriorityFeatures:\n"); printf("======================================\n"); @@ -3184,14 +3187,32 @@ static void AppGpuDumpFeatures(const struct AppGpu *gpu, FILE *out) { "\t\t\t\t\t\t
bufferDeviceAddressMultiDevice = %" PRIuLEAST32 "
\n", buffer_address_features->bufferDeviceAddressMultiDevice); + fprintf(out, "\t\t\t\t\t\n"); } else if (human_readable_output) { printf("\nVkPhysicalDeviceBufferAddressFeatures:\n"); printf("======================================\n"); printf("\tbufferDeviceAddress = %" PRIuLEAST32 "\n", buffer_address_features->bufferDeviceAddress); printf("\tbufferDeviceAddressCaptureReplay = %" PRIuLEAST32 "\n", - buffer_address_features->bufferDeviceAddressCaptureReplay); + buffer_address_features->bufferDeviceAddressCaptureReplay); printf("\tbufferDeviceAddressMultiDevice = %" PRIuLEAST32 "\n", - buffer_address_features->bufferDeviceAddressMultiDevice); + buffer_address_features->bufferDeviceAddressMultiDevice); + } + } else if (structure->sType == VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_YCBCR_IMAGE_ARRAYS_FEATURES_EXT && + CheckPhysicalDeviceExtensionIncluded(VK_EXT_YCBCR_IMAGE_ARRAYS_EXTENSION_NAME, gpu->device_extensions, + gpu->device_extension_count)) { + VkPhysicalDeviceYcbcrImageArraysFeaturesEXT *ycbcr_image_arrays_features = + (VkPhysicalDeviceYcbcrImageArraysFeaturesEXT *)structure; + if (html_output) { + fprintf(out, "\n\t\t\t\t\t
VkPhysicalDeviceYcbcrImageArraysFeatures\n"); + fprintf(out, + "\t\t\t\t\t\t
ycbcrImageArrays = %" PRIuLEAST32 + "
\n", + ycbcr_image_arrays_features->ycbcrImageArrays); + fprintf(out, "\t\t\t\t\t
\n"); + } else if (human_readable_output) { + printf("\nVkPhysicalDeviceYcbcrImageArraysFeatures:\n"); + printf("=========================================\n"); + printf("\tycbcrImageArrays = %" PRIuLEAST32 "\n", ycbcr_image_arrays_features->ycbcrImageArrays); } } place = structure->pNext; -- 2.7.4