1bf215546Sopenharmony_ci/*
2bf215546Sopenharmony_ci * Copyright (C) 2022 Collabora, Ltd.
3bf215546Sopenharmony_ci *
4bf215546Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a
5bf215546Sopenharmony_ci * copy of this software and associated documentation files (the "Software"),
6bf215546Sopenharmony_ci * to deal in the Software without restriction, including without limitation
7bf215546Sopenharmony_ci * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8bf215546Sopenharmony_ci * and/or sell copies of the Software, and to permit persons to whom the
9bf215546Sopenharmony_ci * Software is furnished to do so, subject to the following conditions:
10bf215546Sopenharmony_ci *
11bf215546Sopenharmony_ci * The above copyright notice and this permission notice (including the next
12bf215546Sopenharmony_ci * paragraph) shall be included in all copies or substantial portions of the
13bf215546Sopenharmony_ci * Software.
14bf215546Sopenharmony_ci *
15bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16bf215546Sopenharmony_ci * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17bf215546Sopenharmony_ci * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18bf215546Sopenharmony_ci * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19bf215546Sopenharmony_ci * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20bf215546Sopenharmony_ci * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21bf215546Sopenharmony_ci * SOFTWARE.
22bf215546Sopenharmony_ci */
23bf215546Sopenharmony_ci
24bf215546Sopenharmony_ci#include "pan_earlyzs.h"
25bf215546Sopenharmony_ci#include "util/pan_ir.h"
26bf215546Sopenharmony_ci
27bf215546Sopenharmony_ci#include <gtest/gtest.h>
28bf215546Sopenharmony_ci
29bf215546Sopenharmony_ci/*
30bf215546Sopenharmony_ci * Test the early-ZS helpers used on Bifrost and Valhall. Early-ZS state depends
31bf215546Sopenharmony_ci * on both shader state and draw-time API state. As such, there are two helpers
32bf215546Sopenharmony_ci * -- analzye and get -- that separate the link-time analysis of a fragment
33bf215546Sopenharmony_ci * shader from the draw-time classification. The internal data structure is not
34bf215546Sopenharmony_ci * under test, only the external API. So we test only the composition.
35bf215546Sopenharmony_ci */
36bf215546Sopenharmony_ci
37bf215546Sopenharmony_ci#define ZS_WRITEMASK BITFIELD_BIT(0)
38bf215546Sopenharmony_ci#define ALPHA2COV BITFIELD_BIT(1)
39bf215546Sopenharmony_ci#define ZS_ALWAYS_PASSES BITFIELD_BIT(2)
40bf215546Sopenharmony_ci#define DISCARD BITFIELD_BIT(3)
41bf215546Sopenharmony_ci#define WRITES_Z BITFIELD_BIT(4)
42bf215546Sopenharmony_ci#define WRITES_S BITFIELD_BIT(5)
43bf215546Sopenharmony_ci#define WRITES_COV BITFIELD_BIT(6)
44bf215546Sopenharmony_ci#define SIDEFX BITFIELD_BIT(7)
45bf215546Sopenharmony_ci#define API_EARLY BITFIELD_BIT(8)
46bf215546Sopenharmony_ci
47bf215546Sopenharmony_cistatic void
48bf215546Sopenharmony_citest(enum pan_earlyzs expected_update, enum pan_earlyzs expected_kill, uint32_t flags)
49bf215546Sopenharmony_ci{
50bf215546Sopenharmony_ci   struct pan_shader_info info = {
51bf215546Sopenharmony_ci      .fs = {
52bf215546Sopenharmony_ci         .can_discard = !!(flags & DISCARD),
53bf215546Sopenharmony_ci         .writes_depth = !!(flags & WRITES_Z),
54bf215546Sopenharmony_ci         .writes_stencil = !!(flags & WRITES_S),
55bf215546Sopenharmony_ci         .writes_coverage = !!(flags & WRITES_COV),
56bf215546Sopenharmony_ci         .early_fragment_tests = !!(flags & API_EARLY),
57bf215546Sopenharmony_ci      },
58bf215546Sopenharmony_ci      .writes_global = !!(flags & SIDEFX),
59bf215546Sopenharmony_ci   };
60bf215546Sopenharmony_ci
61bf215546Sopenharmony_ci   struct pan_earlyzs_state result =
62bf215546Sopenharmony_ci      pan_earlyzs_get(pan_earlyzs_analyze(&info),
63bf215546Sopenharmony_ci                      !!(flags & ZS_WRITEMASK),
64bf215546Sopenharmony_ci                      !!(flags & ALPHA2COV),
65bf215546Sopenharmony_ci                      !!(flags & ZS_ALWAYS_PASSES));
66bf215546Sopenharmony_ci
67bf215546Sopenharmony_ci   ASSERT_EQ(result.update, expected_update);
68bf215546Sopenharmony_ci   ASSERT_EQ(result.kill, expected_kill);
69bf215546Sopenharmony_ci}
70bf215546Sopenharmony_ci
71bf215546Sopenharmony_ci
72bf215546Sopenharmony_ci#define CASE(expected_update, expected_kill, flags) \
73bf215546Sopenharmony_ci   test(PAN_EARLYZS_ ## expected_update, PAN_EARLYZS_ ## expected_kill, flags)
74bf215546Sopenharmony_ci
75bf215546Sopenharmony_ciTEST(EarlyZS, APIForceEarly)
76bf215546Sopenharmony_ci{
77bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_EARLY, API_EARLY);
78bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_EARLY, API_EARLY | WRITES_Z | WRITES_S);
79bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_EARLY, API_EARLY | ALPHA2COV | DISCARD);
80bf215546Sopenharmony_ci}
81bf215546Sopenharmony_ci
82bf215546Sopenharmony_ciTEST(EarlyZS, ShaderCalculatesZS)
83bf215546Sopenharmony_ci{
84bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, WRITES_Z);
85bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, WRITES_S);
86bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, WRITES_Z | WRITES_S);
87bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, WRITES_Z | WRITES_S | SIDEFX);
88bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, WRITES_Z | WRITES_S | ZS_ALWAYS_PASSES);
89bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, WRITES_Z | ZS_ALWAYS_PASSES | ALPHA2COV);
90bf215546Sopenharmony_ci}
91bf215546Sopenharmony_ci
92bf215546Sopenharmony_ciTEST(EarlyZS, ModifiesCoverageWritesZSNoSideFX)
93bf215546Sopenharmony_ci{
94bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_EARLY, ZS_WRITEMASK | WRITES_COV);
95bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_EARLY, ZS_WRITEMASK | DISCARD);
96bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_EARLY, ZS_WRITEMASK | ALPHA2COV);
97bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_EARLY, ZS_WRITEMASK | WRITES_COV | DISCARD | ALPHA2COV);
98bf215546Sopenharmony_ci}
99bf215546Sopenharmony_ci
100bf215546Sopenharmony_ciTEST(EarlyZS, ModifiesCoverageWritesZSNoSideFXAlt)
101bf215546Sopenharmony_ci{
102bf215546Sopenharmony_ci   CASE(FORCE_LATE, WEAK_EARLY, ZS_ALWAYS_PASSES | ZS_WRITEMASK | WRITES_COV);
103bf215546Sopenharmony_ci   CASE(FORCE_LATE, WEAK_EARLY, ZS_ALWAYS_PASSES | ZS_WRITEMASK | DISCARD);
104bf215546Sopenharmony_ci   CASE(FORCE_LATE, WEAK_EARLY, ZS_ALWAYS_PASSES | ZS_WRITEMASK | ALPHA2COV);
105bf215546Sopenharmony_ci   CASE(FORCE_LATE, WEAK_EARLY, ZS_ALWAYS_PASSES | ZS_WRITEMASK | WRITES_COV | DISCARD | ALPHA2COV);
106bf215546Sopenharmony_ci}
107bf215546Sopenharmony_ci
108bf215546Sopenharmony_ciTEST(EarlyZS, ModifiesCoverageWritesZSSideFX)
109bf215546Sopenharmony_ci{
110bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, ZS_WRITEMASK | SIDEFX | WRITES_COV);
111bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, ZS_WRITEMASK | SIDEFX | DISCARD);
112bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, ZS_WRITEMASK | SIDEFX | ALPHA2COV);
113bf215546Sopenharmony_ci   CASE(FORCE_LATE, FORCE_LATE, ZS_WRITEMASK | SIDEFX | WRITES_COV | DISCARD | ALPHA2COV);
114bf215546Sopenharmony_ci}
115bf215546Sopenharmony_ci
116bf215546Sopenharmony_ciTEST(EarlyZS, SideFXNoShaderZS)
117bf215546Sopenharmony_ci{
118bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_LATE, SIDEFX);
119bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_LATE, SIDEFX | DISCARD);
120bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_LATE, SIDEFX | WRITES_COV);
121bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_LATE, SIDEFX | ALPHA2COV);
122bf215546Sopenharmony_ci}
123bf215546Sopenharmony_ci
124bf215546Sopenharmony_ciTEST(EarlyZS, SideFXNoShaderZSAlt)
125bf215546Sopenharmony_ci{
126bf215546Sopenharmony_ci   CASE(WEAK_EARLY, FORCE_LATE, ZS_ALWAYS_PASSES | SIDEFX);
127bf215546Sopenharmony_ci   CASE(WEAK_EARLY, FORCE_LATE, ZS_ALWAYS_PASSES | SIDEFX | DISCARD);
128bf215546Sopenharmony_ci   CASE(WEAK_EARLY, FORCE_LATE, ZS_ALWAYS_PASSES | SIDEFX | WRITES_COV);
129bf215546Sopenharmony_ci   CASE(WEAK_EARLY, FORCE_LATE, ZS_ALWAYS_PASSES | SIDEFX | ALPHA2COV);
130bf215546Sopenharmony_ci}
131bf215546Sopenharmony_ci
132bf215546Sopenharmony_ciTEST(EarlyZS, NoSideFXNoShaderZS)
133bf215546Sopenharmony_ci{
134bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_EARLY, 0);
135bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_EARLY, ALPHA2COV | DISCARD | WRITES_COV);
136bf215546Sopenharmony_ci   CASE(FORCE_EARLY, FORCE_EARLY, ZS_WRITEMASK);
137bf215546Sopenharmony_ci}
138bf215546Sopenharmony_ci
139bf215546Sopenharmony_ciTEST(EarlyZS, NoSideFXNoShaderZSAlt)
140bf215546Sopenharmony_ci{
141bf215546Sopenharmony_ci   CASE(WEAK_EARLY, WEAK_EARLY, ZS_ALWAYS_PASSES);
142bf215546Sopenharmony_ci   CASE(WEAK_EARLY, WEAK_EARLY, ZS_ALWAYS_PASSES | ALPHA2COV | DISCARD | WRITES_COV);
143bf215546Sopenharmony_ci   CASE(WEAK_EARLY, WEAK_EARLY, ZS_ALWAYS_PASSES | ZS_WRITEMASK);
144bf215546Sopenharmony_ci}
145