Renderer: Allow to enable or disable API validation layers using config
This commit is contained in:
@@ -116,7 +116,7 @@ namespace Nz
|
||||
return dummy;
|
||||
}
|
||||
|
||||
bool Vulkan::Initialize(UInt32 targetApiVersion, const ParameterList& parameters)
|
||||
bool Vulkan::Initialize(UInt32 targetApiVersion, RenderAPIValidationLevel validationLevel, const ParameterList& parameters)
|
||||
{
|
||||
NazaraAssert(!IsInitialized(), "Vulkan is already initialized");
|
||||
|
||||
@@ -186,13 +186,14 @@ namespace Nz
|
||||
{
|
||||
//< Nazara default layers goes here
|
||||
|
||||
#ifdef NAZARA_DEBUG
|
||||
// Enable Vulkan validation if available in debug mode
|
||||
if (availableLayerByName.count("VK_LAYER_KHRONOS_validation"))
|
||||
enabledLayers.push_back("VK_LAYER_KHRONOS_validation");
|
||||
else if (availableLayerByName.count("VK_LAYER_LUNARG_standard_validation"))
|
||||
enabledLayers.push_back("VK_LAYER_LUNARG_standard_validation");
|
||||
#endif
|
||||
if (validationLevel != RenderAPIValidationLevel::None)
|
||||
{
|
||||
// Enable Vulkan validation if available in debug mode
|
||||
if (availableLayerByName.count("VK_LAYER_KHRONOS_validation"))
|
||||
enabledLayers.push_back("VK_LAYER_KHRONOS_validation");
|
||||
else if (availableLayerByName.count("VK_LAYER_LUNARG_standard_validation"))
|
||||
enabledLayers.push_back("VK_LAYER_LUNARG_standard_validation");
|
||||
}
|
||||
}
|
||||
|
||||
std::vector<const char*> enabledExtensions;
|
||||
@@ -324,7 +325,7 @@ namespace Nz
|
||||
instanceInfo.enabledLayerCount = UInt32(enabledLayers.size());
|
||||
instanceInfo.ppEnabledLayerNames = enabledLayers.data();
|
||||
|
||||
if (!s_instance.Create(instanceInfo))
|
||||
if (!s_instance.Create(validationLevel, instanceInfo))
|
||||
{
|
||||
NazaraError("Failed to create instance: " + TranslateVulkanError(s_instance.GetLastErrorCode()));
|
||||
return false;
|
||||
|
||||
@@ -38,9 +38,9 @@ namespace Nz
|
||||
return Vulkan::CreateDevice(physDevices[deviceIndex], enabledFeatures);
|
||||
}
|
||||
|
||||
bool VulkanRenderer::Prepare(const ParameterList& parameters)
|
||||
bool VulkanRenderer::Prepare(const Renderer::Config& config)
|
||||
{
|
||||
if (!Vulkan::Initialize(APIVersion, parameters))
|
||||
if (!Vulkan::Initialize(APIVersion, config.validationLevel, config.customParameters))
|
||||
return false;
|
||||
|
||||
const auto& physDevices = Vulkan::GetPhysicalDevices();
|
||||
|
||||
@@ -148,7 +148,7 @@ namespace Nz
|
||||
{
|
||||
switch (type)
|
||||
{
|
||||
case QueueType::Compute: return VK_QUEUE_COMPUTE_BIT;
|
||||
case QueueType::Compute: return VK_QUEUE_COMPUTE_BIT;
|
||||
case QueueType::Graphics: return VK_QUEUE_GRAPHICS_BIT;
|
||||
case QueueType::Transfer: return VK_QUEUE_COMPUTE_BIT | VK_QUEUE_GRAPHICS_BIT | VK_QUEUE_TRANSFER_BIT; //< Compute/graphics imply transfer
|
||||
}
|
||||
|
||||
@@ -21,8 +21,22 @@ namespace Nz
|
||||
VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
|
||||
VkDebugUtilsMessageTypeFlagsEXT messageTypes,
|
||||
const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData,
|
||||
void* /*pUserData*/)
|
||||
void* pUserData)
|
||||
{
|
||||
Instance& instance = *static_cast<Instance*>(pUserData);
|
||||
if (messageTypes & VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT)
|
||||
{
|
||||
RenderAPIValidationLevel validationLevel = instance.GetValidationLevel();
|
||||
if ((messageSeverity & VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT) && validationLevel < RenderAPIValidationLevel::Debug)
|
||||
return VK_FALSE;
|
||||
|
||||
if ((messageSeverity & VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT) && validationLevel < RenderAPIValidationLevel::Verbose)
|
||||
return VK_FALSE;
|
||||
|
||||
if ((messageSeverity & VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT) && validationLevel < RenderAPIValidationLevel::Warnings)
|
||||
return VK_FALSE;
|
||||
}
|
||||
|
||||
std::stringstream ss;
|
||||
ss << "Vulkan log: ";
|
||||
|
||||
@@ -48,7 +62,6 @@ namespace Nz
|
||||
if (messageTypes & VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT)
|
||||
ss << "[Validation]";
|
||||
|
||||
|
||||
ss << "[" << pCallbackData->messageIdNumber;
|
||||
if (pCallbackData->pMessageIdName)
|
||||
ss << ":" << pCallbackData->pMessageIdName;
|
||||
@@ -82,7 +95,7 @@ namespace Nz
|
||||
DestroyInstance();
|
||||
}
|
||||
|
||||
bool Instance::Create(const VkInstanceCreateInfo& createInfo, const VkAllocationCallbacks* allocator)
|
||||
bool Instance::Create(RenderAPIValidationLevel validationLevel, const VkInstanceCreateInfo& createInfo, const VkAllocationCallbacks* allocator)
|
||||
{
|
||||
m_lastErrorCode = Loader::vkCreateInstance(&createInfo, allocator, &m_instance);
|
||||
if (m_lastErrorCode != VkResult::VK_SUCCESS)
|
||||
@@ -92,6 +105,7 @@ namespace Nz
|
||||
}
|
||||
|
||||
m_apiVersion = createInfo.pApplicationInfo->apiVersion;
|
||||
m_validationLevel = validationLevel;
|
||||
|
||||
// Store the allocator to access them when needed
|
||||
if (allocator)
|
||||
@@ -223,6 +237,7 @@ namespace Nz
|
||||
callbackCreateInfo.messageSeverity = VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT;
|
||||
callbackCreateInfo.messageType = VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_PERFORMANCE_BIT_EXT;
|
||||
callbackCreateInfo.pfnUserCallback = &DebugCallback;
|
||||
callbackCreateInfo.pUserData = this;
|
||||
|
||||
if (!m_internalData->debugMessenger.Create(*this, callbackCreateInfo))
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user