aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Lobodzinski <mark@lunarg.com>2017-05-31 09:14:22 -0600
committerMark Lobodzinski <mark@lunarg.com>2017-05-31 14:30:45 -0600
commit347793f2978044e9db41faaebce3adda1166460a (patch)
treedb5299372867d2c697ccb80c2bd77d888b4693ae
parent28336d5b59e53c19a55fb03dac8087916bc3e2b9 (diff)
downloadusermoji-347793f2978044e9db41faaebce3adda1166460a.tar.xz
Layers: Implement PV per-API ext dependency checks
As each API is used, PV will now us a code-generated check to verify that all of the required extensions for this particular API call have been enabled via CreateInstance or CreateDevice. Change-Id: I1c11d0b8322edf005b2b197a415c92a82e0cb810
-rw-r--r--layers/parameter_validation.cpp22
-rw-r--r--layers/parameter_validation_utils.h4
-rw-r--r--scripts/parameter_validation_generator.py2
3 files changed, 20 insertions, 8 deletions
diff --git a/layers/parameter_validation.cpp b/layers/parameter_validation.cpp
index 949d510d..b4d23b81 100644
--- a/layers/parameter_validation.cpp
+++ b/layers/parameter_validation.cpp
@@ -117,13 +117,20 @@ static const VkLayerProperties global_layer = {
"VK_LAYER_LUNARG_parameter_validation", VK_LAYER_API_VERSION, 1, "LunarG Validation Layer",
};
-bool ValidateRequiredExtensions(std::string api_name, const std::vector<std::string> required_extensions) {
+template <typename T>
+bool ValidateRequiredExtensions(const T *layer_data, const std::string &api_name, const std::vector<std::string> &required_extensions) {
bool skip = false;
+ std::stringstream error_results;
+ auto const &enabled_extensions = layer_data->enabled_extensions;
- for (auto reqd_ext = required_extensions.begin(); reqd_ext != required_extensions.end(); reqd_ext++) {
- // Insert depency checks here
+ for (const auto &reqd_ext : required_extensions) {
+ if (enabled_extensions.find(reqd_ext) == enabled_extensions.end()) {
+ skip = log_msg(layer_data->report_data, VK_DEBUG_REPORT_ERROR_BIT_EXT, VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT, 0,
+ __LINE__, EXTENSION_NOT_ENABLED, LayerName,
+ "Attemped to call %s() but its required extension %s has not been enabled\n", api_name.c_str(),
+ reqd_ext.c_str());
+ }
}
-
return skip;
}
@@ -595,9 +602,12 @@ VKAPI_ATTR VkResult VKAPI_CALL CreateDevice(VkPhysicalDevice physicalDevice, con
my_device_data->report_data = layer_debug_report_create_device(my_instance_data->report_data, *pDevice);
layer_init_device_dispatch_table(*pDevice, &my_device_data->dispatch_table, fpGetDeviceProcAddr);
- // Save enabled instance extension names for validation extension APIs
+ // Save enabled device AND instance extension names for validation extension APIs
for (uint32_t i = 0; i < pCreateInfo->enabledExtensionCount; i++) {
- my_instance_data->enabled_extensions.emplace(pCreateInfo->ppEnabledExtensionNames[i]);
+ my_device_data->enabled_extensions.emplace(pCreateInfo->ppEnabledExtensionNames[i]);
+ }
+ for (const auto &inst_ext : my_instance_data->enabled_extensions) {
+ my_device_data->enabled_extensions.emplace(inst_ext);
}
my_device_data->enables.InitFromDeviceCreateInfo(pCreateInfo);
diff --git a/layers/parameter_validation_utils.h b/layers/parameter_validation_utils.h
index a0f268ba..0d6ec260 100644
--- a/layers/parameter_validation_utils.h
+++ b/layers/parameter_validation_utils.h
@@ -119,7 +119,9 @@ const uint32_t ExtEnumBaseValue = 1000000000;
const uint32_t MaxEnumValue = 0x7FFFFFFF;
// Forward declaration
-bool ValidateRequiredExtensions(std::string api_name, const std::vector<std::string> required_extensions);
+template <typename T>
+bool ValidateRequiredExtensions(const T *layer_data, const std::string &api_name,
+ const std::vector<std::string> &required_extensions);
template <typename T>
bool is_extension_added_token(T value) {
diff --git a/scripts/parameter_validation_generator.py b/scripts/parameter_validation_generator.py
index 52cedd06..0e276bfe 100644
--- a/scripts/parameter_validation_generator.py
+++ b/scripts/parameter_validation_generator.py
@@ -1029,7 +1029,7 @@ class ParamCheckerOutputGenerator(OutputGenerator):
for ext in self.required_extensions:
def_line += '"%s", ' % ext
def_line = def_line[:-2] + '};'
- ext_call = 'skipCall |= ValidateRequiredExtensions("%s", required_extensions);\n' % command.name
+ ext_call = 'skipCall |= ValidateRequiredExtensions(layer_data, "%s", required_extensions);\n' % command.name
lines.insert(0, ext_call)
lines.insert(0, def_line)
if lines: