2 * © Copyright 2017-2098 The Panfrost Communiy
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
24 #include "pan_pretty_print.h"
30 /* Some self-contained prettyprinting functions shared between pandecode and
33 #define DEFINE_CASE(name) case MALI_## name: return "MALI_" #name
34 char *pandecode_format(enum mali_format format
)
36 static char unk_format_str
[10];
39 DEFINE_CASE(ETC2_RGB8
);
40 DEFINE_CASE(ETC2_R11_UNORM
);
41 DEFINE_CASE(ETC2_RGBA8
);
42 DEFINE_CASE(ETC2_RG11_UNORM
);
43 DEFINE_CASE(ETC2_R11_SNORM
);
44 DEFINE_CASE(ETC2_RG11_SNORM
);
45 DEFINE_CASE(ETC2_RGB8A1
);
46 DEFINE_CASE(ASTC_SRGB_SUPP
);
47 DEFINE_CASE(ASTC_HDR_SUPP
);
49 DEFINE_CASE(RGB5_A1_UNORM
);
50 DEFINE_CASE(RGB10_A2_UNORM
);
51 DEFINE_CASE(RGB10_A2_SNORM
);
52 DEFINE_CASE(RGB10_A2UI
);
53 DEFINE_CASE(RGB10_A2I
);
55 DEFINE_CASE(Z32_UNORM
);
56 DEFINE_CASE(R32_FIXED
);
57 DEFINE_CASE(RG32_FIXED
);
58 DEFINE_CASE(RGB32_FIXED
);
59 DEFINE_CASE(RGBA32_FIXED
);
60 DEFINE_CASE(R11F_G11F_B10F
);
61 DEFINE_CASE(R9F_G9F_B9F_E5F
);
62 DEFINE_CASE(VARYING_POS
);
63 DEFINE_CASE(VARYING_DISCARD
);
65 DEFINE_CASE(R8_SNORM
);
66 DEFINE_CASE(R16_SNORM
);
67 DEFINE_CASE(R32_SNORM
);
68 DEFINE_CASE(RG8_SNORM
);
69 DEFINE_CASE(RG16_SNORM
);
70 DEFINE_CASE(RG32_SNORM
);
71 DEFINE_CASE(RGB8_SNORM
);
72 DEFINE_CASE(RGB16_SNORM
);
73 DEFINE_CASE(RGB32_SNORM
);
74 DEFINE_CASE(RGBA8_SNORM
);
75 DEFINE_CASE(RGBA16_SNORM
);
76 DEFINE_CASE(RGBA32_SNORM
);
88 DEFINE_CASE(RGBA16UI
);
89 DEFINE_CASE(RGBA32UI
);
91 DEFINE_CASE(R8_UNORM
);
92 DEFINE_CASE(R16_UNORM
);
93 DEFINE_CASE(R32_UNORM
);
95 DEFINE_CASE(RG8_UNORM
);
96 DEFINE_CASE(RG16_UNORM
);
97 DEFINE_CASE(RG32_UNORM
);
99 DEFINE_CASE(RGB8_UNORM
);
100 DEFINE_CASE(RGB16_UNORM
);
101 DEFINE_CASE(RGB32_UNORM
);
103 DEFINE_CASE(RGBA4_UNORM
);
104 DEFINE_CASE(RGBA8_UNORM
);
105 DEFINE_CASE(RGBA16_UNORM
);
106 DEFINE_CASE(RGBA32_UNORM
);
107 DEFINE_CASE(RGBA32F
);
122 DEFINE_CASE(RGBA16I
);
123 DEFINE_CASE(RGBA32I
);
124 DEFINE_CASE(RGBA16F
);
127 DEFINE_CASE(RGBA8_2
);
128 DEFINE_CASE(RGB10_A2_2
);
130 snprintf(unk_format_str
, sizeof(unk_format_str
), "MALI_0x%02x", format
);
131 return unk_format_str
;
137 /* Helper to dump fixed-function blend part for debugging */
140 panfrost_factor_name(enum mali_dominant_factor factor
)
143 case MALI_DOMINANT_UNK0
:
146 case MALI_DOMINANT_ZERO
:
149 case MALI_DOMINANT_SRC_COLOR
:
150 return "source color";
152 case MALI_DOMINANT_DST_COLOR
:
155 case MALI_DOMINANT_UNK4
:
158 case MALI_DOMINANT_SRC_ALPHA
:
159 return "source alpha";
161 case MALI_DOMINANT_DST_ALPHA
:
164 case MALI_DOMINANT_CONSTANT
:
168 return "unreachable";
172 panfrost_modifier_name(enum mali_blend_modifier mod
)
175 case MALI_BLEND_MOD_UNK0
:
178 case MALI_BLEND_MOD_NORMAL
:
181 case MALI_BLEND_MOD_SOURCE_ONE
:
184 case MALI_BLEND_MOD_DEST_ONE
:
188 return "unreachable";
192 panfrost_print_fixed_part(const char *name
, unsigned u
)
194 struct mali_blend_mode part
;
195 memcpy(&part
, &u
, sizeof(part
));
197 printf("%s blend mode (%X):\n", name
, u
);
199 printf(" %s dominant:\n",
200 (part
.dominant
== MALI_BLEND_DOM_SOURCE
) ? "source" : "destination");
202 printf(" %s\n", panfrost_factor_name(part
.dominant_factor
));
204 if (part
.complement_dominant
)
205 printf(" complement\n");
208 printf(" nondominant %s\n",
209 (part
.nondominant_mode
== MALI_BLEND_NON_MIRROR
) ? "mirror" : "zero");
212 printf(" mode: %s\n", panfrost_modifier_name(part
.clip_modifier
));
214 if (part
.negate_source
) printf(" negate source\n");
216 if (part
.negate_dest
) printf(" negate dest\n");
218 assert(!(part
.unused_0
|| part
.unused_1
));
222 panfrost_print_blend_equation(struct mali_blend_equation eq
)
225 panfrost_print_fixed_part("RGB", eq
.rgb_mode
);
226 panfrost_print_fixed_part("Alpha", eq
.alpha_mode
);
230 printf("Mask: %s%s%s%s\n",
231 (eq
.color_mask
& MALI_MASK_R
) ? "R" : "",
232 (eq
.color_mask
& MALI_MASK_G
) ? "G" : "",
233 (eq
.color_mask
& MALI_MASK_B
) ? "B" : "",
234 (eq
.color_mask
& MALI_MASK_A
) ? "A" : "");