Skip to content

Commit

Permalink
Validation Layer Fixes (#774)
Browse files Browse the repository at this point in the history
* Validation Layer Fixes

* review fixes

* remove USE_VALIDATION_LAYERS
  • Loading branch information
tomadamatkinson authored Aug 28, 2023
1 parent 68a1f53 commit 9a13455
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 16 deletions.
24 changes: 16 additions & 8 deletions framework/core/hpp_instance.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,19 @@
#include <core/hpp_physical_device.h>
#include <volk.h>

#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
# define USE_VALIDATION_LAYERS
#endif

#if defined(USE_VALIDATION_LAYERS) && (defined(VKB_VALIDATION_LAYERS_GPU_ASSISTED) || defined(VKB_VALIDATION_LAYERS_BEST_PRACTICES) || defined(VKB_VALIDATION_LAYERS_SYNCHRONIZATION))
# define USE_VALIDATION_LAYER_FEATURES
#endif

namespace vkb
{
namespace
{
#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
VKAPI_ATTR VkBool32 VKAPI_CALL debug_utils_messenger_callback(VkDebugUtilsMessageSeverityFlagBitsEXT message_severity, VkDebugUtilsMessageTypeFlagsEXT message_type,
const VkDebugUtilsMessengerCallbackDataEXT *callback_data,
void *user_data)
Expand Down Expand Up @@ -181,7 +189,7 @@ HPPInstance::HPPInstance(const std::string &applicati
{
std::vector<vk::ExtensionProperties> available_instance_extensions = vk::enumerateInstanceExtensionProperties();

#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
// Check if VK_EXT_debug_utils is supported, which supersedes VK_EXT_Debug_Report
const bool has_debug_utils = enable_extension(VK_EXT_DEBUG_UTILS_EXTENSION_NAME,
available_instance_extensions, enabled_extensions);
Expand All @@ -204,7 +212,7 @@ HPPInstance::HPPInstance(const std::string &applicati
enable_extension(VK_KHR_PORTABILITY_ENUMERATION_EXTENSION_NAME, available_instance_extensions, enabled_extensions);
#endif

#if (defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)) && (defined(VKB_VALIDATION_LAYERS_GPU_ASSISTED) || defined(VKB_VALIDATION_LAYERS_BEST_PRACTICES))
#ifdef USE_VALIDATION_LAYER_FEATURES
bool validation_features = false;
{
std::vector<vk::ExtensionProperties> available_layer_instance_extensions = vk::enumerateInstanceExtensionProperties(std::string("VK_LAYER_KHRONOS_validation"));
Expand Down Expand Up @@ -270,7 +278,7 @@ HPPInstance::HPPInstance(const std::string &applicati

std::vector<const char *> requested_validation_layers(required_validation_layers);

#ifdef VKB_VALIDATION_LAYERS
#ifdef USE_VALIDATION_LAYERS
// Determine the optimal validation layers to enable that are necessary for useful debugging
std::vector<const char *> optimal_validation_layers = get_optimal_validation_layers(supported_validation_layers);
requested_validation_layers.insert(requested_validation_layers.end(), optimal_validation_layers.begin(), optimal_validation_layers.end());
Expand All @@ -293,7 +301,7 @@ HPPInstance::HPPInstance(const std::string &applicati

vk::InstanceCreateInfo instance_info({}, &app_info, requested_validation_layers, enabled_extensions);

#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
vk::DebugUtilsMessengerCreateInfoEXT debug_utils_create_info;
vk::DebugReportCallbackCreateInfoEXT debug_report_create_info;
if (has_debug_utils)
Expand All @@ -319,7 +327,7 @@ HPPInstance::HPPInstance(const std::string &applicati
instance_info.flags |= vk::InstanceCreateFlagBits::eEnumeratePortabilityKHR;
#endif

#if (defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)) && (defined(VKB_VALIDATION_LAYERS_GPU_ASSISTED) || defined(VKB_VALIDATION_LAYERS_BEST_PRACTICES))
#ifdef USE_VALIDATION_LAYER_FEATURES
vk::ValidationFeaturesEXT validation_features_info;
std::vector<vk::ValidationFeatureEnableEXT> enable_features{};
if (validation_features)
Expand All @@ -346,7 +354,7 @@ HPPInstance::HPPInstance(const std::string &applicati
// Need to load volk for all the not-yet Vulkan-Hpp calls
volkLoadInstance(handle);

#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
if (has_debug_utils)
{
debug_utils_messenger = handle.createDebugUtilsMessengerEXT(debug_utils_create_info);
Expand Down Expand Up @@ -375,7 +383,7 @@ HPPInstance::HPPInstance(vk::Instance instance) :

HPPInstance::~HPPInstance()
{
#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
if (debug_utils_messenger)
{
handle.destroyDebugUtilsMessengerEXT(debug_utils_messenger);
Expand Down
25 changes: 17 additions & 8 deletions framework/core/instance.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,11 +22,19 @@
#include <algorithm>
#include <functional>

#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
# define USE_VALIDATION_LAYERS
#endif

#if defined(USE_VALIDATION_LAYERS) && (defined(VKB_VALIDATION_LAYERS_GPU_ASSISTED) || defined(VKB_VALIDATION_LAYERS_BEST_PRACTICES) || defined(VKB_VALIDATION_LAYERS_SYNCHRONIZATION))
# define USE_VALIDATION_LAYER_FEATURES
#endif

namespace vkb
{
namespace
{
#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS

VKAPI_ATTR VkBool32 VKAPI_CALL debug_utils_messenger_callback(VkDebugUtilsMessageSeverityFlagBitsEXT message_severity, VkDebugUtilsMessageTypeFlagsEXT message_type,
const VkDebugUtilsMessengerCallbackDataEXT *callback_data,
Expand Down Expand Up @@ -185,7 +193,7 @@ Instance::Instance(const std::string &application_nam
std::vector<VkExtensionProperties> available_instance_extensions(instance_extension_count);
VK_CHECK(vkEnumerateInstanceExtensionProperties(nullptr, &instance_extension_count, available_instance_extensions.data()));

#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
// Check if VK_EXT_debug_utils is supported, which supersedes VK_EXT_Debug_Report
const bool has_debug_utils = enable_extension(VK_EXT_DEBUG_UTILS_EXTENSION_NAME,
available_instance_extensions, enabled_extensions);
Expand All @@ -208,7 +216,7 @@ Instance::Instance(const std::string &application_nam
enable_extension(VK_KHR_PORTABILITY_ENUMERATION_EXTENSION_NAME, available_instance_extensions, enabled_extensions);
#endif

#if (defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS))
#ifdef USE_VALIDATION_LAYER_FEATURES
bool validation_features = false;
{
uint32_t layer_instance_extension_count;
Expand Down Expand Up @@ -282,7 +290,7 @@ Instance::Instance(const std::string &application_nam

std::vector<const char *> requested_validation_layers(required_validation_layers);

#ifdef VKB_VALIDATION_LAYERS
#ifdef USE_VALIDATION_LAYERS
// Determine the optimal validation layers to enable that are necessary for useful debugging
std::vector<const char *> optimal_validation_layers = get_optimal_validation_layers(supported_validation_layers);
requested_validation_layers.insert(requested_validation_layers.end(), optimal_validation_layers.begin(), optimal_validation_layers.end());
Expand Down Expand Up @@ -319,7 +327,7 @@ Instance::Instance(const std::string &application_nam
instance_info.enabledLayerCount = to_u32(requested_validation_layers.size());
instance_info.ppEnabledLayerNames = requested_validation_layers.data();

#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
VkDebugUtilsMessengerCreateInfoEXT debug_utils_create_info = {VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT};
VkDebugReportCallbackCreateInfoEXT debug_report_create_info = {VK_STRUCTURE_TYPE_DEBUG_REPORT_CREATE_INFO_EXT};
if (has_debug_utils)
Expand All @@ -338,12 +346,13 @@ Instance::Instance(const std::string &application_nam
instance_info.pNext = &debug_report_create_info;
}
#endif

#if (defined(VKB_ENABLE_PORTABILITY))
instance_info.flags |= VK_INSTANCE_CREATE_ENUMERATE_PORTABILITY_BIT_KHR;
#endif

// Some of the specialized layers need to be enabled explicitly
#if (defined(VKB_VALIDATION_LAYERS_GPU_ASSISTED) || defined(VKB_VALIDATION_LAYERS_BEST_PRACTICES) || defined(VKB_VALIDATION_LAYERS_SYNCHRONIZATION))
#ifdef USE_VALIDATION_LAYER_FEATURES
VkValidationFeaturesEXT validation_features_info = {VK_STRUCTURE_TYPE_VALIDATION_FEATURES_EXT};
std::vector<VkValidationFeatureEnableEXT> enable_features{};
if (validation_features)
Expand Down Expand Up @@ -375,7 +384,7 @@ Instance::Instance(const std::string &application_nam

volkLoadInstance(handle);

#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
if (has_debug_utils)
{
result = vkCreateDebugUtilsMessengerEXT(handle, &debug_utils_create_info, nullptr, &debug_utils_messenger);
Expand Down Expand Up @@ -412,7 +421,7 @@ Instance::Instance(VkInstance instance) :

Instance::~Instance()
{
#if defined(VKB_DEBUG) || defined(VKB_VALIDATION_LAYERS)
#ifdef USE_VALIDATION_LAYERS
if (debug_utils_messenger != VK_NULL_HANDLE)
{
vkDestroyDebugUtilsMessengerEXT(handle, debug_utils_messenger, nullptr);
Expand Down

0 comments on commit 9a13455

Please sign in to comment.