1// Copyright 2018-2023 The Khronos Group Inc. 2// 3// SPDX-License-Identifier: CC-BY-4.0 4 5include::{generated}/meta/{refprefix}VK_EXT_tooling_info.adoc[] 6 7=== Other Extension Metadata 8 9*Last Modified Date*:: 10 2018-11-05 11*Interactions and External Dependencies*:: 12 - Promoted to Vulkan 1.3 Core 13*Contributors*:: 14 - Rolando Caloca 15 - Matthaeus Chajdas 16 - Baldur Karlsson 17 - Daniel Rakos 18 19=== Description 20 21When an error occurs during application development, a common question is 22"What tools are actually running right now?" This extension adds the ability 23to query that information directly from the Vulkan implementation. 24 25Outdated versions of one tool might not play nicely with another, or perhaps 26a tool is not actually running when it should have been. 27Trying to figure that out can cause headaches as it is necessary to consult 28each known tool to figure out what is going on -- in some cases the tool 29might not even be known. 30 31Typically, the expectation is that developers will simply print out this 32information for visual inspection when an issue occurs, however a small 33amount of semantic information about what the tool is doing is provided to 34help identify it programmatically. 35For example, if the advertised limits or features of an implementation are 36unexpected, is there a tool active which modifies these limits? Or if an 37application is providing debug markers, but the implementation is not 38actually doing anything with that information, this can quickly point that 39out. 40 41include::{generated}/interfaces/VK_EXT_tooling_info.adoc[] 42 43=== Promotion to Vulkan 1.3 44 45Functionality in this extension is included in core Vulkan 1.3, with the EXT 46suffix omitted. 47The original type, enum and command names are still available as aliases of 48the core functionality. 49 50=== Examples 51 52.Printing Tool Information 53 54``` 55uint32_t num_tools; 56VkPhysicalDeviceToolPropertiesEXT *pToolProperties; 57vkGetPhysicalDeviceToolPropertiesEXT(physicalDevice, &num_tools, NULL); 58 59pToolProperties = (VkPhysicalDeviceToolPropertiesEXT*)malloc(sizeof(VkPhysicalDeviceToolPropertiesEXT) * num_tools); 60 61vkGetPhysicalDeviceToolPropertiesEXT(physicalDevice, &num_tools, pToolProperties); 62 63for (int i = 0; i < num_tools; ++i) { 64 printf("%s:\n", pToolProperties[i].name); 65 printf("Version:\n"); 66 printf("%s:\n", pToolProperties[i].version); 67 printf("Description:\n"); 68 printf("\t%s\n", pToolProperties[i].description); 69 printf("Purposes:\n"); 70 printf("\t%s\n", VkToolPurposeFlagBitsEXT_to_string(pToolProperties[i].purposes)); 71 if (strnlen_s(pToolProperties[i].layer,VK_MAX_EXTENSION_NAME_SIZE) > 0) { 72 printf("Corresponding Layer:\n"); 73 printf("\t%s\n", pToolProperties[i].layer); 74 } 75} 76``` 77 78=== Issues 79 801) Why is this information separate from the layer mechanism? 81 82Some tooling may be built into a driver, or be part of the Vulkan loader 83etc. 84Tying this information directly to layers would have been awkward at best. 85 86=== Version History 87 88 * Revision 1, 2018-11-05 (Tobias Hector) 89 ** Initial draft 90