Use debug utils during instance creation (#1098)
* Use debug utils during instance creation * fixup! Use debug utils during instance creation
This commit is contained in:
parent
213bf850d5
commit
e37a333b0d
3 changed files with 35 additions and 25 deletions
|
|
@ -17,7 +17,7 @@ namespace vks
|
||||||
PFN_vkDestroyDebugUtilsMessengerEXT vkDestroyDebugUtilsMessengerEXT;
|
PFN_vkDestroyDebugUtilsMessengerEXT vkDestroyDebugUtilsMessengerEXT;
|
||||||
VkDebugUtilsMessengerEXT debugUtilsMessenger;
|
VkDebugUtilsMessengerEXT debugUtilsMessenger;
|
||||||
|
|
||||||
VKAPI_ATTR VkBool32 VKAPI_CALL debugUtilsMessengerCallback(
|
VKAPI_ATTR VkBool32 VKAPI_CALL debugUtilsMessageCallback(
|
||||||
VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
|
VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
|
||||||
VkDebugUtilsMessageTypeFlagsEXT messageType,
|
VkDebugUtilsMessageTypeFlagsEXT messageType,
|
||||||
const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData,
|
const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData,
|
||||||
|
|
@ -78,17 +78,21 @@ namespace vks
|
||||||
return VK_FALSE;
|
return VK_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void setupDebugingMessengerCreateInfo(VkDebugUtilsMessengerCreateInfoEXT& debugUtilsMessengerCI)
|
||||||
|
{
|
||||||
|
debugUtilsMessengerCI.sType = VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT;
|
||||||
|
debugUtilsMessengerCI.messageSeverity = VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT;
|
||||||
|
debugUtilsMessengerCI.messageType = VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT;
|
||||||
|
debugUtilsMessengerCI.pfnUserCallback = debugUtilsMessageCallback;
|
||||||
|
}
|
||||||
|
|
||||||
void setupDebugging(VkInstance instance)
|
void setupDebugging(VkInstance instance)
|
||||||
{
|
{
|
||||||
|
|
||||||
vkCreateDebugUtilsMessengerEXT = reinterpret_cast<PFN_vkCreateDebugUtilsMessengerEXT>(vkGetInstanceProcAddr(instance, "vkCreateDebugUtilsMessengerEXT"));
|
vkCreateDebugUtilsMessengerEXT = reinterpret_cast<PFN_vkCreateDebugUtilsMessengerEXT>(vkGetInstanceProcAddr(instance, "vkCreateDebugUtilsMessengerEXT"));
|
||||||
vkDestroyDebugUtilsMessengerEXT = reinterpret_cast<PFN_vkDestroyDebugUtilsMessengerEXT>(vkGetInstanceProcAddr(instance, "vkDestroyDebugUtilsMessengerEXT"));
|
vkDestroyDebugUtilsMessengerEXT = reinterpret_cast<PFN_vkDestroyDebugUtilsMessengerEXT>(vkGetInstanceProcAddr(instance, "vkDestroyDebugUtilsMessengerEXT"));
|
||||||
|
|
||||||
VkDebugUtilsMessengerCreateInfoEXT debugUtilsMessengerCI{};
|
VkDebugUtilsMessengerCreateInfoEXT debugUtilsMessengerCI{};
|
||||||
debugUtilsMessengerCI.sType = VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT;
|
setupDebugingMessengerCreateInfo(debugUtilsMessengerCI);
|
||||||
debugUtilsMessengerCI.messageSeverity = VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT;
|
|
||||||
debugUtilsMessengerCI.messageType = VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT;
|
|
||||||
debugUtilsMessengerCI.pfnUserCallback = debugUtilsMessengerCallback;
|
|
||||||
VkResult result = vkCreateDebugUtilsMessengerEXT(instance, &debugUtilsMessengerCI, nullptr, &debugUtilsMessenger);
|
VkResult result = vkCreateDebugUtilsMessengerEXT(instance, &debugUtilsMessengerCI, nullptr, &debugUtilsMessenger);
|
||||||
assert(result == VK_SUCCESS);
|
assert(result == VK_SUCCESS);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -35,20 +35,18 @@ namespace vks
|
||||||
namespace debug
|
namespace debug
|
||||||
{
|
{
|
||||||
// Default debug callback
|
// Default debug callback
|
||||||
VKAPI_ATTR VkBool32 VKAPI_CALL messageCallback(
|
VKAPI_ATTR VkBool32 VKAPI_CALL debugUtilsMessageCallback(
|
||||||
VkDebugReportFlagsEXT flags,
|
VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
|
||||||
VkDebugReportObjectTypeEXT objType,
|
VkDebugUtilsMessageTypeFlagsEXT messageType,
|
||||||
uint64_t srcObject,
|
const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData,
|
||||||
size_t location,
|
|
||||||
int32_t msgCode,
|
|
||||||
const char* pLayerPrefix,
|
|
||||||
const char* pMsg,
|
|
||||||
void* pUserData);
|
void* pUserData);
|
||||||
|
|
||||||
// Load debug function pointers and set debug callback
|
// Load debug function pointers and set debug callback
|
||||||
void setupDebugging(VkInstance instance);
|
void setupDebugging(VkInstance instance);
|
||||||
// Clear debug callback
|
// Clear debug callback
|
||||||
void freeDebugCallback(VkInstance instance);
|
void freeDebugCallback(VkInstance instance);
|
||||||
|
// Used to populate a VkDebugUtilsMessengerCreateInfoEXT with our example messenger function and desired flags
|
||||||
|
void setupDebugingMessengerCreateInfo(VkDebugUtilsMessengerCreateInfoEXT& debugUtilsMessengerCI);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wrapper for the VK_EXT_debug_utils extension
|
// Wrapper for the VK_EXT_debug_utils extension
|
||||||
|
|
|
||||||
|
|
@ -98,6 +98,14 @@ VkResult VulkanExampleBase::createInstance(bool enableValidation)
|
||||||
instanceCreateInfo.pNext = NULL;
|
instanceCreateInfo.pNext = NULL;
|
||||||
instanceCreateInfo.pApplicationInfo = &appInfo;
|
instanceCreateInfo.pApplicationInfo = &appInfo;
|
||||||
|
|
||||||
|
VkDebugUtilsMessengerCreateInfoEXT debugUtilsMessengerCI{};
|
||||||
|
if (settings.validation) {
|
||||||
|
vks::debug::setupDebugingMessengerCreateInfo(debugUtilsMessengerCI);
|
||||||
|
debugUtilsMessengerCI.pNext = instanceCreateInfo.pNext;
|
||||||
|
instanceCreateInfo.pNext = &debugUtilsMessengerCI;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#if (defined(VK_USE_PLATFORM_IOS_MVK) || defined(VK_USE_PLATFORM_MACOS_MVK)) && defined(VK_KHR_portability_enumeration)
|
#if (defined(VK_USE_PLATFORM_IOS_MVK) || defined(VK_USE_PLATFORM_MACOS_MVK)) && defined(VK_KHR_portability_enumeration)
|
||||||
// SRS - When running on iOS/macOS with MoltenVK and VK_KHR_portability_enumeration is defined and supported by the instance, enable the extension and the flag
|
// SRS - When running on iOS/macOS with MoltenVK and VK_KHR_portability_enumeration is defined and supported by the instance, enable the extension and the flag
|
||||||
if (std::find(supportedInstanceExtensions.begin(), supportedInstanceExtensions.end(), VK_KHR_PORTABILITY_ENUMERATION_EXTENSION_NAME) != supportedInstanceExtensions.end())
|
if (std::find(supportedInstanceExtensions.begin(), supportedInstanceExtensions.end(), VK_KHR_PORTABILITY_ENUMERATION_EXTENSION_NAME) != supportedInstanceExtensions.end())
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue