pan/bi: Add ASSERT_SHADER_EQUAL macro
authorAlyssa Rosenzweig <alyssa@collabora.com>
Thu, 19 May 2022 20:11:24 +0000 (16:11 -0400)
committerMarge Bot <emma+marge@anholt.net>
Wed, 1 Jun 2022 16:14:38 +0000 (16:14 +0000)
Useful for whole-program unit tests.

Signed-off-by: Alyssa Rosenzweig <alyssa@collabora.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/16804>

src/panfrost/bifrost/bi_test.h

index e39aa00..d43463c 100644 (file)
@@ -91,6 +91,17 @@ bit_shader_equal(bi_context *A, bi_context *B)
    return true;
 }
 
+#define ASSERT_SHADER_EQUAL(A, B) \
+   if (!bit_shader_equal(A, B)) { \
+      ADD_FAILURE(); \
+      fprintf(stderr, "Pass produced unexpected results"); \
+      fprintf(stderr, "  Actual:\n"); \
+      bi_print_shader(A, stderr); \
+      fprintf(stderr, " Expected:\n"); \
+      bi_print_shader(B, stderr); \
+      fprintf(stderr, "\n"); \
+   } \
+
 #define INSTRUCTION_CASE(instr, expected, pass) do { \
    bi_builder *A = bit_builder(mem_ctx); \
    bi_builder *B = bit_builder(mem_ctx); \
@@ -103,15 +114,7 @@ bit_shader_equal(bi_context *A, bi_context *B)
       expected; \
    } \
    pass(A->shader); \
-   if (!bit_shader_equal(A->shader, B->shader)) { \
-      ADD_FAILURE(); \
-      fprintf(stderr, "Pass produced unexpected results"); \
-      fprintf(stderr, "  Actual:\n"); \
-      bi_print_shader(A->shader, stderr); \
-      fprintf(stderr, "Expected:\n"); \
-      bi_print_shader(B->shader, stderr); \
-      fprintf(stderr, "\n"); \
-   } \
+   ASSERT_SHADER_EQUAL(A->shader, B->shader); \
 } while(0)
 
 #endif