xref: /aosp_15_r20/external/mesa3d/src/panfrost/compiler/bi_test.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * Copyright (C) 2020-2021 Collabora Ltd.
3*61046927SAndroid Build Coastguard Worker  *
4*61046927SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker  *
11*61046927SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker  * Software.
14*61046927SAndroid Build Coastguard Worker  *
15*61046927SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20*61046927SAndroid Build Coastguard Worker  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21*61046927SAndroid Build Coastguard Worker  * SOFTWARE.
22*61046927SAndroid Build Coastguard Worker  *
23*61046927SAndroid Build Coastguard Worker  * Authors (Collabora):
24*61046927SAndroid Build Coastguard Worker  *      Alyssa Rosenzweig <[email protected]>
25*61046927SAndroid Build Coastguard Worker  */
26*61046927SAndroid Build Coastguard Worker 
27*61046927SAndroid Build Coastguard Worker #ifndef __BI_TEST_H
28*61046927SAndroid Build Coastguard Worker #define __BI_TEST_H
29*61046927SAndroid Build Coastguard Worker 
30*61046927SAndroid Build Coastguard Worker #include <inttypes.h>
31*61046927SAndroid Build Coastguard Worker #include <stdio.h>
32*61046927SAndroid Build Coastguard Worker #include "compiler.h"
33*61046927SAndroid Build Coastguard Worker 
34*61046927SAndroid Build Coastguard Worker /* Helper to generate a bi_builder suitable for creating test instructions */
35*61046927SAndroid Build Coastguard Worker static inline bi_block *
bit_block(bi_context * ctx)36*61046927SAndroid Build Coastguard Worker bit_block(bi_context *ctx)
37*61046927SAndroid Build Coastguard Worker {
38*61046927SAndroid Build Coastguard Worker    bi_block *blk = rzalloc(ctx, bi_block);
39*61046927SAndroid Build Coastguard Worker 
40*61046927SAndroid Build Coastguard Worker    util_dynarray_init(&blk->predecessors, blk);
41*61046927SAndroid Build Coastguard Worker    list_addtail(&blk->link, &ctx->blocks);
42*61046927SAndroid Build Coastguard Worker    list_inithead(&blk->instructions);
43*61046927SAndroid Build Coastguard Worker 
44*61046927SAndroid Build Coastguard Worker    blk->index = ctx->num_blocks++;
45*61046927SAndroid Build Coastguard Worker 
46*61046927SAndroid Build Coastguard Worker    return blk;
47*61046927SAndroid Build Coastguard Worker }
48*61046927SAndroid Build Coastguard Worker 
49*61046927SAndroid Build Coastguard Worker static inline bi_builder *
bit_builder(void * memctx)50*61046927SAndroid Build Coastguard Worker bit_builder(void *memctx)
51*61046927SAndroid Build Coastguard Worker {
52*61046927SAndroid Build Coastguard Worker    bi_context *ctx = rzalloc(memctx, bi_context);
53*61046927SAndroid Build Coastguard Worker    list_inithead(&ctx->blocks);
54*61046927SAndroid Build Coastguard Worker    ctx->inputs = rzalloc(memctx, struct panfrost_compile_inputs);
55*61046927SAndroid Build Coastguard Worker 
56*61046927SAndroid Build Coastguard Worker    bi_block *blk = bit_block(ctx);
57*61046927SAndroid Build Coastguard Worker 
58*61046927SAndroid Build Coastguard Worker    bi_builder *b = rzalloc(memctx, bi_builder);
59*61046927SAndroid Build Coastguard Worker    b->shader = ctx;
60*61046927SAndroid Build Coastguard Worker    b->cursor = bi_after_block(blk);
61*61046927SAndroid Build Coastguard Worker    return b;
62*61046927SAndroid Build Coastguard Worker }
63*61046927SAndroid Build Coastguard Worker 
64*61046927SAndroid Build Coastguard Worker /* Helper to compare for logical equality of instructions. Need to skip over
65*61046927SAndroid Build Coastguard Worker  * the pointers, guaranteed to be first. After that we can compare raw data.
66*61046927SAndroid Build Coastguard Worker  */
67*61046927SAndroid Build Coastguard Worker static inline bool
bit_instr_equal(bi_instr * A,bi_instr * B)68*61046927SAndroid Build Coastguard Worker bit_instr_equal(bi_instr *A, bi_instr *B)
69*61046927SAndroid Build Coastguard Worker {
70*61046927SAndroid Build Coastguard Worker    size_t skip = sizeof(struct list_head) + 2 * sizeof(bi_index *);
71*61046927SAndroid Build Coastguard Worker 
72*61046927SAndroid Build Coastguard Worker    if (memcmp((uint8_t *)A + skip, (uint8_t *)B + skip,
73*61046927SAndroid Build Coastguard Worker               sizeof(bi_instr) - skip))
74*61046927SAndroid Build Coastguard Worker       return false;
75*61046927SAndroid Build Coastguard Worker 
76*61046927SAndroid Build Coastguard Worker    if (memcmp(A->dest, B->dest, sizeof(bi_index) * A->nr_dests))
77*61046927SAndroid Build Coastguard Worker       return false;
78*61046927SAndroid Build Coastguard Worker 
79*61046927SAndroid Build Coastguard Worker    if (memcmp(A->src, B->src, sizeof(bi_index) * A->nr_srcs))
80*61046927SAndroid Build Coastguard Worker       return false;
81*61046927SAndroid Build Coastguard Worker 
82*61046927SAndroid Build Coastguard Worker    return true;
83*61046927SAndroid Build Coastguard Worker }
84*61046927SAndroid Build Coastguard Worker 
85*61046927SAndroid Build Coastguard Worker static inline bool
bit_block_equal(bi_block * A,bi_block * B)86*61046927SAndroid Build Coastguard Worker bit_block_equal(bi_block *A, bi_block *B)
87*61046927SAndroid Build Coastguard Worker {
88*61046927SAndroid Build Coastguard Worker    if (list_length(&A->instructions) != list_length(&B->instructions))
89*61046927SAndroid Build Coastguard Worker       return false;
90*61046927SAndroid Build Coastguard Worker 
91*61046927SAndroid Build Coastguard Worker    list_pair_for_each_entry(bi_instr, insA, insB, &A->instructions,
92*61046927SAndroid Build Coastguard Worker                             &B->instructions, link) {
93*61046927SAndroid Build Coastguard Worker       if (!bit_instr_equal(insA, insB))
94*61046927SAndroid Build Coastguard Worker          return false;
95*61046927SAndroid Build Coastguard Worker    }
96*61046927SAndroid Build Coastguard Worker 
97*61046927SAndroid Build Coastguard Worker    return true;
98*61046927SAndroid Build Coastguard Worker }
99*61046927SAndroid Build Coastguard Worker 
100*61046927SAndroid Build Coastguard Worker static inline bool
bit_shader_equal(bi_context * A,bi_context * B)101*61046927SAndroid Build Coastguard Worker bit_shader_equal(bi_context *A, bi_context *B)
102*61046927SAndroid Build Coastguard Worker {
103*61046927SAndroid Build Coastguard Worker    if (list_length(&A->blocks) != list_length(&B->blocks))
104*61046927SAndroid Build Coastguard Worker       return false;
105*61046927SAndroid Build Coastguard Worker 
106*61046927SAndroid Build Coastguard Worker    list_pair_for_each_entry(bi_block, blockA, blockB, &A->blocks, &B->blocks,
107*61046927SAndroid Build Coastguard Worker                             link) {
108*61046927SAndroid Build Coastguard Worker       if (!bit_block_equal(blockA, blockB))
109*61046927SAndroid Build Coastguard Worker          return false;
110*61046927SAndroid Build Coastguard Worker    }
111*61046927SAndroid Build Coastguard Worker 
112*61046927SAndroid Build Coastguard Worker    return true;
113*61046927SAndroid Build Coastguard Worker }
114*61046927SAndroid Build Coastguard Worker 
115*61046927SAndroid Build Coastguard Worker #define ASSERT_SHADER_EQUAL(A, B)                                              \
116*61046927SAndroid Build Coastguard Worker    if (!bit_shader_equal(A, B)) {                                              \
117*61046927SAndroid Build Coastguard Worker       ADD_FAILURE();                                                           \
118*61046927SAndroid Build Coastguard Worker       fprintf(stderr, "Pass produced unexpected results");                     \
119*61046927SAndroid Build Coastguard Worker       fprintf(stderr, "  Actual:\n");                                          \
120*61046927SAndroid Build Coastguard Worker       bi_print_shader(A, stderr);                                              \
121*61046927SAndroid Build Coastguard Worker       fprintf(stderr, " Expected:\n");                                         \
122*61046927SAndroid Build Coastguard Worker       bi_print_shader(B, stderr);                                              \
123*61046927SAndroid Build Coastguard Worker       fprintf(stderr, "\n");                                                   \
124*61046927SAndroid Build Coastguard Worker    }
125*61046927SAndroid Build Coastguard Worker 
126*61046927SAndroid Build Coastguard Worker #define INSTRUCTION_CASE(instr, expected, pass)                                \
127*61046927SAndroid Build Coastguard Worker    do {                                                                        \
128*61046927SAndroid Build Coastguard Worker       bi_builder *A = bit_builder(mem_ctx);                                    \
129*61046927SAndroid Build Coastguard Worker       bi_builder *B = bit_builder(mem_ctx);                                    \
130*61046927SAndroid Build Coastguard Worker       {                                                                        \
131*61046927SAndroid Build Coastguard Worker          bi_builder *b = A;                                                    \
132*61046927SAndroid Build Coastguard Worker          instr;                                                                \
133*61046927SAndroid Build Coastguard Worker       }                                                                        \
134*61046927SAndroid Build Coastguard Worker       {                                                                        \
135*61046927SAndroid Build Coastguard Worker          bi_builder *b = B;                                                    \
136*61046927SAndroid Build Coastguard Worker          expected;                                                             \
137*61046927SAndroid Build Coastguard Worker       }                                                                        \
138*61046927SAndroid Build Coastguard Worker       pass(A->shader);                                                         \
139*61046927SAndroid Build Coastguard Worker       ASSERT_SHADER_EQUAL(A->shader, B->shader);                               \
140*61046927SAndroid Build Coastguard Worker    } while (0)
141*61046927SAndroid Build Coastguard Worker 
142*61046927SAndroid Build Coastguard Worker #endif
143