1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker * Copyright (C) 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
24*61046927SAndroid Build Coastguard Worker #include "bi_builder.h"
25*61046927SAndroid Build Coastguard Worker #include "bi_test.h"
26*61046927SAndroid Build Coastguard Worker #include "compiler.h"
27*61046927SAndroid Build Coastguard Worker
28*61046927SAndroid Build Coastguard Worker #include <gtest/gtest.h>
29*61046927SAndroid Build Coastguard Worker
30*61046927SAndroid Build Coastguard Worker class SchedulerPredicates : public testing::Test {
31*61046927SAndroid Build Coastguard Worker protected:
SchedulerPredicates()32*61046927SAndroid Build Coastguard Worker SchedulerPredicates()
33*61046927SAndroid Build Coastguard Worker {
34*61046927SAndroid Build Coastguard Worker mem_ctx = ralloc_context(NULL);
35*61046927SAndroid Build Coastguard Worker b = bit_builder(mem_ctx);
36*61046927SAndroid Build Coastguard Worker }
~SchedulerPredicates()37*61046927SAndroid Build Coastguard Worker ~SchedulerPredicates()
38*61046927SAndroid Build Coastguard Worker {
39*61046927SAndroid Build Coastguard Worker ralloc_free(mem_ctx);
40*61046927SAndroid Build Coastguard Worker }
41*61046927SAndroid Build Coastguard Worker
TMP()42*61046927SAndroid Build Coastguard Worker bi_index TMP()
43*61046927SAndroid Build Coastguard Worker {
44*61046927SAndroid Build Coastguard Worker return bi_temp(b->shader);
45*61046927SAndroid Build Coastguard Worker }
46*61046927SAndroid Build Coastguard Worker
47*61046927SAndroid Build Coastguard Worker void *mem_ctx;
48*61046927SAndroid Build Coastguard Worker bi_builder *b;
49*61046927SAndroid Build Coastguard Worker };
50*61046927SAndroid Build Coastguard Worker
TEST_F(SchedulerPredicates,MOV)51*61046927SAndroid Build Coastguard Worker TEST_F(SchedulerPredicates, MOV)
52*61046927SAndroid Build Coastguard Worker {
53*61046927SAndroid Build Coastguard Worker bi_instr *mov = bi_mov_i32_to(b, TMP(), TMP());
54*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_fma(mov));
55*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_add(mov));
56*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_must_message(mov));
57*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_zero(mov));
58*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_temps(mov, 0));
59*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_t(mov, 0));
60*61046927SAndroid Build Coastguard Worker }
61*61046927SAndroid Build Coastguard Worker
TEST_F(SchedulerPredicates,FMA)62*61046927SAndroid Build Coastguard Worker TEST_F(SchedulerPredicates, FMA)
63*61046927SAndroid Build Coastguard Worker {
64*61046927SAndroid Build Coastguard Worker bi_instr *fma = bi_fma_f32_to(b, TMP(), TMP(), TMP(), bi_zero());
65*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_fma(fma));
66*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_can_add(fma));
67*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_must_message(fma));
68*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_zero(fma));
69*61046927SAndroid Build Coastguard Worker for (unsigned i = 0; i < 3; ++i) {
70*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_temps(fma, i));
71*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_t(fma, i));
72*61046927SAndroid Build Coastguard Worker }
73*61046927SAndroid Build Coastguard Worker }
74*61046927SAndroid Build Coastguard Worker
TEST_F(SchedulerPredicates,LOAD)75*61046927SAndroid Build Coastguard Worker TEST_F(SchedulerPredicates, LOAD)
76*61046927SAndroid Build Coastguard Worker {
77*61046927SAndroid Build Coastguard Worker bi_instr *load = bi_load_i128_to(b, TMP(), TMP(), TMP(), BI_SEG_UBO, 0);
78*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_can_fma(load));
79*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_add(load));
80*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_must_message(load));
81*61046927SAndroid Build Coastguard Worker for (unsigned i = 0; i < 2; ++i) {
82*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_temps(load, i));
83*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_t(load, i));
84*61046927SAndroid Build Coastguard Worker }
85*61046927SAndroid Build Coastguard Worker }
86*61046927SAndroid Build Coastguard Worker
TEST_F(SchedulerPredicates,BLEND)87*61046927SAndroid Build Coastguard Worker TEST_F(SchedulerPredicates, BLEND)
88*61046927SAndroid Build Coastguard Worker {
89*61046927SAndroid Build Coastguard Worker bi_instr *blend = bi_blend_to(b, TMP(), TMP(), TMP(), TMP(), TMP(), TMP(),
90*61046927SAndroid Build Coastguard Worker BI_REGISTER_FORMAT_F32, 4, 4);
91*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_can_fma(blend));
92*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_add(blend));
93*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_must_message(blend));
94*61046927SAndroid Build Coastguard Worker for (unsigned i = 0; i < 4; ++i)
95*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_temps(blend, i));
96*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_reads_t(blend, 0));
97*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_t(blend, 1));
98*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_reads_t(blend, 2));
99*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_reads_t(blend, 3));
100*61046927SAndroid Build Coastguard Worker }
101*61046927SAndroid Build Coastguard Worker
TEST_F(SchedulerPredicates,RestrictionsOnModifiersOfSameCycleTemporaries)102*61046927SAndroid Build Coastguard Worker TEST_F(SchedulerPredicates, RestrictionsOnModifiersOfSameCycleTemporaries)
103*61046927SAndroid Build Coastguard Worker {
104*61046927SAndroid Build Coastguard Worker bi_instr *fadd = bi_fadd_f32_to(b, TMP(), TMP(), TMP());
105*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_t(fadd, 0));
106*61046927SAndroid Build Coastguard Worker
107*61046927SAndroid Build Coastguard Worker for (unsigned i = 0; i < 2; ++i) {
108*61046927SAndroid Build Coastguard Worker for (unsigned j = 0; j < 2; ++j) {
109*61046927SAndroid Build Coastguard Worker bi_instr *fadd = bi_fadd_f32_to(b, TMP(), TMP(), TMP());
110*61046927SAndroid Build Coastguard Worker fadd->src[i] = bi_swz_16(TMP(), j, j);
111*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_reads_t(fadd, 1 - i));
112*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_reads_t(fadd, i));
113*61046927SAndroid Build Coastguard Worker }
114*61046927SAndroid Build Coastguard Worker }
115*61046927SAndroid Build Coastguard Worker }
116*61046927SAndroid Build Coastguard Worker
TEST_F(SchedulerPredicates,RestrictionsOnFAddV2F16)117*61046927SAndroid Build Coastguard Worker TEST_F(SchedulerPredicates, RestrictionsOnFAddV2F16)
118*61046927SAndroid Build Coastguard Worker {
119*61046927SAndroid Build Coastguard Worker bi_index x = bi_register(0);
120*61046927SAndroid Build Coastguard Worker bi_index y = bi_register(1);
121*61046927SAndroid Build Coastguard Worker
122*61046927SAndroid Build Coastguard Worker /* Basic */
123*61046927SAndroid Build Coastguard Worker bi_instr *fadd = bi_fadd_v2f16_to(b, TMP(), x, x);
124*61046927SAndroid Build Coastguard Worker
125*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_fma(fadd));
126*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_add(fadd));
127*61046927SAndroid Build Coastguard Worker
128*61046927SAndroid Build Coastguard Worker /* With imbalanced abs */
129*61046927SAndroid Build Coastguard Worker fadd->src[0].abs = true;
130*61046927SAndroid Build Coastguard Worker
131*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_fma(fadd));
132*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_add(fadd));
133*61046927SAndroid Build Coastguard Worker
134*61046927SAndroid Build Coastguard Worker /* With equal abs */
135*61046927SAndroid Build Coastguard Worker fadd->src[1].abs = true;
136*61046927SAndroid Build Coastguard Worker
137*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_can_fma(fadd));
138*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_add(fadd));
139*61046927SAndroid Build Coastguard Worker
140*61046927SAndroid Build Coastguard Worker /* With equal abs but different sources */
141*61046927SAndroid Build Coastguard Worker fadd->src[1] = bi_abs(y);
142*61046927SAndroid Build Coastguard Worker
143*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_fma(fadd));
144*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_add(fadd));
145*61046927SAndroid Build Coastguard Worker
146*61046927SAndroid Build Coastguard Worker /* With clamp */
147*61046927SAndroid Build Coastguard Worker fadd->clamp = BI_CLAMP_CLAMP_M1_1;
148*61046927SAndroid Build Coastguard Worker
149*61046927SAndroid Build Coastguard Worker ASSERT_TRUE(bi_can_fma(fadd));
150*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_can_add(fadd));
151*61046927SAndroid Build Coastguard Worker
152*61046927SAndroid Build Coastguard Worker /* Impossible encoding (should never be seen) */
153*61046927SAndroid Build Coastguard Worker fadd->src[1] = fadd->src[0];
154*61046927SAndroid Build Coastguard Worker
155*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_can_fma(fadd));
156*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_can_add(fadd));
157*61046927SAndroid Build Coastguard Worker }
158*61046927SAndroid Build Coastguard Worker
TEST_F(SchedulerPredicates,BranchOffset)159*61046927SAndroid Build Coastguard Worker TEST_F(SchedulerPredicates, BranchOffset)
160*61046927SAndroid Build Coastguard Worker {
161*61046927SAndroid Build Coastguard Worker bi_instr *jump = bi_jump(b, TMP());
162*61046927SAndroid Build Coastguard Worker ASSERT_FALSE(bi_reads_t(jump, 0));
163*61046927SAndroid Build Coastguard Worker }
164