[Mesa-dev] [PATCH 1/2] Split dispatch sanity's validate_function test into two
Matt Turner
mattst88 at gmail.com
Wed Oct 24 14:38:50 PDT 2012
Will be useful for the next patch, adding GLES 3 testing.
---
This patch has been trivially rebased onto Paul's "dispatch_sanity: print names
of functions that shouldnt be in dispatch table."
src/mesa/main/tests/dispatch_sanity.cpp | 11 +++++++++++
1 files changed, 11 insertions(+), 0 deletions(-)
diff --git a/src/mesa/main/tests/dispatch_sanity.cpp b/src/mesa/main/tests/dispatch_sanity.cpp
index ee53d2e..c50f40b 100644
--- a/src/mesa/main/tests/dispatch_sanity.cpp
+++ b/src/mesa/main/tests/dispatch_sanity.cpp
@@ -107,6 +107,9 @@ offset_to_proc_name_safe(unsigned offset)
return name ? name : "???";
}
+/* Scan through the dispatch table and check that all the functions in
+ * _glapi_proc *table exist. When found, set their pointers in the table
+ * to _mesa_generic_nop. */
static void
validate_functions(_glapi_proc *table, const struct function *function_table)
{
@@ -126,7 +129,13 @@ validate_functions(_glapi_proc *table, const struct function *function_table)
table[offset] = (_glapi_proc) _mesa_generic_nop;
}
+}
+/* Scan through the table and ensure that there is nothing except
+ * _mesa_generic_nop (as set by validate_functions(). */
+static void
+validate_nops(const _glapi_proc *table)
+{
const unsigned size = _glapi_get_dispatch_table_size();
for (unsigned i = 0; i < size; i++) {
EXPECT_EQ((_glapi_proc) _mesa_generic_nop, table[i])
@@ -139,6 +148,7 @@ TEST_F(DispatchSanity_test, GLES11)
{
_glapi_proc *exec = (_glapi_proc *) _mesa_create_exec_table_es1();
validate_functions(exec, gles11_functions_possible);
+ validate_nops(exec);
}
#endif /* FEATURE_ES1 */
@@ -157,6 +167,7 @@ TEST_F(DispatchSanity_test, GLES2)
_swsetup_CreateContext(&ctx);
validate_functions((_glapi_proc *) ctx.Exec, gles2_functions_possible);
+ validate_nops((_glapi_proc *) ctx.Exec);
}
#if FEATURE_ES1
--
1.7.8.6
More information about the mesa-dev
mailing list