aboutsummaryrefslogtreecommitdiff
path: root/layers/core_validation.cpp
diff options
context:
space:
mode:
authorMark Lobodzinski <mark@lunarg.com>2017-03-23 14:30:25 -0600
committerMark Lobodzinski <mark@lunarg.com>2017-03-29 10:58:32 -0600
commited38fe2ab23cc761d78da1a7b3ece92ae87351a9 (patch)
tree6351dca7680e9ba4449b56fa8f23baa7c0da14b7 /layers/core_validation.cpp
parent91ff4bcb967ef7ba2916eaa086c82e67d7cc9b1f (diff)
downloadusermoji-ed38fe2ab23cc761d78da1a7b3ece92ae87351a9.tar.xz
layers: Support CapabilitySampleMaskOverrideCoverage
Recognize and validate shader capability added in the new VK_NV_sample_mask_override_coverage extension. Change-Id: I30131189beee8cb5f087846eff3a5f7571d0d309
Diffstat (limited to 'layers/core_validation.cpp')
-rw-r--r--layers/core_validation.cpp9
1 files changed, 9 insertions, 0 deletions
diff --git a/layers/core_validation.cpp b/layers/core_validation.cpp
index 4664c344..5d481a9d 100644
--- a/layers/core_validation.cpp
+++ b/layers/core_validation.cpp
@@ -2536,6 +2536,11 @@ static bool validate_shader_capabilities(layer_data *dev_data, shader_module con
VK_NV_GEOMETRY_SHADER_PASSTHROUGH_EXTENSION_NAME);
break;
+ case spv::CapabilitySampleMaskOverrideCoverageNV:
+ pass &= require_extension(report_data, dev_data->device_extensions.nv_sample_mask_override_coverage_enabled,
+ VK_NV_SAMPLE_MASK_OVERRIDE_COVERAGE_EXTENSION_NAME);
+ break;
+
default:
// Spirv-validator should catch these errors
break;
@@ -3848,6 +3853,7 @@ static void checkDeviceRegisterExtensions(const VkDeviceCreateInfo *pCreateInfo,
dev_data->device_extensions.khr_shader_draw_parameters_enabled = false;
dev_data->device_extensions.khr_maintenance1_enabled = false;
dev_data->device_extensions.nv_geometry_shader_passthrough_enabled = false;
+ dev_data->device_extensions.nv_sample_mask_override_coverage_enabled = false;
for (i = 0; i < pCreateInfo->enabledExtensionCount; i++) {
if (strcmp(pCreateInfo->ppEnabledExtensionNames[i], VK_KHR_SWAPCHAIN_EXTENSION_NAME) == 0) {
@@ -3871,6 +3877,9 @@ static void checkDeviceRegisterExtensions(const VkDeviceCreateInfo *pCreateInfo,
if (strcmp(pCreateInfo->ppEnabledExtensionNames[i], VK_NV_GEOMETRY_SHADER_PASSTHROUGH_EXTENSION_NAME) == 0) {
dev_data->device_extensions.nv_geometry_shader_passthrough_enabled = true;
}
+ if (strcmp(pCreateInfo->ppEnabledExtensionNames[i], VK_NV_SAMPLE_MASK_OVERRIDE_COVERAGE_EXTENSION_NAME) == 0) {
+ dev_data->device_extensions.nv_sample_mask_override_coverage_enabled = true;
+ }
}
}