1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24 #ifndef GFX_8_0_ENUM_H
25 #define GFX_8_0_ENUM_H
26
27 typedef enum SurfaceNumber {
28 NUMBER_UNORM = 0x0,
29 NUMBER_SNORM = 0x1,
30 NUMBER_USCALED = 0x2,
31 NUMBER_SSCALED = 0x3,
32 NUMBER_UINT = 0x4,
33 NUMBER_SINT = 0x5,
34 NUMBER_SRGB = 0x6,
35 NUMBER_FLOAT = 0x7,
36 } SurfaceNumber;
37 typedef enum SurfaceSwap {
38 SWAP_STD = 0x0,
39 SWAP_ALT = 0x1,
40 SWAP_STD_REV = 0x2,
41 SWAP_ALT_REV = 0x3,
42 } SurfaceSwap;
43 typedef enum CBMode {
44 CB_DISABLE = 0x0,
45 CB_NORMAL = 0x1,
46 CB_ELIMINATE_FAST_CLEAR = 0x2,
47 CB_RESOLVE = 0x3,
48 CB_DECOMPRESS = 0x4,
49 CB_FMASK_DECOMPRESS = 0x5,
50 CB_DCC_DECOMPRESS = 0x6,
51 } CBMode;
52 typedef enum RoundMode {
53 ROUND_BY_HALF = 0x0,
54 ROUND_TRUNCATE = 0x1,
55 } RoundMode;
56 typedef enum SourceFormat {
57 EXPORT_4C_32BPC = 0x0,
58 EXPORT_4C_16BPC = 0x1,
59 EXPORT_2C_32BPC_GR = 0x2,
60 EXPORT_2C_32BPC_AR = 0x3,
61 } SourceFormat;
62 typedef enum BlendOp {
63 BLEND_ZERO = 0x0,
64 BLEND_ONE = 0x1,
65 BLEND_SRC_COLOR = 0x2,
66 BLEND_ONE_MINUS_SRC_COLOR = 0x3,
67 BLEND_SRC_ALPHA = 0x4,
68 BLEND_ONE_MINUS_SRC_ALPHA = 0x5,
69 BLEND_DST_ALPHA = 0x6,
70 BLEND_ONE_MINUS_DST_ALPHA = 0x7,
71 BLEND_DST_COLOR = 0x8,
72 BLEND_ONE_MINUS_DST_COLOR = 0x9,
73 BLEND_SRC_ALPHA_SATURATE = 0xa,
74 BLEND_BOTH_SRC_ALPHA = 0xb,
75 BLEND_BOTH_INV_SRC_ALPHA = 0xc,
76 BLEND_CONSTANT_COLOR = 0xd,
77 BLEND_ONE_MINUS_CONSTANT_COLOR = 0xe,
78 BLEND_SRC1_COLOR = 0xf,
79 BLEND_INV_SRC1_COLOR = 0x10,
80 BLEND_SRC1_ALPHA = 0x11,
81 BLEND_INV_SRC1_ALPHA = 0x12,
82 BLEND_CONSTANT_ALPHA = 0x13,
83 BLEND_ONE_MINUS_CONSTANT_ALPHA = 0x14,
84 } BlendOp;
85 typedef enum CombFunc {
86 COMB_DST_PLUS_SRC = 0x0,
87 COMB_SRC_MINUS_DST = 0x1,
88 COMB_MIN_DST_SRC = 0x2,
89 COMB_MAX_DST_SRC = 0x3,
90 COMB_DST_MINUS_SRC = 0x4,
91 } CombFunc;
92 typedef enum BlendOpt {
93 FORCE_OPT_AUTO = 0x0,
94 FORCE_OPT_DISABLE = 0x1,
95 FORCE_OPT_ENABLE_IF_SRC_A_0 = 0x2,
96 FORCE_OPT_ENABLE_IF_SRC_RGB_0 = 0x3,
97 FORCE_OPT_ENABLE_IF_SRC_ARGB_0 = 0x4,
98 FORCE_OPT_ENABLE_IF_SRC_A_1 = 0x5,
99 FORCE_OPT_ENABLE_IF_SRC_RGB_1 = 0x6,
100 FORCE_OPT_ENABLE_IF_SRC_ARGB_1 = 0x7,
101 } BlendOpt;
102 typedef enum CmaskCode {
103 CMASK_CLR00_F0 = 0x0,
104 CMASK_CLR00_F1 = 0x1,
105 CMASK_CLR00_F2 = 0x2,
106 CMASK_CLR00_FX = 0x3,
107 CMASK_CLR01_F0 = 0x4,
108 CMASK_CLR01_F1 = 0x5,
109 CMASK_CLR01_F2 = 0x6,
110 CMASK_CLR01_FX = 0x7,
111 CMASK_CLR10_F0 = 0x8,
112 CMASK_CLR10_F1 = 0x9,
113 CMASK_CLR10_F2 = 0xa,
114 CMASK_CLR10_FX = 0xb,
115 CMASK_CLR11_F0 = 0xc,
116 CMASK_CLR11_F1 = 0xd,
117 CMASK_CLR11_F2 = 0xe,
118 CMASK_CLR11_FX = 0xf,
119 } CmaskCode;
120 typedef enum CmaskAddr {
121 CMASK_ADDR_TILED = 0x0,
122 CMASK_ADDR_LINEAR = 0x1,
123 CMASK_ADDR_COMPATIBLE = 0x2,
124 } CmaskAddr;
125 typedef enum CBPerfSel {
126 CB_PERF_SEL_NONE = 0x0,
127 CB_PERF_SEL_BUSY = 0x1,
128 CB_PERF_SEL_CORE_SCLK_VLD = 0x2,
129 CB_PERF_SEL_REG_SCLK0_VLD = 0x3,
130 CB_PERF_SEL_REG_SCLK1_VLD = 0x4,
131 CB_PERF_SEL_DRAWN_QUAD = 0x5,
132 CB_PERF_SEL_DRAWN_PIXEL = 0x6,
133 CB_PERF_SEL_DRAWN_QUAD_FRAGMENT = 0x7,
134 CB_PERF_SEL_DRAWN_TILE = 0x8,
135 CB_PERF_SEL_DB_CB_TILE_VALID_READY = 0x9,
136 CB_PERF_SEL_DB_CB_TILE_VALID_READYB = 0xa,
137 CB_PERF_SEL_DB_CB_TILE_VALIDB_READY = 0xb,
138 CB_PERF_SEL_DB_CB_TILE_VALIDB_READYB = 0xc,
139 CB_PERF_SEL_CM_FC_TILE_VALID_READY = 0xd,
140 CB_PERF_SEL_CM_FC_TILE_VALID_READYB = 0xe,
141 CB_PERF_SEL_CM_FC_TILE_VALIDB_READY = 0xf,
142 CB_PERF_SEL_CM_FC_TILE_VALIDB_READYB = 0x10,
143 CB_PERF_SEL_MERGE_TILE_ONLY_VALID_READY = 0x11,
144 CB_PERF_SEL_MERGE_TILE_ONLY_VALID_READYB = 0x12,
145 CB_PERF_SEL_DB_CB_LQUAD_VALID_READY = 0x13,
146 CB_PERF_SEL_DB_CB_LQUAD_VALID_READYB = 0x14,
147 CB_PERF_SEL_DB_CB_LQUAD_VALIDB_READY = 0x15,
148 CB_PERF_SEL_DB_CB_LQUAD_VALIDB_READYB = 0x16,
149 CB_PERF_SEL_LQUAD_NO_TILE = 0x17,
150 CB_PERF_SEL_LQUAD_FORMAT_IS_EXPORT_32_R = 0x18,
151 CB_PERF_SEL_LQUAD_FORMAT_IS_EXPORT_32_AR = 0x19,
152 CB_PERF_SEL_LQUAD_FORMAT_IS_EXPORT_32_GR = 0x1a,
153 CB_PERF_SEL_LQUAD_FORMAT_IS_EXPORT_32_ABGR = 0x1b,
154 CB_PERF_SEL_LQUAD_FORMAT_IS_EXPORT_FP16_ABGR = 0x1c,
155 CB_PERF_SEL_LQUAD_FORMAT_IS_EXPORT_SIGNED16_ABGR = 0x1d,
156 CB_PERF_SEL_LQUAD_FORMAT_IS_EXPORT_UNSIGNED16_ABGR= 0x1e,
157 CB_PERF_SEL_QUAD_KILLED_BY_EXTRA_PIXEL_EXPORT = 0x1f,
158 CB_PERF_SEL_QUAD_KILLED_BY_COLOR_INVALID = 0x20,
159 CB_PERF_SEL_QUAD_KILLED_BY_NULL_TARGET_SHADER_MASK= 0x21,
160 CB_PERF_SEL_QUAD_KILLED_BY_NULL_SAMPLE_MASK = 0x22,
161 CB_PERF_SEL_QUAD_KILLED_BY_DISCARD_PIXEL = 0x23,
162 CB_PERF_SEL_FC_CLEAR_QUAD_VALID_READY = 0x24,
163 CB_PERF_SEL_FC_CLEAR_QUAD_VALID_READYB = 0x25,
164 CB_PERF_SEL_FC_CLEAR_QUAD_VALIDB_READY = 0x26,
165 CB_PERF_SEL_FC_CLEAR_QUAD_VALIDB_READYB = 0x27,
166 CB_PERF_SEL_FOP_IN_VALID_READY = 0x28,
167 CB_PERF_SEL_FOP_IN_VALID_READYB = 0x29,
168 CB_PERF_SEL_FOP_IN_VALIDB_READY = 0x2a,
169 CB_PERF_SEL_FOP_IN_VALIDB_READYB = 0x2b,
170 CB_PERF_SEL_FC_CC_QUADFRAG_VALID_READY = 0x2c,
171 CB_PERF_SEL_FC_CC_QUADFRAG_VALID_READYB = 0x2d,
172 CB_PERF_SEL_FC_CC_QUADFRAG_VALIDB_READY = 0x2e,
173 CB_PERF_SEL_FC_CC_QUADFRAG_VALIDB_READYB = 0x2f,
174 CB_PERF_SEL_CC_IB_SR_FRAG_VALID_READY = 0x30,
175 CB_PERF_SEL_CC_IB_SR_FRAG_VALID_READYB = 0x31,
176 CB_PERF_SEL_CC_IB_SR_FRAG_VALIDB_READY = 0x32,
177 CB_PERF_SEL_CC_IB_SR_FRAG_VALIDB_READYB = 0x33,
178 CB_PERF_SEL_CC_IB_TB_FRAG_VALID_READY = 0x34,
179 CB_PERF_SEL_CC_IB_TB_FRAG_VALID_READYB = 0x35,
180 CB_PERF_SEL_CC_IB_TB_FRAG_VALIDB_READY = 0x36,
181 CB_PERF_SEL_CC_IB_TB_FRAG_VALIDB_READYB = 0x37,
182 CB_PERF_SEL_CC_RB_BC_EVENFRAG_VALID_READY = 0x38,
183 CB_PERF_SEL_CC_RB_BC_EVENFRAG_VALID_READYB = 0x39,
184 CB_PERF_SEL_CC_RB_BC_EVENFRAG_VALIDB_READY = 0x3a,
185 CB_PERF_SEL_CC_RB_BC_EVENFRAG_VALIDB_READYB = 0x3b,
186 CB_PERF_SEL_CC_RB_BC_ODDFRAG_VALID_READY = 0x3c,
187 CB_PERF_SEL_CC_RB_BC_ODDFRAG_VALID_READYB = 0x3d,
188 CB_PERF_SEL_CC_RB_BC_ODDFRAG_VALIDB_READY = 0x3e,
189 CB_PERF_SEL_CC_RB_BC_ODDFRAG_VALIDB_READYB = 0x3f,
190 CB_PERF_SEL_CC_BC_CS_FRAG_VALID = 0x40,
191 CB_PERF_SEL_CM_CACHE_HIT = 0x41,
192 CB_PERF_SEL_CM_CACHE_TAG_MISS = 0x42,
193 CB_PERF_SEL_CM_CACHE_SECTOR_MISS = 0x43,
194 CB_PERF_SEL_CM_CACHE_REEVICTION_STALL = 0x44,
195 CB_PERF_SEL_CM_CACHE_EVICT_NONZERO_INFLIGHT_STALL= 0x45,
196 CB_PERF_SEL_CM_CACHE_REPLACE_PENDING_EVICT_STALL = 0x46,
197 CB_PERF_SEL_CM_CACHE_INFLIGHT_COUNTER_MAXIMUM_STALL= 0x47,
198 CB_PERF_SEL_CM_CACHE_READ_OUTPUT_STALL = 0x48,
199 CB_PERF_SEL_CM_CACHE_WRITE_OUTPUT_STALL = 0x49,
200 CB_PERF_SEL_CM_CACHE_ACK_OUTPUT_STALL = 0x4a,
201 CB_PERF_SEL_CM_CACHE_STALL = 0x4b,
202 CB_PERF_SEL_CM_CACHE_FLUSH = 0x4c,
203 CB_PERF_SEL_CM_CACHE_TAGS_FLUSHED = 0x4d,
204 CB_PERF_SEL_CM_CACHE_SECTORS_FLUSHED = 0x4e,
205 CB_PERF_SEL_CM_CACHE_DIRTY_SECTORS_FLUSHED = 0x4f,
206 CB_PERF_SEL_FC_CACHE_HIT = 0x50,
207 CB_PERF_SEL_FC_CACHE_TAG_MISS = 0x51,
208 CB_PERF_SEL_FC_CACHE_SECTOR_MISS = 0x52,
209 CB_PERF_SEL_FC_CACHE_REEVICTION_STALL = 0x53,
210 CB_PERF_SEL_FC_CACHE_EVICT_NONZERO_INFLIGHT_STALL= 0x54,
211 CB_PERF_SEL_FC_CACHE_REPLACE_PENDING_EVICT_STALL = 0x55,
212 CB_PERF_SEL_FC_CACHE_INFLIGHT_COUNTER_MAXIMUM_STALL= 0x56,
213 CB_PERF_SEL_FC_CACHE_READ_OUTPUT_STALL = 0x57,
214 CB_PERF_SEL_FC_CACHE_WRITE_OUTPUT_STALL = 0x58,
215 CB_PERF_SEL_FC_CACHE_ACK_OUTPUT_STALL = 0x59,
216 CB_PERF_SEL_FC_CACHE_STALL = 0x5a,
217 CB_PERF_SEL_FC_CACHE_FLUSH = 0x5b,
218 CB_PERF_SEL_FC_CACHE_TAGS_FLUSHED = 0x5c,
219 CB_PERF_SEL_FC_CACHE_SECTORS_FLUSHED = 0x5d,
220 CB_PERF_SEL_FC_CACHE_DIRTY_SECTORS_FLUSHED = 0x5e,
221 CB_PERF_SEL_CC_CACHE_HIT = 0x5f,
222 CB_PERF_SEL_CC_CACHE_TAG_MISS = 0x60,
223 CB_PERF_SEL_CC_CACHE_SECTOR_MISS = 0x61,
224 CB_PERF_SEL_CC_CACHE_REEVICTION_STALL = 0x62,
225 CB_PERF_SEL_CC_CACHE_EVICT_NONZERO_INFLIGHT_STALL= 0x63,
226 CB_PERF_SEL_CC_CACHE_REPLACE_PENDING_EVICT_STALL = 0x64,
227 CB_PERF_SEL_CC_CACHE_INFLIGHT_COUNTER_MAXIMUM_STALL= 0x65,
228 CB_PERF_SEL_CC_CACHE_READ_OUTPUT_STALL = 0x66,
229 CB_PERF_SEL_CC_CACHE_WRITE_OUTPUT_STALL = 0x67,
230 CB_PERF_SEL_CC_CACHE_ACK_OUTPUT_STALL = 0x68,
231 CB_PERF_SEL_CC_CACHE_STALL = 0x69,
232 CB_PERF_SEL_CC_CACHE_FLUSH = 0x6a,
233 CB_PERF_SEL_CC_CACHE_TAGS_FLUSHED = 0x6b,
234 CB_PERF_SEL_CC_CACHE_SECTORS_FLUSHED = 0x6c,
235 CB_PERF_SEL_CC_CACHE_DIRTY_SECTORS_FLUSHED = 0x6d,
236 CB_PERF_SEL_CC_CACHE_WA_TO_RMW_CONVERSION = 0x6e,
237 CB_PERF_SEL_CC_CACHE_READS_SAVED_DUE_TO_DCC = 0x6f,
238 CB_PERF_SEL_CB_TAP_WRREQ_VALID_READY = 0x70,
239 CB_PERF_SEL_CB_TAP_WRREQ_VALID_READYB = 0x71,
240 CB_PERF_SEL_CB_TAP_WRREQ_VALIDB_READY = 0x72,
241 CB_PERF_SEL_CB_TAP_WRREQ_VALIDB_READYB = 0x73,
242 CB_PERF_SEL_CM_MC_WRITE_REQUEST = 0x74,
243 CB_PERF_SEL_FC_MC_WRITE_REQUEST = 0x75,
244 CB_PERF_SEL_CC_MC_WRITE_REQUEST = 0x76,
245 CB_PERF_SEL_CM_MC_WRITE_REQUESTS_IN_FLIGHT = 0x77,
246 CB_PERF_SEL_FC_MC_WRITE_REQUESTS_IN_FLIGHT = 0x78,
247 CB_PERF_SEL_CC_MC_WRITE_REQUESTS_IN_FLIGHT = 0x79,
248 CB_PERF_SEL_CB_TAP_RDREQ_VALID_READY = 0x7a,
249 CB_PERF_SEL_CB_TAP_RDREQ_VALID_READYB = 0x7b,
250 CB_PERF_SEL_CB_TAP_RDREQ_VALIDB_READY = 0x7c,
251 CB_PERF_SEL_CB_TAP_RDREQ_VALIDB_READYB = 0x7d,
252 CB_PERF_SEL_CM_MC_READ_REQUEST = 0x7e,
253 CB_PERF_SEL_FC_MC_READ_REQUEST = 0x7f,
254 CB_PERF_SEL_CC_MC_READ_REQUEST = 0x80,
255 CB_PERF_SEL_CM_MC_READ_REQUESTS_IN_FLIGHT = 0x81,
256 CB_PERF_SEL_FC_MC_READ_REQUESTS_IN_FLIGHT = 0x82,
257 CB_PERF_SEL_CC_MC_READ_REQUESTS_IN_FLIGHT = 0x83,
258 CB_PERF_SEL_CM_TQ_FULL = 0x84,
259 CB_PERF_SEL_CM_TQ_FIFO_TILE_RESIDENCY_STALL = 0x85,
260 CB_PERF_SEL_FC_QUAD_RDLAT_FIFO_FULL = 0x86,
261 CB_PERF_SEL_FC_TILE_RDLAT_FIFO_FULL = 0x87,
262 CB_PERF_SEL_FC_RDLAT_FIFO_QUAD_RESIDENCY_STALL = 0x88,
263 CB_PERF_SEL_FOP_FMASK_RAW_STALL = 0x89,
264 CB_PERF_SEL_FOP_FMASK_BYPASS_STALL = 0x8a,
265 CB_PERF_SEL_CC_SF_FULL = 0x8b,
266 CB_PERF_SEL_CC_RB_FULL = 0x8c,
267 CB_PERF_SEL_CC_EVENFIFO_QUAD_RESIDENCY_STALL = 0x8d,
268 CB_PERF_SEL_CC_ODDFIFO_QUAD_RESIDENCY_STALL = 0x8e,
269 CB_PERF_SEL_BLENDER_RAW_HAZARD_STALL = 0x8f,
270 CB_PERF_SEL_EVENT = 0x90,
271 CB_PERF_SEL_EVENT_CACHE_FLUSH_TS = 0x91,
272 CB_PERF_SEL_EVENT_CONTEXT_DONE = 0x92,
273 CB_PERF_SEL_EVENT_CACHE_FLUSH = 0x93,
274 CB_PERF_SEL_EVENT_CACHE_FLUSH_AND_INV_TS_EVENT = 0x94,
275 CB_PERF_SEL_EVENT_CACHE_FLUSH_AND_INV_EVENT = 0x95,
276 CB_PERF_SEL_EVENT_FLUSH_AND_INV_CB_DATA_TS = 0x96,
277 CB_PERF_SEL_EVENT_FLUSH_AND_INV_CB_META = 0x97,
278 CB_PERF_SEL_CC_SURFACE_SYNC = 0x98,
279 CB_PERF_SEL_CMASK_READ_DATA_0xC = 0x99,
280 CB_PERF_SEL_CMASK_READ_DATA_0xD = 0x9a,
281 CB_PERF_SEL_CMASK_READ_DATA_0xE = 0x9b,
282 CB_PERF_SEL_CMASK_READ_DATA_0xF = 0x9c,
283 CB_PERF_SEL_CMASK_WRITE_DATA_0xC = 0x9d,
284 CB_PERF_SEL_CMASK_WRITE_DATA_0xD = 0x9e,
285 CB_PERF_SEL_CMASK_WRITE_DATA_0xE = 0x9f,
286 CB_PERF_SEL_CMASK_WRITE_DATA_0xF = 0xa0,
287 CB_PERF_SEL_TWO_PROBE_QUAD_FRAGMENT = 0xa1,
288 CB_PERF_SEL_EXPORT_32_ABGR_QUAD_FRAGMENT = 0xa2,
289 CB_PERF_SEL_DUAL_SOURCE_COLOR_QUAD_FRAGMENT = 0xa3,
290 CB_PERF_SEL_QUAD_HAS_1_FRAGMENT_BEFORE_UPDATE = 0xa4,
291 CB_PERF_SEL_QUAD_HAS_2_FRAGMENTS_BEFORE_UPDATE = 0xa5,
292 CB_PERF_SEL_QUAD_HAS_3_FRAGMENTS_BEFORE_UPDATE = 0xa6,
293 CB_PERF_SEL_QUAD_HAS_4_FRAGMENTS_BEFORE_UPDATE = 0xa7,
294 CB_PERF_SEL_QUAD_HAS_5_FRAGMENTS_BEFORE_UPDATE = 0xa8,
295 CB_PERF_SEL_QUAD_HAS_6_FRAGMENTS_BEFORE_UPDATE = 0xa9,
296 CB_PERF_SEL_QUAD_HAS_7_FRAGMENTS_BEFORE_UPDATE = 0xaa,
297 CB_PERF_SEL_QUAD_HAS_8_FRAGMENTS_BEFORE_UPDATE = 0xab,
298 CB_PERF_SEL_QUAD_HAS_1_FRAGMENT_AFTER_UPDATE = 0xac,
299 CB_PERF_SEL_QUAD_HAS_2_FRAGMENTS_AFTER_UPDATE = 0xad,
300 CB_PERF_SEL_QUAD_HAS_3_FRAGMENTS_AFTER_UPDATE = 0xae,
301 CB_PERF_SEL_QUAD_HAS_4_FRAGMENTS_AFTER_UPDATE = 0xaf,
302 CB_PERF_SEL_QUAD_HAS_5_FRAGMENTS_AFTER_UPDATE = 0xb0,
303 CB_PERF_SEL_QUAD_HAS_6_FRAGMENTS_AFTER_UPDATE = 0xb1,
304 CB_PERF_SEL_QUAD_HAS_7_FRAGMENTS_AFTER_UPDATE = 0xb2,
305 CB_PERF_SEL_QUAD_HAS_8_FRAGMENTS_AFTER_UPDATE = 0xb3,
306 CB_PERF_SEL_QUAD_ADDED_1_FRAGMENT = 0xb4,
307 CB_PERF_SEL_QUAD_ADDED_2_FRAGMENTS = 0xb5,
308 CB_PERF_SEL_QUAD_ADDED_3_FRAGMENTS = 0xb6,
309 CB_PERF_SEL_QUAD_ADDED_4_FRAGMENTS = 0xb7,
310 CB_PERF_SEL_QUAD_ADDED_5_FRAGMENTS = 0xb8,
311 CB_PERF_SEL_QUAD_ADDED_6_FRAGMENTS = 0xb9,
312 CB_PERF_SEL_QUAD_ADDED_7_FRAGMENTS = 0xba,
313 CB_PERF_SEL_QUAD_REMOVED_1_FRAGMENT = 0xbb,
314 CB_PERF_SEL_QUAD_REMOVED_2_FRAGMENTS = 0xbc,
315 CB_PERF_SEL_QUAD_REMOVED_3_FRAGMENTS = 0xbd,
316 CB_PERF_SEL_QUAD_REMOVED_4_FRAGMENTS = 0xbe,
317 CB_PERF_SEL_QUAD_REMOVED_5_FRAGMENTS = 0xbf,
318 CB_PERF_SEL_QUAD_REMOVED_6_FRAGMENTS = 0xc0,
319 CB_PERF_SEL_QUAD_REMOVED_7_FRAGMENTS = 0xc1,
320 CB_PERF_SEL_QUAD_READS_FRAGMENT_0 = 0xc2,
321 CB_PERF_SEL_QUAD_READS_FRAGMENT_1 = 0xc3,
322 CB_PERF_SEL_QUAD_READS_FRAGMENT_2 = 0xc4,
323 CB_PERF_SEL_QUAD_READS_FRAGMENT_3 = 0xc5,
324 CB_PERF_SEL_QUAD_READS_FRAGMENT_4 = 0xc6,
325 CB_PERF_SEL_QUAD_READS_FRAGMENT_5 = 0xc7,
326 CB_PERF_SEL_QUAD_READS_FRAGMENT_6 = 0xc8,
327 CB_PERF_SEL_QUAD_READS_FRAGMENT_7 = 0xc9,
328 CB_PERF_SEL_QUAD_WRITES_FRAGMENT_0 = 0xca,
329 CB_PERF_SEL_QUAD_WRITES_FRAGMENT_1 = 0xcb,
330 CB_PERF_SEL_QUAD_WRITES_FRAGMENT_2 = 0xcc,
331 CB_PERF_SEL_QUAD_WRITES_FRAGMENT_3 = 0xcd,
332 CB_PERF_SEL_QUAD_WRITES_FRAGMENT_4 = 0xce,
333 CB_PERF_SEL_QUAD_WRITES_FRAGMENT_5 = 0xcf,
334 CB_PERF_SEL_QUAD_WRITES_FRAGMENT_6 = 0xd0,
335 CB_PERF_SEL_QUAD_WRITES_FRAGMENT_7 = 0xd1,
336 CB_PERF_SEL_QUAD_BLEND_OPT_DONT_READ_DST = 0xd2,
337 CB_PERF_SEL_QUAD_BLEND_OPT_BLEND_BYPASS = 0xd3,
338 CB_PERF_SEL_QUAD_BLEND_OPT_DISCARD_PIXELS = 0xd4,
339 CB_PERF_SEL_QUAD_DST_READ_COULD_HAVE_BEEN_OPTIMIZED= 0xd5,
340 CB_PERF_SEL_QUAD_BLENDING_COULD_HAVE_BEEN_BYPASSED= 0xd6,
341 CB_PERF_SEL_QUAD_COULD_HAVE_BEEN_DISCARDED = 0xd7,
342 CB_PERF_SEL_BLEND_OPT_PIXELS_RESULT_EQ_DEST = 0xd8,
343 CB_PERF_SEL_DRAWN_BUSY = 0xd9,
344 CB_PERF_SEL_TILE_TO_CMR_REGION_BUSY = 0xda,
345 CB_PERF_SEL_CMR_TO_FCR_REGION_BUSY = 0xdb,
346 CB_PERF_SEL_FCR_TO_CCR_REGION_BUSY = 0xdc,
347 CB_PERF_SEL_CCR_TO_CCW_REGION_BUSY = 0xdd,
348 CB_PERF_SEL_FC_PF_SLOW_MODE_QUAD_EMPTY_HALF_DROPPED= 0xde,
349 CB_PERF_SEL_FC_SEQUENCER_CLEAR = 0xdf,
350 CB_PERF_SEL_FC_SEQUENCER_ELIMINATE_FAST_CLEAR = 0xe0,
351 CB_PERF_SEL_FC_SEQUENCER_FMASK_DECOMPRESS = 0xe1,
352 CB_PERF_SEL_FC_SEQUENCER_FMASK_COMPRESSION_DISABLE= 0xe2,
353 CB_PERF_SEL_FC_KEYID_RDLAT_FIFO_FULL = 0xe3,
354 CB_PERF_SEL_FC_DOC_IS_STALLED = 0xe4,
355 CB_PERF_SEL_FC_DOC_MRTS_NOT_COMBINED = 0xe5,
356 CB_PERF_SEL_FC_DOC_MRTS_COMBINED = 0xe6,
357 CB_PERF_SEL_FC_DOC_QTILE_CAM_MISS = 0xe7,
358 CB_PERF_SEL_FC_DOC_QTILE_CAM_HIT = 0xe8,
359 CB_PERF_SEL_FC_DOC_CLINE_CAM_MISS = 0xe9,
360 CB_PERF_SEL_FC_DOC_CLINE_CAM_HIT = 0xea,
361 CB_PERF_SEL_FC_DOC_QUAD_PTR_FIFO_IS_FULL = 0xeb,
362 CB_PERF_SEL_FC_DOC_OVERWROTE_1_SECTOR = 0xec,
363 CB_PERF_SEL_FC_DOC_OVERWROTE_2_SECTORS = 0xed,
364 CB_PERF_SEL_FC_DOC_OVERWROTE_3_SECTORS = 0xee,
365 CB_PERF_SEL_FC_DOC_OVERWROTE_4_SECTORS = 0xef,
366 CB_PERF_SEL_FC_DOC_TOTAL_OVERWRITTEN_SECTORS = 0xf0,
367 CB_PERF_SEL_FC_DCC_CACHE_HIT = 0xf1,
368 CB_PERF_SEL_FC_DCC_CACHE_TAG_MISS = 0xf2,
369 CB_PERF_SEL_FC_DCC_CACHE_SECTOR_MISS = 0xf3,
370 CB_PERF_SEL_FC_DCC_CACHE_REEVICTION_STALL = 0xf4,
371 CB_PERF_SEL_FC_DCC_CACHE_EVICT_NONZERO_INFLIGHT_STALL= 0xf5,
372 CB_PERF_SEL_FC_DCC_CACHE_REPLACE_PENDING_EVICT_STALL= 0xf6,
373 CB_PERF_SEL_FC_DCC_CACHE_INFLIGHT_COUNTER_MAXIMUM_STALL= 0xf7,
374 CB_PERF_SEL_FC_DCC_CACHE_READ_OUTPUT_STALL = 0xf8,
375 CB_PERF_SEL_FC_DCC_CACHE_WRITE_OUTPUT_STALL = 0xf9,
376 CB_PERF_SEL_FC_DCC_CACHE_ACK_OUTPUT_STALL = 0xfa,
377 CB_PERF_SEL_FC_DCC_CACHE_STALL = 0xfb,
378 CB_PERF_SEL_FC_DCC_CACHE_FLUSH = 0xfc,
379 CB_PERF_SEL_FC_DCC_CACHE_TAGS_FLUSHED = 0xfd,
380 CB_PERF_SEL_FC_DCC_CACHE_SECTORS_FLUSHED = 0xfe,
381 CB_PERF_SEL_FC_DCC_CACHE_DIRTY_SECTORS_FLUSHED = 0xff,
382 CB_PERF_SEL_CC_DCC_BEYOND_TILE_SPLIT = 0x100,
383 CB_PERF_SEL_FC_MC_DCC_WRITE_REQUEST = 0x101,
384 CB_PERF_SEL_FC_MC_DCC_WRITE_REQUESTS_IN_FLIGHT = 0x102,
385 CB_PERF_SEL_FC_MC_DCC_READ_REQUEST = 0x103,
386 CB_PERF_SEL_FC_MC_DCC_READ_REQUESTS_IN_FLIGHT = 0x104,
387 CB_PERF_SEL_CC_DCC_RDREQ_STALL = 0x105,
388 CB_PERF_SEL_CC_DCC_DECOMPRESS_TIDS_IN = 0x106,
389 CB_PERF_SEL_CC_DCC_DECOMPRESS_TIDS_OUT = 0x107,
390 CB_PERF_SEL_CC_DCC_COMPRESS_TIDS_IN = 0x108,
391 CB_PERF_SEL_CC_DCC_COMPRESS_TIDS_OUT = 0x109,
392 CB_PERF_SEL_FC_DCC_KEY_VALUE__CLEAR = 0x10a,
393 CB_PERF_SEL_CC_DCC_KEY_VALUE__4_BLOCKS__2TO1 = 0x10b,
394 CB_PERF_SEL_CC_DCC_KEY_VALUE__3BLOCKS_2TO1__1BLOCK_2TO2= 0x10c,
395 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO1__1BLOCK_2TO2__1BLOCK_2TO1= 0x10d,
396 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_2TO2__2BLOCKS_2TO1= 0x10e,
397 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__3BLOCKS_2TO1= 0x10f,
398 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO1__2BLOCKS_2TO2= 0x110,
399 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__2BLOCKS_2TO2__1BLOCK_2TO1= 0x111,
400 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_2TO2__1BLOCK_2TO1__1BLOCK_2TO2= 0x112,
401 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_2TO1__1BLOCK_2TO2__1BLOCK_2TO1= 0x113,
402 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO2__2BLOCKS_2TO1= 0x114,
403 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__2BLOCKS_2TO1__1BLOCK_2TO2= 0x115,
404 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__3BLOCKS_2TO2= 0x116,
405 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_2TO1__2BLOCKS_2TO2= 0x117,
406 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO2__1BLOCK_2TO1__1BLOCK_2TO2= 0x118,
407 CB_PERF_SEL_CC_DCC_KEY_VALUE__3BLOCKS_2TO2__1BLOCK_2TO1= 0x119,
408 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_4TO1 = 0x11a,
409 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO1__1BLOCK_4TO2= 0x11b,
410 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO1__1BLOCK_4TO3= 0x11c,
411 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO1__1BLOCK_4TO4= 0x11d,
412 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO2__1BLOCK_4TO1= 0x11e,
413 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_4TO2 = 0x11f,
414 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO2__1BLOCK_4TO3= 0x120,
415 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO2__1BLOCK_4TO4= 0x121,
416 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO3__1BLOCK_4TO1= 0x122,
417 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO3__1BLOCK_4TO2= 0x123,
418 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_4TO3 = 0x124,
419 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO3__1BLOCK_4TO4= 0x125,
420 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO4__1BLOCK_4TO1= 0x126,
421 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO4__1BLOCK_4TO2= 0x127,
422 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO4__1BLOCK_4TO3= 0x128,
423 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO1__1BLOCK_4TO1= 0x129,
424 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO1__1BLOCK_4TO2= 0x12a,
425 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO1__1BLOCK_4TO3= 0x12b,
426 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO1__1BLOCK_4TO4= 0x12c,
427 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_2TO2__1BLOCK_4TO1= 0x12d,
428 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_2TO2__1BLOCK_4TO2= 0x12e,
429 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_2TO2__1BLOCK_4TO3= 0x12f,
430 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_2TO2__1BLOCK_4TO4= 0x130,
431 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_2TO1__1BLOCK_4TO1= 0x131,
432 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_2TO1__1BLOCK_4TO2= 0x132,
433 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_2TO1__1BLOCK_4TO3= 0x133,
434 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_2TO1__1BLOCK_4TO4= 0x134,
435 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO2__1BLOCK_4TO1= 0x135,
436 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO2__1BLOCK_4TO2= 0x136,
437 CB_PERF_SEL_CC_DCC_KEY_VALUE__2BLOCKS_2TO2__1BLOCK_4TO3= 0x137,
438 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_4TO1__1BLOCK_2TO1= 0x138,
439 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_4TO2__1BLOCK_2TO1= 0x139,
440 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_4TO3__1BLOCK_2TO1= 0x13a,
441 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_4TO4__1BLOCK_2TO1= 0x13b,
442 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_4TO1__1BLOCK_2TO1= 0x13c,
443 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_4TO2__1BLOCK_2TO1= 0x13d,
444 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_4TO3__1BLOCK_2TO1= 0x13e,
445 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_4TO4__1BLOCK_2TO1= 0x13f,
446 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_4TO1__1BLOCK_2TO2= 0x140,
447 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_4TO2__1BLOCK_2TO2= 0x141,
448 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_4TO3__1BLOCK_2TO2= 0x142,
449 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_4TO4__1BLOCK_2TO2= 0x143,
450 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_4TO1__1BLOCK_2TO2= 0x144,
451 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_4TO2__1BLOCK_2TO2= 0x145,
452 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_4TO3__1BLOCK_2TO2= 0x146,
453 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO1__2BLOCKS_2TO1= 0x147,
454 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO2__2BLOCKS_2TO1= 0x148,
455 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO3__2BLOCKS_2TO1= 0x149,
456 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO4__2BLOCKS_2TO1= 0x14a,
457 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO1__2BLOCKS_2TO2= 0x14b,
458 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO2__2BLOCKS_2TO2= 0x14c,
459 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO3__2BLOCKS_2TO2= 0x14d,
460 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO1__1BLOCK_2TO1__1BLOCK_2TO2= 0x14e,
461 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO2__1BLOCK_2TO1__1BLOCK_2TO2= 0x14f,
462 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO3__1BLOCK_2TO1__1BLOCK_2TO2= 0x150,
463 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO4__1BLOCK_2TO1__1BLOCK_2TO2= 0x151,
464 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO1__1BLOCK_2TO2__1BLOCK_2TO1= 0x152,
465 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO2__1BLOCK_2TO2__1BLOCK_2TO1= 0x153,
466 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO3__1BLOCK_2TO2__1BLOCK_2TO1= 0x154,
467 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_4TO4__1BLOCK_2TO2__1BLOCK_2TO1= 0x155,
468 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_6TO1= 0x156,
469 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_6TO2= 0x157,
470 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_6TO3= 0x158,
471 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_6TO4= 0x159,
472 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_6TO5= 0x15a,
473 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__1BLOCK_6TO6= 0x15b,
474 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__INV0 = 0x15c,
475 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO1__INV1 = 0x15d,
476 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_6TO1= 0x15e,
477 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_6TO2= 0x15f,
478 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_6TO3= 0x160,
479 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_6TO4= 0x161,
480 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__1BLOCK_6TO5= 0x162,
481 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__INV0 = 0x163,
482 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_2TO2__INV1 = 0x164,
483 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO1__1BLOCK_2TO1= 0x165,
484 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO2__1BLOCK_2TO1= 0x166,
485 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO3__1BLOCK_2TO1= 0x167,
486 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO4__1BLOCK_2TO1= 0x168,
487 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO5__1BLOCK_2TO1= 0x169,
488 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO6__1BLOCK_2TO1= 0x16a,
489 CB_PERF_SEL_CC_DCC_KEY_VALUE__INV0__1BLOCK_2TO1 = 0x16b,
490 CB_PERF_SEL_CC_DCC_KEY_VALUE__INV1__1BLOCK_2TO1 = 0x16c,
491 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO1__1BLOCK_2TO2= 0x16d,
492 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO2__1BLOCK_2TO2= 0x16e,
493 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO3__1BLOCK_2TO2= 0x16f,
494 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO4__1BLOCK_2TO2= 0x170,
495 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_6TO5__1BLOCK_2TO2= 0x171,
496 CB_PERF_SEL_CC_DCC_KEY_VALUE__INV0__1BLOCK_2TO2 = 0x172,
497 CB_PERF_SEL_CC_DCC_KEY_VALUE__INV1__1BLOCK_2TO2 = 0x173,
498 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_8TO1 = 0x174,
499 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_8TO2 = 0x175,
500 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_8TO3 = 0x176,
501 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_8TO4 = 0x177,
502 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_8TO5 = 0x178,
503 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_8TO6 = 0x179,
504 CB_PERF_SEL_CC_DCC_KEY_VALUE__1BLOCK_8TO7 = 0x17a,
505 CB_PERF_SEL_CC_DCC_KEY_VALUE__UNCOMPRESSED = 0x17b,
506 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_2TO1 = 0x17c,
507 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_4TO1 = 0x17d,
508 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_4TO2 = 0x17e,
509 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_4TO3 = 0x17f,
510 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_6TO1 = 0x180,
511 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_6TO2 = 0x181,
512 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_6TO3 = 0x182,
513 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_6TO4 = 0x183,
514 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_6TO5 = 0x184,
515 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_8TO1 = 0x185,
516 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_8TO2 = 0x186,
517 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_8TO3 = 0x187,
518 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_8TO4 = 0x188,
519 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_8TO5 = 0x189,
520 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_8TO6 = 0x18a,
521 CB_PERF_SEL_CC_DCC_COMPRESS_RATIO_8TO7 = 0x18b,
522 } CBPerfSel;
523 typedef enum CBPerfOpFilterSel {
524 CB_PERF_OP_FILTER_SEL_WRITE_ONLY = 0x0,
525 CB_PERF_OP_FILTER_SEL_NEEDS_DESTINATION = 0x1,
526 CB_PERF_OP_FILTER_SEL_RESOLVE = 0x2,
527 CB_PERF_OP_FILTER_SEL_DECOMPRESS = 0x3,
528 CB_PERF_OP_FILTER_SEL_FMASK_DECOMPRESS = 0x4,
529 CB_PERF_OP_FILTER_SEL_ELIMINATE_FAST_CLEAR = 0x5,
530 } CBPerfOpFilterSel;
531 typedef enum CBPerfClearFilterSel {
532 CB_PERF_CLEAR_FILTER_SEL_NONCLEAR = 0x0,
533 CB_PERF_CLEAR_FILTER_SEL_CLEAR = 0x1,
534 } CBPerfClearFilterSel;
535 typedef enum CP_RING_ID {
536 RINGID0 = 0x0,
537 RINGID1 = 0x1,
538 RINGID2 = 0x2,
539 RINGID3 = 0x3,
540 } CP_RING_ID;
541 typedef enum CP_PIPE_ID {
542 PIPE_ID0 = 0x0,
543 PIPE_ID1 = 0x1,
544 PIPE_ID2 = 0x2,
545 PIPE_ID3 = 0x3,
546 } CP_PIPE_ID;
547 typedef enum CP_ME_ID {
548 ME_ID0 = 0x0,
549 ME_ID1 = 0x1,
550 ME_ID2 = 0x2,
551 ME_ID3 = 0x3,
552 } CP_ME_ID;
553 typedef enum SPM_PERFMON_STATE {
554 STRM_PERFMON_STATE_DISABLE_AND_RESET = 0x0,
555 STRM_PERFMON_STATE_START_COUNTING = 0x1,
556 STRM_PERFMON_STATE_STOP_COUNTING = 0x2,
557 STRM_PERFMON_STATE_RESERVED_3 = 0x3,
558 STRM_PERFMON_STATE_DISABLE_AND_RESET_PHANTOM = 0x4,
559 STRM_PERFMON_STATE_COUNT_AND_DUMP_PHANTOM = 0x5,
560 } SPM_PERFMON_STATE;
561 typedef enum CP_PERFMON_STATE {
562 CP_PERFMON_STATE_DISABLE_AND_RESET = 0x0,
563 CP_PERFMON_STATE_START_COUNTING = 0x1,
564 CP_PERFMON_STATE_STOP_COUNTING = 0x2,
565 CP_PERFMON_STATE_RESERVED_3 = 0x3,
566 CP_PERFMON_STATE_DISABLE_AND_RESET_PHANTOM = 0x4,
567 CP_PERFMON_STATE_COUNT_AND_DUMP_PHANTOM = 0x5,
568 } CP_PERFMON_STATE;
569 typedef enum CP_PERFMON_ENABLE_MODE {
570 CP_PERFMON_ENABLE_MODE_ALWAYS_COUNT = 0x0,
571 CP_PERFMON_ENABLE_MODE_RESERVED_1 = 0x1,
572 CP_PERFMON_ENABLE_MODE_COUNT_CONTEXT_TRUE = 0x2,
573 CP_PERFMON_ENABLE_MODE_COUNT_CONTEXT_FALSE = 0x3,
574 } CP_PERFMON_ENABLE_MODE;
575 typedef enum CPG_PERFCOUNT_SEL {
576 CPG_PERF_SEL_ALWAYS_COUNT = 0x0,
577 CPG_PERF_SEL_RBIU_FIFO_FULL = 0x1,
578 CPG_PERF_SEL_CSF_RTS_BUT_MIU_NOT_RTR = 0x2,
579 CPG_PERF_SEL_CSF_ST_BASE_SIZE_FIFO_FULL = 0x3,
580 CPG_PERF_SEL_CP_GRBM_DWORDS_SENT = 0x4,
581 CPG_PERF_SEL_ME_PARSER_BUSY = 0x5,
582 CPG_PERF_SEL_COUNT_TYPE0_PACKETS = 0x6,
583 CPG_PERF_SEL_COUNT_TYPE3_PACKETS = 0x7,
584 CPG_PERF_SEL_CSF_FETCHING_CMD_BUFFERS = 0x8,
585 CPG_PERF_SEL_CP_GRBM_OUT_OF_CREDITS = 0x9,
586 CPG_PERF_SEL_CP_PFP_GRBM_OUT_OF_CREDITS = 0xa,
587 CPG_PERF_SEL_CP_GDS_GRBM_OUT_OF_CREDITS = 0xb,
588 CPG_PERF_SEL_RCIU_STALLED_ON_ME_READ = 0xc,
589 CPG_PERF_SEL_RCIU_STALLED_ON_DMA_READ = 0xd,
590 CPG_PERF_SEL_SSU_STALLED_ON_ACTIVE_CNTX = 0xe,
591 CPG_PERF_SEL_SSU_STALLED_ON_CLEAN_SIGNALS = 0xf,
592 CPG_PERF_SEL_QU_STALLED_ON_EOP_DONE_PULSE = 0x10,
593 CPG_PERF_SEL_QU_STALLED_ON_EOP_DONE_WR_CONFIRM = 0x11,
594 CPG_PERF_SEL_PFP_STALLED_ON_CSF_READY = 0x12,
595 CPG_PERF_SEL_PFP_STALLED_ON_MEQ_READY = 0x13,
596 CPG_PERF_SEL_PFP_STALLED_ON_RCIU_READY = 0x14,
597 CPG_PERF_SEL_PFP_STALLED_FOR_DATA_FROM_ROQ = 0x15,
598 CPG_PERF_SEL_ME_STALLED_FOR_DATA_FROM_PFP = 0x16,
599 CPG_PERF_SEL_ME_STALLED_FOR_DATA_FROM_STQ = 0x17,
600 CPG_PERF_SEL_ME_STALLED_ON_NO_AVAIL_GFX_CNTX = 0x18,
601 CPG_PERF_SEL_ME_STALLED_WRITING_TO_RCIU = 0x19,
602 CPG_PERF_SEL_ME_STALLED_WRITING_CONSTANTS = 0x1a,
603 CPG_PERF_SEL_ME_STALLED_ON_PARTIAL_FLUSH = 0x1b,
604 CPG_PERF_SEL_ME_WAIT_ON_CE_COUNTER = 0x1c,
605 CPG_PERF_SEL_ME_WAIT_ON_AVAIL_BUFFER = 0x1d,
606 CPG_PERF_SEL_SEMAPHORE_BUSY_POLLING_FOR_PASS = 0x1e,
607 CPG_PERF_SEL_LOAD_STALLED_ON_SET_COHERENCY = 0x1f,
608 CPG_PERF_SEL_DYNAMIC_CLK_VALID = 0x20,
609 CPG_PERF_SEL_REGISTER_CLK_VALID = 0x21,
610 CPG_PERF_SEL_MIU_WRITE_REQUEST_SENT = 0x22,
611 CPG_PERF_SEL_MIU_READ_REQUEST_SENT = 0x23,
612 CPG_PERF_SEL_CE_STALL_RAM_DUMP = 0x24,
613 CPG_PERF_SEL_CE_STALL_RAM_WRITE = 0x25,
614 CPG_PERF_SEL_CE_STALL_ON_INC_FIFO = 0x26,
615 CPG_PERF_SEL_CE_STALL_ON_WR_RAM_FIFO = 0x27,
616 CPG_PERF_SEL_CE_STALL_ON_DATA_FROM_MIU = 0x28,
617 CPG_PERF_SEL_CE_STALL_ON_DATA_FROM_ROQ = 0x29,
618 CPG_PERF_SEL_CE_STALL_ON_CE_BUFFER_FLAG = 0x2a,
619 CPG_PERF_SEL_CE_STALL_ON_DE_COUNTER = 0x2b,
620 CPG_PERF_SEL_TCIU_STALL_WAIT_ON_FREE = 0x2c,
621 CPG_PERF_SEL_TCIU_STALL_WAIT_ON_TAGS = 0x2d,
622 CPG_PERF_SEL_ATCL2IU_STALL_WAIT_ON_FREE = 0x2e,
623 CPG_PERF_SEL_ATCL2IU_STALL_WAIT_ON_TAGS = 0x2f,
624 CPG_PERF_SEL_ATCL1_STALL_ON_TRANSLATION = 0x30,
625 } CPG_PERFCOUNT_SEL;
626 typedef enum CPF_PERFCOUNT_SEL {
627 CPF_PERF_SEL_ALWAYS_COUNT = 0x0,
628 CPF_PERF_SEL_MIU_STALLED_WAITING_RDREQ_FREE = 0x1,
629 CPF_PERF_SEL_TCIU_STALLED_WAITING_ON_FREE = 0x2,
630 CPF_PERF_SEL_TCIU_STALLED_WAITING_ON_TAGS = 0x3,
631 CPF_PERF_SEL_CSF_BUSY_FOR_FETCHING_RING = 0x4,
632 CPF_PERF_SEL_CSF_BUSY_FOR_FETCHING_IB1 = 0x5,
633 CPF_PERF_SEL_CSF_BUSY_FOR_FETCHING_IB2 = 0x6,
634 CPF_PERF_SEL_CSF_BUSY_FOR_FECTHINC_STATE = 0x7,
635 CPF_PERF_SEL_MIU_BUSY_FOR_OUTSTANDING_TAGS = 0x8,
636 CPF_PERF_SEL_CSF_RTS_MIU_NOT_RTR = 0x9,
637 CPF_PERF_SEL_CSF_STATE_FIFO_NOT_RTR = 0xa,
638 CPF_PERF_SEL_CSF_FETCHING_CMD_BUFFERS = 0xb,
639 CPF_PERF_SEL_GRBM_DWORDS_SENT = 0xc,
640 CPF_PERF_SEL_DYNAMIC_CLOCK_VALID = 0xd,
641 CPF_PERF_SEL_REGISTER_CLOCK_VALID = 0xe,
642 CPF_PERF_SEL_MIU_WRITE_REQUEST_SEND = 0xf,
643 CPF_PERF_SEL_MIU_READ_REQUEST_SEND = 0x10,
644 CPF_PERF_SEL_ATCL2IU_STALL_WAIT_ON_FREE = 0x11,
645 CPF_PERF_SEL_ATCL2IU_STALL_WAIT_ON_TAGS = 0x12,
646 CPF_PERF_SEL_ATCL1_STALL_ON_TRANSLATION = 0x13,
647 } CPF_PERFCOUNT_SEL;
648 typedef enum CPC_PERFCOUNT_SEL {
649 CPC_PERF_SEL_ALWAYS_COUNT = 0x0,
650 CPC_PERF_SEL_RCIU_STALL_WAIT_ON_FREE = 0x1,
651 CPC_PERF_SEL_RCIU_STALL_PRIV_VIOLATION = 0x2,
652 CPC_PERF_SEL_MIU_STALL_ON_RDREQ_FREE = 0x3,
653 CPC_PERF_SEL_MIU_STALL_ON_WRREQ_FREE = 0x4,
654 CPC_PERF_SEL_TCIU_STALL_WAIT_ON_FREE = 0x5,
655 CPC_PERF_SEL_ME1_STALL_WAIT_ON_RCIU_READY = 0x6,
656 CPC_PERF_SEL_ME1_STALL_WAIT_ON_RCIU_READY_PERF = 0x7,
657 CPC_PERF_SEL_ME1_STALL_WAIT_ON_RCIU_READ = 0x8,
658 CPC_PERF_SEL_ME1_STALL_WAIT_ON_MIU_READ = 0x9,
659 CPC_PERF_SEL_ME1_STALL_WAIT_ON_MIU_WRITE = 0xa,
660 CPC_PERF_SEL_ME1_STALL_ON_DATA_FROM_ROQ = 0xb,
661 CPC_PERF_SEL_ME1_STALL_ON_DATA_FROM_ROQ_PERF = 0xc,
662 CPC_PERF_SEL_ME1_BUSY_FOR_PACKET_DECODE = 0xd,
663 CPC_PERF_SEL_ME2_STALL_WAIT_ON_RCIU_READY = 0xe,
664 CPC_PERF_SEL_ME2_STALL_WAIT_ON_RCIU_READY_PERF = 0xf,
665 CPC_PERF_SEL_ME2_STALL_WAIT_ON_RCIU_READ = 0x10,
666 CPC_PERF_SEL_ME2_STALL_WAIT_ON_MIU_READ = 0x11,
667 CPC_PERF_SEL_ME2_STALL_WAIT_ON_MIU_WRITE = 0x12,
668 CPC_PERF_SEL_ME2_STALL_ON_DATA_FROM_ROQ = 0x13,
669 CPC_PERF_SEL_ME2_STALL_ON_DATA_FROM_ROQ_PERF = 0x14,
670 CPC_PERF_SEL_ME2_BUSY_FOR_PACKET_DECODE = 0x15,
671 CPC_PERF_SEL_ATCL2IU_STALL_WAIT_ON_FREE = 0x16,
672 CPC_PERF_SEL_ATCL2IU_STALL_WAIT_ON_TAGS = 0x17,
673 CPC_PERF_SEL_ATCL1_STALL_ON_TRANSLATION = 0x18,
674 } CPC_PERFCOUNT_SEL;
675 typedef enum CP_ALPHA_TAG_RAM_SEL {
676 CPG_TAG_RAM = 0x0,
677 CPC_TAG_RAM = 0x1,
678 CPF_TAG_RAM = 0x2,
679 RSV_TAG_RAM = 0x3,
680 } CP_ALPHA_TAG_RAM_SEL;
681 #define SEM_ECC_ERROR 0x0
682 #define SEM_RESERVED 0x1
683 #define SEM_FAILED 0x2
684 #define SEM_PASSED 0x3
685 #define IQ_QUEUE_SLEEP 0x0
686 #define IQ_OFFLOAD_RETRY 0x1
687 #define IQ_SCH_WAVE_MSG 0x2
688 #define IQ_SEM_REARM 0x3
689 #define IQ_DEQUEUE_RETRY 0x4
690 #define IQ_INTR_TYPE_PQ 0x0
691 #define IQ_INTR_TYPE_IB 0x1
692 #define IQ_INTR_TYPE_MQD 0x2
693 #define VMID_SZ 0x4
694 #define CONFIG_SPACE_START 0x2000
695 #define CONFIG_SPACE_END 0x9fff
696 #define CONFIG_SPACE1_START 0x2000
697 #define CONFIG_SPACE1_END 0x2bff
698 #define CONFIG_SPACE2_START 0x3000
699 #define CONFIG_SPACE2_END 0x9fff
700 #define UCONFIG_SPACE_START 0xc000
701 #define UCONFIG_SPACE_END 0xffff
702 #define PERSISTENT_SPACE_START 0x2c00
703 #define PERSISTENT_SPACE_END 0x2fff
704 #define CONTEXT_SPACE_START 0xa000
705 #define CONTEXT_SPACE_END 0xbfff
706 typedef enum ForceControl {
707 FORCE_OFF = 0x0,
708 FORCE_ENABLE = 0x1,
709 FORCE_DISABLE = 0x2,
710 FORCE_RESERVED = 0x3,
711 } ForceControl;
712 typedef enum ZSamplePosition {
713 Z_SAMPLE_CENTER = 0x0,
714 Z_SAMPLE_CENTROID = 0x1,
715 } ZSamplePosition;
716 typedef enum ZOrder {
717 LATE_Z = 0x0,
718 EARLY_Z_THEN_LATE_Z = 0x1,
719 RE_Z = 0x2,
720 EARLY_Z_THEN_RE_Z = 0x3,
721 } ZOrder;
722 typedef enum ZpassControl {
723 ZPASS_DISABLE = 0x0,
724 ZPASS_SAMPLES = 0x1,
725 ZPASS_PIXELS = 0x2,
726 } ZpassControl;
727 typedef enum ZModeForce {
728 NO_FORCE = 0x0,
729 FORCE_EARLY_Z = 0x1,
730 FORCE_LATE_Z = 0x2,
731 FORCE_RE_Z = 0x3,
732 } ZModeForce;
733 typedef enum ZLimitSumm {
734 FORCE_SUMM_OFF = 0x0,
735 FORCE_SUMM_MINZ = 0x1,
736 FORCE_SUMM_MAXZ = 0x2,
737 FORCE_SUMM_BOTH = 0x3,
738 } ZLimitSumm;
739 typedef enum CompareFrag {
740 FRAG_NEVER = 0x0,
741 FRAG_LESS = 0x1,
742 FRAG_EQUAL = 0x2,
743 FRAG_LEQUAL = 0x3,
744 FRAG_GREATER = 0x4,
745 FRAG_NOTEQUAL = 0x5,
746 FRAG_GEQUAL = 0x6,
747 FRAG_ALWAYS = 0x7,
748 } CompareFrag;
749 typedef enum StencilOp {
750 STENCIL_KEEP = 0x0,
751 STENCIL_ZERO = 0x1,
752 STENCIL_ONES = 0x2,
753 STENCIL_REPLACE_TEST = 0x3,
754 STENCIL_REPLACE_OP = 0x4,
755 STENCIL_ADD_CLAMP = 0x5,
756 STENCIL_SUB_CLAMP = 0x6,
757 STENCIL_INVERT = 0x7,
758 STENCIL_ADD_WRAP = 0x8,
759 STENCIL_SUB_WRAP = 0x9,
760 STENCIL_AND = 0xa,
761 STENCIL_OR = 0xb,
762 STENCIL_XOR = 0xc,
763 STENCIL_NAND = 0xd,
764 STENCIL_NOR = 0xe,
765 STENCIL_XNOR = 0xf,
766 } StencilOp;
767 typedef enum ConservativeZExport {
768 EXPORT_ANY_Z = 0x0,
769 EXPORT_LESS_THAN_Z = 0x1,
770 EXPORT_GREATER_THAN_Z = 0x2,
771 EXPORT_RESERVED = 0x3,
772 } ConservativeZExport;
773 typedef enum DbPSLControl {
774 PSLC_AUTO = 0x0,
775 PSLC_ON_HANG_ONLY = 0x1,
776 PSLC_ASAP = 0x2,
777 PSLC_COUNTDOWN = 0x3,
778 } DbPSLControl;
779 typedef enum PerfCounter_Vals {
780 DB_PERF_SEL_SC_DB_tile_sends = 0x0,
781 DB_PERF_SEL_SC_DB_tile_busy = 0x1,
782 DB_PERF_SEL_SC_DB_tile_stalls = 0x2,
783 DB_PERF_SEL_SC_DB_tile_events = 0x3,
784 DB_PERF_SEL_SC_DB_tile_tiles = 0x4,
785 DB_PERF_SEL_SC_DB_tile_covered = 0x5,
786 DB_PERF_SEL_hiz_tc_read_starved = 0x6,
787 DB_PERF_SEL_hiz_tc_write_stall = 0x7,
788 DB_PERF_SEL_hiz_qtiles_culled = 0x8,
789 DB_PERF_SEL_his_qtiles_culled = 0x9,
790 DB_PERF_SEL_DB_SC_tile_sends = 0xa,
791 DB_PERF_SEL_DB_SC_tile_busy = 0xb,
792 DB_PERF_SEL_DB_SC_tile_stalls = 0xc,
793 DB_PERF_SEL_DB_SC_tile_df_stalls = 0xd,
794 DB_PERF_SEL_DB_SC_tile_tiles = 0xe,
795 DB_PERF_SEL_DB_SC_tile_culled = 0xf,
796 DB_PERF_SEL_DB_SC_tile_hier_kill = 0x10,
797 DB_PERF_SEL_DB_SC_tile_fast_ops = 0x11,
798 DB_PERF_SEL_DB_SC_tile_no_ops = 0x12,
799 DB_PERF_SEL_DB_SC_tile_tile_rate = 0x13,
800 DB_PERF_SEL_DB_SC_tile_ssaa_kill = 0x14,
801 DB_PERF_SEL_DB_SC_tile_fast_z_ops = 0x15,
802 DB_PERF_SEL_DB_SC_tile_fast_stencil_ops = 0x16,
803 DB_PERF_SEL_SC_DB_quad_sends = 0x17,
804 DB_PERF_SEL_SC_DB_quad_busy = 0x18,
805 DB_PERF_SEL_SC_DB_quad_squads = 0x19,
806 DB_PERF_SEL_SC_DB_quad_tiles = 0x1a,
807 DB_PERF_SEL_SC_DB_quad_pixels = 0x1b,
808 DB_PERF_SEL_SC_DB_quad_killed_tiles = 0x1c,
809 DB_PERF_SEL_DB_SC_quad_sends = 0x1d,
810 DB_PERF_SEL_DB_SC_quad_busy = 0x1e,
811 DB_PERF_SEL_DB_SC_quad_stalls = 0x1f,
812 DB_PERF_SEL_DB_SC_quad_tiles = 0x20,
813 DB_PERF_SEL_DB_SC_quad_lit_quad = 0x21,
814 DB_PERF_SEL_DB_CB_tile_sends = 0x22,
815 DB_PERF_SEL_DB_CB_tile_busy = 0x23,
816 DB_PERF_SEL_DB_CB_tile_stalls = 0x24,
817 DB_PERF_SEL_SX_DB_quad_sends = 0x25,
818 DB_PERF_SEL_SX_DB_quad_busy = 0x26,
819 DB_PERF_SEL_SX_DB_quad_stalls = 0x27,
820 DB_PERF_SEL_SX_DB_quad_quads = 0x28,
821 DB_PERF_SEL_SX_DB_quad_pixels = 0x29,
822 DB_PERF_SEL_SX_DB_quad_exports = 0x2a,
823 DB_PERF_SEL_SH_quads_outstanding_sum = 0x2b,
824 DB_PERF_SEL_DB_CB_lquad_sends = 0x2c,
825 DB_PERF_SEL_DB_CB_lquad_busy = 0x2d,
826 DB_PERF_SEL_DB_CB_lquad_stalls = 0x2e,
827 DB_PERF_SEL_DB_CB_lquad_quads = 0x2f,
828 DB_PERF_SEL_tile_rd_sends = 0x30,
829 DB_PERF_SEL_mi_tile_rd_outstanding_sum = 0x31,
830 DB_PERF_SEL_quad_rd_sends = 0x32,
831 DB_PERF_SEL_quad_rd_busy = 0x33,
832 DB_PERF_SEL_quad_rd_mi_stall = 0x34,
833 DB_PERF_SEL_quad_rd_rw_collision = 0x35,
834 DB_PERF_SEL_quad_rd_tag_stall = 0x36,
835 DB_PERF_SEL_quad_rd_32byte_reqs = 0x37,
836 DB_PERF_SEL_quad_rd_panic = 0x38,
837 DB_PERF_SEL_mi_quad_rd_outstanding_sum = 0x39,
838 DB_PERF_SEL_quad_rdret_sends = 0x3a,
839 DB_PERF_SEL_quad_rdret_busy = 0x3b,
840 DB_PERF_SEL_tile_wr_sends = 0x3c,
841 DB_PERF_SEL_tile_wr_acks = 0x3d,
842 DB_PERF_SEL_mi_tile_wr_outstanding_sum = 0x3e,
843 DB_PERF_SEL_quad_wr_sends = 0x3f,
844 DB_PERF_SEL_quad_wr_busy = 0x40,
845 DB_PERF_SEL_quad_wr_mi_stall = 0x41,
846 DB_PERF_SEL_quad_wr_coherency_stall = 0x42,
847 DB_PERF_SEL_quad_wr_acks = 0x43,
848 DB_PERF_SEL_mi_quad_wr_outstanding_sum = 0x44,
849 DB_PERF_SEL_Tile_Cache_misses = 0x45,
850 DB_PERF_SEL_Tile_Cache_hits = 0x46,
851 DB_PERF_SEL_Tile_Cache_flushes = 0x47,
852 DB_PERF_SEL_Tile_Cache_surface_stall = 0x48,
853 DB_PERF_SEL_Tile_Cache_starves = 0x49,
854 DB_PERF_SEL_Tile_Cache_mem_return_starve = 0x4a,
855 DB_PERF_SEL_tcp_dispatcher_reads = 0x4b,
856 DB_PERF_SEL_tcp_prefetcher_reads = 0x4c,
857 DB_PERF_SEL_tcp_preloader_reads = 0x4d,
858 DB_PERF_SEL_tcp_dispatcher_flushes = 0x4e,
859 DB_PERF_SEL_tcp_prefetcher_flushes = 0x4f,
860 DB_PERF_SEL_tcp_preloader_flushes = 0x50,
861 DB_PERF_SEL_Depth_Tile_Cache_sends = 0x51,
862 DB_PERF_SEL_Depth_Tile_Cache_busy = 0x52,
863 DB_PERF_SEL_Depth_Tile_Cache_starves = 0x53,
864 DB_PERF_SEL_Depth_Tile_Cache_dtile_locked = 0x54,
865 DB_PERF_SEL_Depth_Tile_Cache_alloc_stall = 0x55,
866 DB_PERF_SEL_Depth_Tile_Cache_misses = 0x56,
867 DB_PERF_SEL_Depth_Tile_Cache_hits = 0x57,
868 DB_PERF_SEL_Depth_Tile_Cache_flushes = 0x58,
869 DB_PERF_SEL_Depth_Tile_Cache_noop_tile = 0x59,
870 DB_PERF_SEL_Depth_Tile_Cache_detailed_noop = 0x5a,
871 DB_PERF_SEL_Depth_Tile_Cache_event = 0x5b,
872 DB_PERF_SEL_Depth_Tile_Cache_tile_frees = 0x5c,
873 DB_PERF_SEL_Depth_Tile_Cache_data_frees = 0x5d,
874 DB_PERF_SEL_Depth_Tile_Cache_mem_return_starve = 0x5e,
875 DB_PERF_SEL_Stencil_Cache_misses = 0x5f,
876 DB_PERF_SEL_Stencil_Cache_hits = 0x60,
877 DB_PERF_SEL_Stencil_Cache_flushes = 0x61,
878 DB_PERF_SEL_Stencil_Cache_starves = 0x62,
879 DB_PERF_SEL_Stencil_Cache_frees = 0x63,
880 DB_PERF_SEL_Z_Cache_separate_Z_misses = 0x64,
881 DB_PERF_SEL_Z_Cache_separate_Z_hits = 0x65,
882 DB_PERF_SEL_Z_Cache_separate_Z_flushes = 0x66,
883 DB_PERF_SEL_Z_Cache_separate_Z_starves = 0x67,
884 DB_PERF_SEL_Z_Cache_pmask_misses = 0x68,
885 DB_PERF_SEL_Z_Cache_pmask_hits = 0x69,
886 DB_PERF_SEL_Z_Cache_pmask_flushes = 0x6a,
887 DB_PERF_SEL_Z_Cache_pmask_starves = 0x6b,
888 DB_PERF_SEL_Z_Cache_frees = 0x6c,
889 DB_PERF_SEL_Plane_Cache_misses = 0x6d,
890 DB_PERF_SEL_Plane_Cache_hits = 0x6e,
891 DB_PERF_SEL_Plane_Cache_flushes = 0x6f,
892 DB_PERF_SEL_Plane_Cache_starves = 0x70,
893 DB_PERF_SEL_Plane_Cache_frees = 0x71,
894 DB_PERF_SEL_flush_expanded_stencil = 0x72,
895 DB_PERF_SEL_flush_compressed_stencil = 0x73,
896 DB_PERF_SEL_flush_single_stencil = 0x74,
897 DB_PERF_SEL_planes_flushed = 0x75,
898 DB_PERF_SEL_flush_1plane = 0x76,
899 DB_PERF_SEL_flush_2plane = 0x77,
900 DB_PERF_SEL_flush_3plane = 0x78,
901 DB_PERF_SEL_flush_4plane = 0x79,
902 DB_PERF_SEL_flush_5plane = 0x7a,
903 DB_PERF_SEL_flush_6plane = 0x7b,
904 DB_PERF_SEL_flush_7plane = 0x7c,
905 DB_PERF_SEL_flush_8plane = 0x7d,
906 DB_PERF_SEL_flush_9plane = 0x7e,
907 DB_PERF_SEL_flush_10plane = 0x7f,
908 DB_PERF_SEL_flush_11plane = 0x80,
909 DB_PERF_SEL_flush_12plane = 0x81,
910 DB_PERF_SEL_flush_13plane = 0x82,
911 DB_PERF_SEL_flush_14plane = 0x83,
912 DB_PERF_SEL_flush_15plane = 0x84,
913 DB_PERF_SEL_flush_16plane = 0x85,
914 DB_PERF_SEL_flush_expanded_z = 0x86,
915 DB_PERF_SEL_earlyZ_waiting_for_postZ_done = 0x87,
916 DB_PERF_SEL_reZ_waiting_for_postZ_done = 0x88,
917 DB_PERF_SEL_dk_tile_sends = 0x89,
918 DB_PERF_SEL_dk_tile_busy = 0x8a,
919 DB_PERF_SEL_dk_tile_quad_starves = 0x8b,
920 DB_PERF_SEL_dk_tile_stalls = 0x8c,
921 DB_PERF_SEL_dk_squad_sends = 0x8d,
922 DB_PERF_SEL_dk_squad_busy = 0x8e,
923 DB_PERF_SEL_dk_squad_stalls = 0x8f,
924 DB_PERF_SEL_Op_Pipe_Busy = 0x90,
925 DB_PERF_SEL_Op_Pipe_MC_Read_stall = 0x91,
926 DB_PERF_SEL_qc_busy = 0x92,
927 DB_PERF_SEL_qc_xfc = 0x93,
928 DB_PERF_SEL_qc_conflicts = 0x94,
929 DB_PERF_SEL_qc_full_stall = 0x95,
930 DB_PERF_SEL_qc_in_preZ_tile_stalls_postZ = 0x96,
931 DB_PERF_SEL_qc_in_postZ_tile_stalls_preZ = 0x97,
932 DB_PERF_SEL_tsc_insert_summarize_stall = 0x98,
933 DB_PERF_SEL_tl_busy = 0x99,
934 DB_PERF_SEL_tl_dtc_read_starved = 0x9a,
935 DB_PERF_SEL_tl_z_fetch_stall = 0x9b,
936 DB_PERF_SEL_tl_stencil_stall = 0x9c,
937 DB_PERF_SEL_tl_z_decompress_stall = 0x9d,
938 DB_PERF_SEL_tl_stencil_locked_stall = 0x9e,
939 DB_PERF_SEL_tl_events = 0x9f,
940 DB_PERF_SEL_tl_summarize_squads = 0xa0,
941 DB_PERF_SEL_tl_flush_expand_squads = 0xa1,
942 DB_PERF_SEL_tl_expand_squads = 0xa2,
943 DB_PERF_SEL_tl_preZ_squads = 0xa3,
944 DB_PERF_SEL_tl_postZ_squads = 0xa4,
945 DB_PERF_SEL_tl_preZ_noop_squads = 0xa5,
946 DB_PERF_SEL_tl_postZ_noop_squads = 0xa6,
947 DB_PERF_SEL_tl_tile_ops = 0xa7,
948 DB_PERF_SEL_tl_in_xfc = 0xa8,
949 DB_PERF_SEL_tl_in_single_stencil_expand_stall = 0xa9,
950 DB_PERF_SEL_tl_in_fast_z_stall = 0xaa,
951 DB_PERF_SEL_tl_out_xfc = 0xab,
952 DB_PERF_SEL_tl_out_squads = 0xac,
953 DB_PERF_SEL_zf_plane_multicycle = 0xad,
954 DB_PERF_SEL_PostZ_Samples_passing_Z = 0xae,
955 DB_PERF_SEL_PostZ_Samples_failing_Z = 0xaf,
956 DB_PERF_SEL_PostZ_Samples_failing_S = 0xb0,
957 DB_PERF_SEL_PreZ_Samples_passing_Z = 0xb1,
958 DB_PERF_SEL_PreZ_Samples_failing_Z = 0xb2,
959 DB_PERF_SEL_PreZ_Samples_failing_S = 0xb3,
960 DB_PERF_SEL_ts_tc_update_stall = 0xb4,
961 DB_PERF_SEL_sc_kick_start = 0xb5,
962 DB_PERF_SEL_sc_kick_end = 0xb6,
963 DB_PERF_SEL_clock_reg_active = 0xb7,
964 DB_PERF_SEL_clock_main_active = 0xb8,
965 DB_PERF_SEL_clock_mem_export_active = 0xb9,
966 DB_PERF_SEL_esr_ps_out_busy = 0xba,
967 DB_PERF_SEL_esr_ps_lqf_busy = 0xbb,
968 DB_PERF_SEL_esr_ps_lqf_stall = 0xbc,
969 DB_PERF_SEL_etr_out_send = 0xbd,
970 DB_PERF_SEL_etr_out_busy = 0xbe,
971 DB_PERF_SEL_etr_out_ltile_probe_fifo_full_stall = 0xbf,
972 DB_PERF_SEL_etr_out_cb_tile_stall = 0xc0,
973 DB_PERF_SEL_etr_out_esr_stall = 0xc1,
974 DB_PERF_SEL_esr_ps_sqq_busy = 0xc2,
975 DB_PERF_SEL_esr_ps_sqq_stall = 0xc3,
976 DB_PERF_SEL_esr_eot_fwd_busy = 0xc4,
977 DB_PERF_SEL_esr_eot_fwd_holding_squad = 0xc5,
978 DB_PERF_SEL_esr_eot_fwd_forward = 0xc6,
979 DB_PERF_SEL_esr_sqq_zi_busy = 0xc7,
980 DB_PERF_SEL_esr_sqq_zi_stall = 0xc8,
981 DB_PERF_SEL_postzl_sq_pt_busy = 0xc9,
982 DB_PERF_SEL_postzl_sq_pt_stall = 0xca,
983 DB_PERF_SEL_postzl_se_busy = 0xcb,
984 DB_PERF_SEL_postzl_se_stall = 0xcc,
985 DB_PERF_SEL_postzl_partial_launch = 0xcd,
986 DB_PERF_SEL_postzl_full_launch = 0xce,
987 DB_PERF_SEL_postzl_partial_waiting = 0xcf,
988 DB_PERF_SEL_postzl_tile_mem_stall = 0xd0,
989 DB_PERF_SEL_postzl_tile_init_stall = 0xd1,
990 DB_PEFF_SEL_prezl_tile_mem_stall = 0xd2,
991 DB_PERF_SEL_prezl_tile_init_stall = 0xd3,
992 DB_PERF_SEL_dtt_sm_clash_stall = 0xd4,
993 DB_PERF_SEL_dtt_sm_slot_stall = 0xd5,
994 DB_PERF_SEL_dtt_sm_miss_stall = 0xd6,
995 DB_PERF_SEL_mi_rdreq_busy = 0xd7,
996 DB_PERF_SEL_mi_rdreq_stall = 0xd8,
997 DB_PERF_SEL_mi_wrreq_busy = 0xd9,
998 DB_PERF_SEL_mi_wrreq_stall = 0xda,
999 DB_PERF_SEL_recomp_tile_to_1zplane_no_fastop = 0xdb,
1000 DB_PERF_SEL_dkg_tile_rate_tile = 0xdc,
1001 DB_PERF_SEL_prezl_src_in_sends = 0xdd,
1002 DB_PERF_SEL_prezl_src_in_stall = 0xde,
1003 DB_PERF_SEL_prezl_src_in_squads = 0xdf,
1004 DB_PERF_SEL_prezl_src_in_squads_unrolled = 0xe0,
1005 DB_PERF_SEL_prezl_src_in_tile_rate = 0xe1,
1006 DB_PERF_SEL_prezl_src_in_tile_rate_unrolled = 0xe2,
1007 DB_PERF_SEL_prezl_src_out_stall = 0xe3,
1008 DB_PERF_SEL_postzl_src_in_sends = 0xe4,
1009 DB_PERF_SEL_postzl_src_in_stall = 0xe5,
1010 DB_PERF_SEL_postzl_src_in_squads = 0xe6,
1011 DB_PERF_SEL_postzl_src_in_squads_unrolled = 0xe7,
1012 DB_PERF_SEL_postzl_src_in_tile_rate = 0xe8,
1013 DB_PERF_SEL_postzl_src_in_tile_rate_unrolled = 0xe9,
1014 DB_PERF_SEL_postzl_src_out_stall = 0xea,
1015 DB_PERF_SEL_esr_ps_src_in_sends = 0xeb,
1016 DB_PERF_SEL_esr_ps_src_in_stall = 0xec,
1017 DB_PERF_SEL_esr_ps_src_in_squads = 0xed,
1018 DB_PERF_SEL_esr_ps_src_in_squads_unrolled = 0xee,
1019 DB_PERF_SEL_esr_ps_src_in_tile_rate = 0xef,
1020 DB_PERF_SEL_esr_ps_src_in_tile_rate_unrolled = 0xf0,
1021 DB_PERF_SEL_esr_ps_src_in_tile_rate_unrolled_to_pixel_rate= 0xf1,
1022 DB_PERF_SEL_esr_ps_src_out_stall = 0xf2,
1023 DB_PERF_SEL_depth_bounds_qtiles_culled = 0xf3,
1024 DB_PERF_SEL_PreZ_Samples_failing_DB = 0xf4,
1025 DB_PERF_SEL_PostZ_Samples_failing_DB = 0xf5,
1026 DB_PERF_SEL_flush_compressed = 0xf6,
1027 DB_PERF_SEL_flush_plane_le4 = 0xf7,
1028 DB_PERF_SEL_tiles_z_fully_summarized = 0xf8,
1029 DB_PERF_SEL_tiles_stencil_fully_summarized = 0xf9,
1030 DB_PERF_SEL_tiles_z_clear_on_expclear = 0xfa,
1031 DB_PERF_SEL_tiles_s_clear_on_expclear = 0xfb,
1032 DB_PERF_SEL_tiles_decomp_on_expclear = 0xfc,
1033 DB_PERF_SEL_tiles_compressed_to_decompressed = 0xfd,
1034 DB_PERF_SEL_Op_Pipe_Prez_Busy = 0xfe,
1035 DB_PERF_SEL_Op_Pipe_Postz_Busy = 0xff,
1036 DB_PERF_SEL_di_dt_stall = 0x100,
1037 } PerfCounter_Vals;
1038 typedef enum RingCounterControl {
1039 COUNTER_RING_SPLIT = 0x0,
1040 COUNTER_RING_0 = 0x1,
1041 COUNTER_RING_1 = 0x2,
1042 } RingCounterControl;
1043 typedef enum PixelPipeCounterId {
1044 PIXEL_PIPE_OCCLUSION_COUNT_0 = 0x0,
1045 PIXEL_PIPE_OCCLUSION_COUNT_1 = 0x1,
1046 PIXEL_PIPE_OCCLUSION_COUNT_2 = 0x2,
1047 PIXEL_PIPE_OCCLUSION_COUNT_3 = 0x3,
1048 PIXEL_PIPE_SCREEN_MIN_EXTENTS_0 = 0x4,
1049 PIXEL_PIPE_SCREEN_MAX_EXTENTS_0 = 0x5,
1050 PIXEL_PIPE_SCREEN_MIN_EXTENTS_1 = 0x6,
1051 PIXEL_PIPE_SCREEN_MAX_EXTENTS_1 = 0x7,
1052 } PixelPipeCounterId;
1053 typedef enum PixelPipeStride {
1054 PIXEL_PIPE_STRIDE_32_BITS = 0x0,
1055 PIXEL_PIPE_STRIDE_64_BITS = 0x1,
1056 PIXEL_PIPE_STRIDE_128_BITS = 0x2,
1057 PIXEL_PIPE_STRIDE_256_BITS = 0x3,
1058 } PixelPipeStride;
1059 typedef enum GB_EDC_DED_MODE {
1060 GB_EDC_DED_MODE_LOG = 0x0,
1061 GB_EDC_DED_MODE_HALT = 0x1,
1062 GB_EDC_DED_MODE_INT_HALT = 0x2,
1063 } GB_EDC_DED_MODE;
1064 #define GB_TILING_CONFIG_TABLE_SIZE 0x20
1065 #define GB_TILING_CONFIG_MACROTABLE_SIZE 0x10
1066 typedef enum GRBM_PERF_SEL {
1067 GRBM_PERF_SEL_COUNT = 0x0,
1068 GRBM_PERF_SEL_USER_DEFINED = 0x1,
1069 GRBM_PERF_SEL_GUI_ACTIVE = 0x2,
1070 GRBM_PERF_SEL_CP_BUSY = 0x3,
1071 GRBM_PERF_SEL_CP_COHER_BUSY = 0x4,
1072 GRBM_PERF_SEL_CP_DMA_BUSY = 0x5,
1073 GRBM_PERF_SEL_CB_BUSY = 0x6,
1074 GRBM_PERF_SEL_DB_BUSY = 0x7,
1075 GRBM_PERF_SEL_PA_BUSY = 0x8,
1076 GRBM_PERF_SEL_SC_BUSY = 0x9,
1077 GRBM_PERF_SEL_RESERVED_6 = 0xa,
1078 GRBM_PERF_SEL_SPI_BUSY = 0xb,
1079 GRBM_PERF_SEL_SX_BUSY = 0xc,
1080 GRBM_PERF_SEL_TA_BUSY = 0xd,
1081 GRBM_PERF_SEL_CB_CLEAN = 0xe,
1082 GRBM_PERF_SEL_DB_CLEAN = 0xf,
1083 GRBM_PERF_SEL_RESERVED_5 = 0x10,
1084 GRBM_PERF_SEL_VGT_BUSY = 0x11,
1085 GRBM_PERF_SEL_RESERVED_4 = 0x12,
1086 GRBM_PERF_SEL_RESERVED_3 = 0x13,
1087 GRBM_PERF_SEL_RESERVED_2 = 0x14,
1088 GRBM_PERF_SEL_RESERVED_1 = 0x15,
1089 GRBM_PERF_SEL_RESERVED_0 = 0x16,
1090 GRBM_PERF_SEL_IA_BUSY = 0x17,
1091 GRBM_PERF_SEL_IA_NO_DMA_BUSY = 0x18,
1092 GRBM_PERF_SEL_GDS_BUSY = 0x19,
1093 GRBM_PERF_SEL_BCI_BUSY = 0x1a,
1094 GRBM_PERF_SEL_RLC_BUSY = 0x1b,
1095 GRBM_PERF_SEL_TC_BUSY = 0x1c,
1096 GRBM_PERF_SEL_CPG_BUSY = 0x1d,
1097 GRBM_PERF_SEL_CPC_BUSY = 0x1e,
1098 GRBM_PERF_SEL_CPF_BUSY = 0x1f,
1099 GRBM_PERF_SEL_WD_BUSY = 0x20,
1100 GRBM_PERF_SEL_WD_NO_DMA_BUSY = 0x21,
1101 } GRBM_PERF_SEL;
1102 typedef enum GRBM_SE0_PERF_SEL {
1103 GRBM_SE0_PERF_SEL_COUNT = 0x0,
1104 GRBM_SE0_PERF_SEL_USER_DEFINED = 0x1,
1105 GRBM_SE0_PERF_SEL_CB_BUSY = 0x2,
1106 GRBM_SE0_PERF_SEL_DB_BUSY = 0x3,
1107 GRBM_SE0_PERF_SEL_SC_BUSY = 0x4,
1108 GRBM_SE0_PERF_SEL_RESERVED_1 = 0x5,
1109 GRBM_SE0_PERF_SEL_SPI_BUSY = 0x6,
1110 GRBM_SE0_PERF_SEL_SX_BUSY = 0x7,
1111 GRBM_SE0_PERF_SEL_TA_BUSY = 0x8,
1112 GRBM_SE0_PERF_SEL_CB_CLEAN = 0x9,
1113 GRBM_SE0_PERF_SEL_DB_CLEAN = 0xa,
1114 GRBM_SE0_PERF_SEL_RESERVED_0 = 0xb,
1115 GRBM_SE0_PERF_SEL_PA_BUSY = 0xc,
1116 GRBM_SE0_PERF_SEL_VGT_BUSY = 0xd,
1117 GRBM_SE0_PERF_SEL_BCI_BUSY = 0xe,
1118 } GRBM_SE0_PERF_SEL;
1119 typedef enum GRBM_SE1_PERF_SEL {
1120 GRBM_SE1_PERF_SEL_COUNT = 0x0,
1121 GRBM_SE1_PERF_SEL_USER_DEFINED = 0x1,
1122 GRBM_SE1_PERF_SEL_CB_BUSY = 0x2,
1123 GRBM_SE1_PERF_SEL_DB_BUSY = 0x3,
1124 GRBM_SE1_PERF_SEL_SC_BUSY = 0x4,
1125 GRBM_SE1_PERF_SEL_RESERVED_1 = 0x5,
1126 GRBM_SE1_PERF_SEL_SPI_BUSY = 0x6,
1127 GRBM_SE1_PERF_SEL_SX_BUSY = 0x7,
1128 GRBM_SE1_PERF_SEL_TA_BUSY = 0x8,
1129 GRBM_SE1_PERF_SEL_CB_CLEAN = 0x9,
1130 GRBM_SE1_PERF_SEL_DB_CLEAN = 0xa,
1131 GRBM_SE1_PERF_SEL_RESERVED_0 = 0xb,
1132 GRBM_SE1_PERF_SEL_PA_BUSY = 0xc,
1133 GRBM_SE1_PERF_SEL_VGT_BUSY = 0xd,
1134 GRBM_SE1_PERF_SEL_BCI_BUSY = 0xe,
1135 } GRBM_SE1_PERF_SEL;
1136 typedef enum GRBM_SE2_PERF_SEL {
1137 GRBM_SE2_PERF_SEL_COUNT = 0x0,
1138 GRBM_SE2_PERF_SEL_USER_DEFINED = 0x1,
1139 GRBM_SE2_PERF_SEL_CB_BUSY = 0x2,
1140 GRBM_SE2_PERF_SEL_DB_BUSY = 0x3,
1141 GRBM_SE2_PERF_SEL_SC_BUSY = 0x4,
1142 GRBM_SE2_PERF_SEL_RESERVED_1 = 0x5,
1143 GRBM_SE2_PERF_SEL_SPI_BUSY = 0x6,
1144 GRBM_SE2_PERF_SEL_SX_BUSY = 0x7,
1145 GRBM_SE2_PERF_SEL_TA_BUSY = 0x8,
1146 GRBM_SE2_PERF_SEL_CB_CLEAN = 0x9,
1147 GRBM_SE2_PERF_SEL_DB_CLEAN = 0xa,
1148 GRBM_SE2_PERF_SEL_RESERVED_0 = 0xb,
1149 GRBM_SE2_PERF_SEL_PA_BUSY = 0xc,
1150 GRBM_SE2_PERF_SEL_VGT_BUSY = 0xd,
1151 GRBM_SE2_PERF_SEL_BCI_BUSY = 0xe,
1152 } GRBM_SE2_PERF_SEL;
1153 typedef enum GRBM_SE3_PERF_SEL {
1154 GRBM_SE3_PERF_SEL_COUNT = 0x0,
1155 GRBM_SE3_PERF_SEL_USER_DEFINED = 0x1,
1156 GRBM_SE3_PERF_SEL_CB_BUSY = 0x2,
1157 GRBM_SE3_PERF_SEL_DB_BUSY = 0x3,
1158 GRBM_SE3_PERF_SEL_SC_BUSY = 0x4,
1159 GRBM_SE3_PERF_SEL_RESERVED_1 = 0x5,
1160 GRBM_SE3_PERF_SEL_SPI_BUSY = 0x6,
1161 GRBM_SE3_PERF_SEL_SX_BUSY = 0x7,
1162 GRBM_SE3_PERF_SEL_TA_BUSY = 0x8,
1163 GRBM_SE3_PERF_SEL_CB_CLEAN = 0x9,
1164 GRBM_SE3_PERF_SEL_DB_CLEAN = 0xa,
1165 GRBM_SE3_PERF_SEL_RESERVED_0 = 0xb,
1166 GRBM_SE3_PERF_SEL_PA_BUSY = 0xc,
1167 GRBM_SE3_PERF_SEL_VGT_BUSY = 0xd,
1168 GRBM_SE3_PERF_SEL_BCI_BUSY = 0xe,
1169 } GRBM_SE3_PERF_SEL;
1170 typedef enum SU_PERFCNT_SEL {
1171 PERF_PAPC_PASX_REQ = 0x0,
1172 PERF_PAPC_PASX_DISABLE_PIPE = 0x1,
1173 PERF_PAPC_PASX_FIRST_VECTOR = 0x2,
1174 PERF_PAPC_PASX_SECOND_VECTOR = 0x3,
1175 PERF_PAPC_PASX_FIRST_DEAD = 0x4,
1176 PERF_PAPC_PASX_SECOND_DEAD = 0x5,
1177 PERF_PAPC_PASX_VTX_KILL_DISCARD = 0x6,
1178 PERF_PAPC_PASX_VTX_NAN_DISCARD = 0x7,
1179 PERF_PAPC_PA_INPUT_PRIM = 0x8,
1180 PERF_PAPC_PA_INPUT_NULL_PRIM = 0x9,
1181 PERF_PAPC_PA_INPUT_EVENT_FLAG = 0xa,
1182 PERF_PAPC_PA_INPUT_FIRST_PRIM_SLOT = 0xb,
1183 PERF_PAPC_PA_INPUT_END_OF_PACKET = 0xc,
1184 PERF_PAPC_PA_INPUT_EXTENDED_EVENT = 0xd,
1185 PERF_PAPC_CLPR_CULL_PRIM = 0xe,
1186 PERF_PAPC_CLPR_VVUCP_CULL_PRIM = 0xf,
1187 PERF_PAPC_CLPR_VV_CULL_PRIM = 0x10,
1188 PERF_PAPC_CLPR_UCP_CULL_PRIM = 0x11,
1189 PERF_PAPC_CLPR_VTX_KILL_CULL_PRIM = 0x12,
1190 PERF_PAPC_CLPR_VTX_NAN_CULL_PRIM = 0x13,
1191 PERF_PAPC_CLPR_CULL_TO_NULL_PRIM = 0x14,
1192 PERF_PAPC_CLPR_VVUCP_CLIP_PRIM = 0x15,
1193 PERF_PAPC_CLPR_VV_CLIP_PRIM = 0x16,
1194 PERF_PAPC_CLPR_UCP_CLIP_PRIM = 0x17,
1195 PERF_PAPC_CLPR_POINT_CLIP_CANDIDATE = 0x18,
1196 PERF_PAPC_CLPR_CLIP_PLANE_CNT_1 = 0x19,
1197 PERF_PAPC_CLPR_CLIP_PLANE_CNT_2 = 0x1a,
1198 PERF_PAPC_CLPR_CLIP_PLANE_CNT_3 = 0x1b,
1199 PERF_PAPC_CLPR_CLIP_PLANE_CNT_4 = 0x1c,
1200 PERF_PAPC_CLPR_CLIP_PLANE_CNT_5_8 = 0x1d,
1201 PERF_PAPC_CLPR_CLIP_PLANE_CNT_9_12 = 0x1e,
1202 PERF_PAPC_CLPR_CLIP_PLANE_NEAR = 0x1f,
1203 PERF_PAPC_CLPR_CLIP_PLANE_FAR = 0x20,
1204 PERF_PAPC_CLPR_CLIP_PLANE_LEFT = 0x21,
1205 PERF_PAPC_CLPR_CLIP_PLANE_RIGHT = 0x22,
1206 PERF_PAPC_CLPR_CLIP_PLANE_TOP = 0x23,
1207 PERF_PAPC_CLPR_CLIP_PLANE_BOTTOM = 0x24,
1208 PERF_PAPC_CLPR_GSC_KILL_CULL_PRIM = 0x25,
1209 PERF_PAPC_CLPR_RASTER_KILL_CULL_PRIM = 0x26,
1210 PERF_PAPC_CLSM_NULL_PRIM = 0x27,
1211 PERF_PAPC_CLSM_TOTALLY_VISIBLE_PRIM = 0x28,
1212 PERF_PAPC_CLSM_CULL_TO_NULL_PRIM = 0x29,
1213 PERF_PAPC_CLSM_OUT_PRIM_CNT_1 = 0x2a,
1214 PERF_PAPC_CLSM_OUT_PRIM_CNT_2 = 0x2b,
1215 PERF_PAPC_CLSM_OUT_PRIM_CNT_3 = 0x2c,
1216 PERF_PAPC_CLSM_OUT_PRIM_CNT_4 = 0x2d,
1217 PERF_PAPC_CLSM_OUT_PRIM_CNT_5_8 = 0x2e,
1218 PERF_PAPC_CLSM_OUT_PRIM_CNT_9_13 = 0x2f,
1219 PERF_PAPC_CLIPGA_VTE_KILL_PRIM = 0x30,
1220 PERF_PAPC_SU_INPUT_PRIM = 0x31,
1221 PERF_PAPC_SU_INPUT_CLIP_PRIM = 0x32,
1222 PERF_PAPC_SU_INPUT_NULL_PRIM = 0x33,
1223 PERF_PAPC_SU_INPUT_PRIM_DUAL = 0x34,
1224 PERF_PAPC_SU_INPUT_CLIP_PRIM_DUAL = 0x35,
1225 PERF_PAPC_SU_ZERO_AREA_CULL_PRIM = 0x36,
1226 PERF_PAPC_SU_BACK_FACE_CULL_PRIM = 0x37,
1227 PERF_PAPC_SU_FRONT_FACE_CULL_PRIM = 0x38,
1228 PERF_PAPC_SU_POLYMODE_FACE_CULL = 0x39,
1229 PERF_PAPC_SU_POLYMODE_BACK_CULL = 0x3a,
1230 PERF_PAPC_SU_POLYMODE_FRONT_CULL = 0x3b,
1231 PERF_PAPC_SU_POLYMODE_INVALID_FILL = 0x3c,
1232 PERF_PAPC_SU_OUTPUT_PRIM = 0x3d,
1233 PERF_PAPC_SU_OUTPUT_CLIP_PRIM = 0x3e,
1234 PERF_PAPC_SU_OUTPUT_NULL_PRIM = 0x3f,
1235 PERF_PAPC_SU_OUTPUT_EVENT_FLAG = 0x40,
1236 PERF_PAPC_SU_OUTPUT_FIRST_PRIM_SLOT = 0x41,
1237 PERF_PAPC_SU_OUTPUT_END_OF_PACKET = 0x42,
1238 PERF_PAPC_SU_OUTPUT_POLYMODE_FACE = 0x43,
1239 PERF_PAPC_SU_OUTPUT_POLYMODE_BACK = 0x44,
1240 PERF_PAPC_SU_OUTPUT_POLYMODE_FRONT = 0x45,
1241 PERF_PAPC_SU_OUT_CLIP_POLYMODE_FACE = 0x46,
1242 PERF_PAPC_SU_OUT_CLIP_POLYMODE_BACK = 0x47,
1243 PERF_PAPC_SU_OUT_CLIP_POLYMODE_FRONT = 0x48,
1244 PERF_PAPC_SU_OUTPUT_PRIM_DUAL = 0x49,
1245 PERF_PAPC_SU_OUTPUT_CLIP_PRIM_DUAL = 0x4a,
1246 PERF_PAPC_SU_OUTPUT_POLYMODE_DUAL = 0x4b,
1247 PERF_PAPC_SU_OUTPUT_CLIP_POLYMODE_DUAL = 0x4c,
1248 PERF_PAPC_PASX_REQ_IDLE = 0x4d,
1249 PERF_PAPC_PASX_REQ_BUSY = 0x4e,
1250 PERF_PAPC_PASX_REQ_STALLED = 0x4f,
1251 PERF_PAPC_PASX_REC_IDLE = 0x50,
1252 PERF_PAPC_PASX_REC_BUSY = 0x51,
1253 PERF_PAPC_PASX_REC_STARVED_SX = 0x52,
1254 PERF_PAPC_PASX_REC_STALLED = 0x53,
1255 PERF_PAPC_PASX_REC_STALLED_POS_MEM = 0x54,
1256 PERF_PAPC_PASX_REC_STALLED_CCGSM_IN = 0x55,
1257 PERF_PAPC_CCGSM_IDLE = 0x56,
1258 PERF_PAPC_CCGSM_BUSY = 0x57,
1259 PERF_PAPC_CCGSM_STALLED = 0x58,
1260 PERF_PAPC_CLPRIM_IDLE = 0x59,
1261 PERF_PAPC_CLPRIM_BUSY = 0x5a,
1262 PERF_PAPC_CLPRIM_STALLED = 0x5b,
1263 PERF_PAPC_CLPRIM_STARVED_CCGSM = 0x5c,
1264 PERF_PAPC_CLIPSM_IDLE = 0x5d,
1265 PERF_PAPC_CLIPSM_BUSY = 0x5e,
1266 PERF_PAPC_CLIPSM_WAIT_CLIP_VERT_ENGH = 0x5f,
1267 PERF_PAPC_CLIPSM_WAIT_HIGH_PRI_SEQ = 0x60,
1268 PERF_PAPC_CLIPSM_WAIT_CLIPGA = 0x61,
1269 PERF_PAPC_CLIPSM_WAIT_AVAIL_VTE_CLIP = 0x62,
1270 PERF_PAPC_CLIPSM_WAIT_CLIP_OUTSM = 0x63,
1271 PERF_PAPC_CLIPGA_IDLE = 0x64,
1272 PERF_PAPC_CLIPGA_BUSY = 0x65,
1273 PERF_PAPC_CLIPGA_STARVED_VTE_CLIP = 0x66,
1274 PERF_PAPC_CLIPGA_STALLED = 0x67,
1275 PERF_PAPC_CLIP_IDLE = 0x68,
1276 PERF_PAPC_CLIP_BUSY = 0x69,
1277 PERF_PAPC_SU_IDLE = 0x6a,
1278 PERF_PAPC_SU_BUSY = 0x6b,
1279 PERF_PAPC_SU_STARVED_CLIP = 0x6c,
1280 PERF_PAPC_SU_STALLED_SC = 0x6d,
1281 PERF_PAPC_CL_DYN_SCLK_VLD = 0x6e,
1282 PERF_PAPC_SU_DYN_SCLK_VLD = 0x6f,
1283 PERF_PAPC_PA_REG_SCLK_VLD = 0x70,
1284 PERF_PAPC_SU_MULTI_GPU_PRIM_FILTER_CULL = 0x71,
1285 PERF_PAPC_PASX_SE0_REQ = 0x72,
1286 PERF_PAPC_PASX_SE1_REQ = 0x73,
1287 PERF_PAPC_PASX_SE0_FIRST_VECTOR = 0x74,
1288 PERF_PAPC_PASX_SE0_SECOND_VECTOR = 0x75,
1289 PERF_PAPC_PASX_SE1_FIRST_VECTOR = 0x76,
1290 PERF_PAPC_PASX_SE1_SECOND_VECTOR = 0x77,
1291 PERF_PAPC_SU_SE0_PRIM_FILTER_CULL = 0x78,
1292 PERF_PAPC_SU_SE1_PRIM_FILTER_CULL = 0x79,
1293 PERF_PAPC_SU_SE01_PRIM_FILTER_CULL = 0x7a,
1294 PERF_PAPC_SU_SE0_OUTPUT_PRIM = 0x7b,
1295 PERF_PAPC_SU_SE1_OUTPUT_PRIM = 0x7c,
1296 PERF_PAPC_SU_SE01_OUTPUT_PRIM = 0x7d,
1297 PERF_PAPC_SU_SE0_OUTPUT_NULL_PRIM = 0x7e,
1298 PERF_PAPC_SU_SE1_OUTPUT_NULL_PRIM = 0x7f,
1299 PERF_PAPC_SU_SE01_OUTPUT_NULL_PRIM = 0x80,
1300 PERF_PAPC_SU_SE0_OUTPUT_FIRST_PRIM_SLOT = 0x81,
1301 PERF_PAPC_SU_SE1_OUTPUT_FIRST_PRIM_SLOT = 0x82,
1302 PERF_PAPC_SU_SE0_STALLED_SC = 0x83,
1303 PERF_PAPC_SU_SE1_STALLED_SC = 0x84,
1304 PERF_PAPC_SU_SE01_STALLED_SC = 0x85,
1305 PERF_PAPC_CLSM_CLIPPING_PRIM = 0x86,
1306 PERF_PAPC_SU_CULLED_PRIM = 0x87,
1307 PERF_PAPC_SU_OUTPUT_EOPG = 0x88,
1308 PERF_PAPC_SU_SE2_PRIM_FILTER_CULL = 0x89,
1309 PERF_PAPC_SU_SE3_PRIM_FILTER_CULL = 0x8a,
1310 PERF_PAPC_SU_SE2_OUTPUT_PRIM = 0x8b,
1311 PERF_PAPC_SU_SE3_OUTPUT_PRIM = 0x8c,
1312 PERF_PAPC_SU_SE2_OUTPUT_NULL_PRIM = 0x8d,
1313 PERF_PAPC_SU_SE3_OUTPUT_NULL_PRIM = 0x8e,
1314 PERF_PAPC_SU_SE0_OUTPUT_END_OF_PACKET = 0x8f,
1315 PERF_PAPC_SU_SE1_OUTPUT_END_OF_PACKET = 0x90,
1316 PERF_PAPC_SU_SE2_OUTPUT_END_OF_PACKET = 0x91,
1317 PERF_PAPC_SU_SE3_OUTPUT_END_OF_PACKET = 0x92,
1318 PERF_PAPC_SU_SE0_OUTPUT_EOPG = 0x93,
1319 PERF_PAPC_SU_SE1_OUTPUT_EOPG = 0x94,
1320 PERF_PAPC_SU_SE2_OUTPUT_EOPG = 0x95,
1321 PERF_PAPC_SU_SE3_OUTPUT_EOPG = 0x96,
1322 PERF_PAPC_SU_SE2_STALLED_SC = 0x97,
1323 PERF_PAPC_SU_SE3_STALLED_SC = 0x98,
1324 } SU_PERFCNT_SEL;
1325 typedef enum SC_PERFCNT_SEL {
1326 SC_SRPS_WINDOW_VALID = 0x0,
1327 SC_PSSW_WINDOW_VALID = 0x1,
1328 SC_TPQZ_WINDOW_VALID = 0x2,
1329 SC_QZQP_WINDOW_VALID = 0x3,
1330 SC_TRPK_WINDOW_VALID = 0x4,
1331 SC_SRPS_WINDOW_VALID_BUSY = 0x5,
1332 SC_PSSW_WINDOW_VALID_BUSY = 0x6,
1333 SC_TPQZ_WINDOW_VALID_BUSY = 0x7,
1334 SC_QZQP_WINDOW_VALID_BUSY = 0x8,
1335 SC_TRPK_WINDOW_VALID_BUSY = 0x9,
1336 SC_STARVED_BY_PA = 0xa,
1337 SC_STALLED_BY_PRIMFIFO = 0xb,
1338 SC_STALLED_BY_DB_TILE = 0xc,
1339 SC_STARVED_BY_DB_TILE = 0xd,
1340 SC_STALLED_BY_TILEORDERFIFO = 0xe,
1341 SC_STALLED_BY_TILEFIFO = 0xf,
1342 SC_STALLED_BY_DB_QUAD = 0x10,
1343 SC_STARVED_BY_DB_QUAD = 0x11,
1344 SC_STALLED_BY_QUADFIFO = 0x12,
1345 SC_STALLED_BY_BCI = 0x13,
1346 SC_STALLED_BY_SPI = 0x14,
1347 SC_SCISSOR_DISCARD = 0x15,
1348 SC_BB_DISCARD = 0x16,
1349 SC_SUPERTILE_COUNT = 0x17,
1350 SC_SUPERTILE_PER_PRIM_H0 = 0x18,
1351 SC_SUPERTILE_PER_PRIM_H1 = 0x19,
1352 SC_SUPERTILE_PER_PRIM_H2 = 0x1a,
1353 SC_SUPERTILE_PER_PRIM_H3 = 0x1b,
1354 SC_SUPERTILE_PER_PRIM_H4 = 0x1c,
1355 SC_SUPERTILE_PER_PRIM_H5 = 0x1d,
1356 SC_SUPERTILE_PER_PRIM_H6 = 0x1e,
1357 SC_SUPERTILE_PER_PRIM_H7 = 0x1f,
1358 SC_SUPERTILE_PER_PRIM_H8 = 0x20,
1359 SC_SUPERTILE_PER_PRIM_H9 = 0x21,
1360 SC_SUPERTILE_PER_PRIM_H10 = 0x22,
1361 SC_SUPERTILE_PER_PRIM_H11 = 0x23,
1362 SC_SUPERTILE_PER_PRIM_H12 = 0x24,
1363 SC_SUPERTILE_PER_PRIM_H13 = 0x25,
1364 SC_SUPERTILE_PER_PRIM_H14 = 0x26,
1365 SC_SUPERTILE_PER_PRIM_H15 = 0x27,
1366 SC_SUPERTILE_PER_PRIM_H16 = 0x28,
1367 SC_TILE_PER_PRIM_H0 = 0x29,
1368 SC_TILE_PER_PRIM_H1 = 0x2a,
1369 SC_TILE_PER_PRIM_H2 = 0x2b,
1370 SC_TILE_PER_PRIM_H3 = 0x2c,
1371 SC_TILE_PER_PRIM_H4 = 0x2d,
1372 SC_TILE_PER_PRIM_H5 = 0x2e,
1373 SC_TILE_PER_PRIM_H6 = 0x2f,
1374 SC_TILE_PER_PRIM_H7 = 0x30,
1375 SC_TILE_PER_PRIM_H8 = 0x31,
1376 SC_TILE_PER_PRIM_H9 = 0x32,
1377 SC_TILE_PER_PRIM_H10 = 0x33,
1378 SC_TILE_PER_PRIM_H11 = 0x34,
1379 SC_TILE_PER_PRIM_H12 = 0x35,
1380 SC_TILE_PER_PRIM_H13 = 0x36,
1381 SC_TILE_PER_PRIM_H14 = 0x37,
1382 SC_TILE_PER_PRIM_H15 = 0x38,
1383 SC_TILE_PER_PRIM_H16 = 0x39,
1384 SC_TILE_PER_SUPERTILE_H0 = 0x3a,
1385 SC_TILE_PER_SUPERTILE_H1 = 0x3b,
1386 SC_TILE_PER_SUPERTILE_H2 = 0x3c,
1387 SC_TILE_PER_SUPERTILE_H3 = 0x3d,
1388 SC_TILE_PER_SUPERTILE_H4 = 0x3e,
1389 SC_TILE_PER_SUPERTILE_H5 = 0x3f,
1390 SC_TILE_PER_SUPERTILE_H6 = 0x40,
1391 SC_TILE_PER_SUPERTILE_H7 = 0x41,
1392 SC_TILE_PER_SUPERTILE_H8 = 0x42,
1393 SC_TILE_PER_SUPERTILE_H9 = 0x43,
1394 SC_TILE_PER_SUPERTILE_H10 = 0x44,
1395 SC_TILE_PER_SUPERTILE_H11 = 0x45,
1396 SC_TILE_PER_SUPERTILE_H12 = 0x46,
1397 SC_TILE_PER_SUPERTILE_H13 = 0x47,
1398 SC_TILE_PER_SUPERTILE_H14 = 0x48,
1399 SC_TILE_PER_SUPERTILE_H15 = 0x49,
1400 SC_TILE_PER_SUPERTILE_H16 = 0x4a,
1401 SC_TILE_PICKED_H1 = 0x4b,
1402 SC_TILE_PICKED_H2 = 0x4c,
1403 SC_TILE_PICKED_H3 = 0x4d,
1404 SC_TILE_PICKED_H4 = 0x4e,
1405 SC_QZ0_MULTI_GPU_TILE_DISCARD = 0x4f,
1406 SC_QZ1_MULTI_GPU_TILE_DISCARD = 0x50,
1407 SC_QZ2_MULTI_GPU_TILE_DISCARD = 0x51,
1408 SC_QZ3_MULTI_GPU_TILE_DISCARD = 0x52,
1409 SC_QZ0_TILE_COUNT = 0x53,
1410 SC_QZ1_TILE_COUNT = 0x54,
1411 SC_QZ2_TILE_COUNT = 0x55,
1412 SC_QZ3_TILE_COUNT = 0x56,
1413 SC_QZ0_TILE_COVERED_COUNT = 0x57,
1414 SC_QZ1_TILE_COVERED_COUNT = 0x58,
1415 SC_QZ2_TILE_COVERED_COUNT = 0x59,
1416 SC_QZ3_TILE_COVERED_COUNT = 0x5a,
1417 SC_QZ0_TILE_NOT_COVERED_COUNT = 0x5b,
1418 SC_QZ1_TILE_NOT_COVERED_COUNT = 0x5c,
1419 SC_QZ2_TILE_NOT_COVERED_COUNT = 0x5d,
1420 SC_QZ3_TILE_NOT_COVERED_COUNT = 0x5e,
1421 SC_QZ0_QUAD_PER_TILE_H0 = 0x5f,
1422 SC_QZ0_QUAD_PER_TILE_H1 = 0x60,
1423 SC_QZ0_QUAD_PER_TILE_H2 = 0x61,
1424 SC_QZ0_QUAD_PER_TILE_H3 = 0x62,
1425 SC_QZ0_QUAD_PER_TILE_H4 = 0x63,
1426 SC_QZ0_QUAD_PER_TILE_H5 = 0x64,
1427 SC_QZ0_QUAD_PER_TILE_H6 = 0x65,
1428 SC_QZ0_QUAD_PER_TILE_H7 = 0x66,
1429 SC_QZ0_QUAD_PER_TILE_H8 = 0x67,
1430 SC_QZ0_QUAD_PER_TILE_H9 = 0x68,
1431 SC_QZ0_QUAD_PER_TILE_H10 = 0x69,
1432 SC_QZ0_QUAD_PER_TILE_H11 = 0x6a,
1433 SC_QZ0_QUAD_PER_TILE_H12 = 0x6b,
1434 SC_QZ0_QUAD_PER_TILE_H13 = 0x6c,
1435 SC_QZ0_QUAD_PER_TILE_H14 = 0x6d,
1436 SC_QZ0_QUAD_PER_TILE_H15 = 0x6e,
1437 SC_QZ0_QUAD_PER_TILE_H16 = 0x6f,
1438 SC_QZ1_QUAD_PER_TILE_H0 = 0x70,
1439 SC_QZ1_QUAD_PER_TILE_H1 = 0x71,
1440 SC_QZ1_QUAD_PER_TILE_H2 = 0x72,
1441 SC_QZ1_QUAD_PER_TILE_H3 = 0x73,
1442 SC_QZ1_QUAD_PER_TILE_H4 = 0x74,
1443 SC_QZ1_QUAD_PER_TILE_H5 = 0x75,
1444 SC_QZ1_QUAD_PER_TILE_H6 = 0x76,
1445 SC_QZ1_QUAD_PER_TILE_H7 = 0x77,
1446 SC_QZ1_QUAD_PER_TILE_H8 = 0x78,
1447 SC_QZ1_QUAD_PER_TILE_H9 = 0x79,
1448 SC_QZ1_QUAD_PER_TILE_H10 = 0x7a,
1449 SC_QZ1_QUAD_PER_TILE_H11 = 0x7b,
1450 SC_QZ1_QUAD_PER_TILE_H12 = 0x7c,
1451 SC_QZ1_QUAD_PER_TILE_H13 = 0x7d,
1452 SC_QZ1_QUAD_PER_TILE_H14 = 0x7e,
1453 SC_QZ1_QUAD_PER_TILE_H15 = 0x7f,
1454 SC_QZ1_QUAD_PER_TILE_H16 = 0x80,
1455 SC_QZ2_QUAD_PER_TILE_H0 = 0x81,
1456 SC_QZ2_QUAD_PER_TILE_H1 = 0x82,
1457 SC_QZ2_QUAD_PER_TILE_H2 = 0x83,
1458 SC_QZ2_QUAD_PER_TILE_H3 = 0x84,
1459 SC_QZ2_QUAD_PER_TILE_H4 = 0x85,
1460 SC_QZ2_QUAD_PER_TILE_H5 = 0x86,
1461 SC_QZ2_QUAD_PER_TILE_H6 = 0x87,
1462 SC_QZ2_QUAD_PER_TILE_H7 = 0x88,
1463 SC_QZ2_QUAD_PER_TILE_H8 = 0x89,
1464 SC_QZ2_QUAD_PER_TILE_H9 = 0x8a,
1465 SC_QZ2_QUAD_PER_TILE_H10 = 0x8b,
1466 SC_QZ2_QUAD_PER_TILE_H11 = 0x8c,
1467 SC_QZ2_QUAD_PER_TILE_H12 = 0x8d,
1468 SC_QZ2_QUAD_PER_TILE_H13 = 0x8e,
1469 SC_QZ2_QUAD_PER_TILE_H14 = 0x8f,
1470 SC_QZ2_QUAD_PER_TILE_H15 = 0x90,
1471 SC_QZ2_QUAD_PER_TILE_H16 = 0x91,
1472 SC_QZ3_QUAD_PER_TILE_H0 = 0x92,
1473 SC_QZ3_QUAD_PER_TILE_H1 = 0x93,
1474 SC_QZ3_QUAD_PER_TILE_H2 = 0x94,
1475 SC_QZ3_QUAD_PER_TILE_H3 = 0x95,
1476 SC_QZ3_QUAD_PER_TILE_H4 = 0x96,
1477 SC_QZ3_QUAD_PER_TILE_H5 = 0x97,
1478 SC_QZ3_QUAD_PER_TILE_H6 = 0x98,
1479 SC_QZ3_QUAD_PER_TILE_H7 = 0x99,
1480 SC_QZ3_QUAD_PER_TILE_H8 = 0x9a,
1481 SC_QZ3_QUAD_PER_TILE_H9 = 0x9b,
1482 SC_QZ3_QUAD_PER_TILE_H10 = 0x9c,
1483 SC_QZ3_QUAD_PER_TILE_H11 = 0x9d,
1484 SC_QZ3_QUAD_PER_TILE_H12 = 0x9e,
1485 SC_QZ3_QUAD_PER_TILE_H13 = 0x9f,
1486 SC_QZ3_QUAD_PER_TILE_H14 = 0xa0,
1487 SC_QZ3_QUAD_PER_TILE_H15 = 0xa1,
1488 SC_QZ3_QUAD_PER_TILE_H16 = 0xa2,
1489 SC_QZ0_QUAD_COUNT = 0xa3,
1490 SC_QZ1_QUAD_COUNT = 0xa4,
1491 SC_QZ2_QUAD_COUNT = 0xa5,
1492 SC_QZ3_QUAD_COUNT = 0xa6,
1493 SC_P0_HIZ_TILE_COUNT = 0xa7,
1494 SC_P1_HIZ_TILE_COUNT = 0xa8,
1495 SC_P2_HIZ_TILE_COUNT = 0xa9,
1496 SC_P3_HIZ_TILE_COUNT = 0xaa,
1497 SC_P0_HIZ_QUAD_PER_TILE_H0 = 0xab,
1498 SC_P0_HIZ_QUAD_PER_TILE_H1 = 0xac,
1499 SC_P0_HIZ_QUAD_PER_TILE_H2 = 0xad,
1500 SC_P0_HIZ_QUAD_PER_TILE_H3 = 0xae,
1501 SC_P0_HIZ_QUAD_PER_TILE_H4 = 0xaf,
1502 SC_P0_HIZ_QUAD_PER_TILE_H5 = 0xb0,
1503 SC_P0_HIZ_QUAD_PER_TILE_H6 = 0xb1,
1504 SC_P0_HIZ_QUAD_PER_TILE_H7 = 0xb2,
1505 SC_P0_HIZ_QUAD_PER_TILE_H8 = 0xb3,
1506 SC_P0_HIZ_QUAD_PER_TILE_H9 = 0xb4,
1507 SC_P0_HIZ_QUAD_PER_TILE_H10 = 0xb5,
1508 SC_P0_HIZ_QUAD_PER_TILE_H11 = 0xb6,
1509 SC_P0_HIZ_QUAD_PER_TILE_H12 = 0xb7,
1510 SC_P0_HIZ_QUAD_PER_TILE_H13 = 0xb8,
1511 SC_P0_HIZ_QUAD_PER_TILE_H14 = 0xb9,
1512 SC_P0_HIZ_QUAD_PER_TILE_H15 = 0xba,
1513 SC_P0_HIZ_QUAD_PER_TILE_H16 = 0xbb,
1514 SC_P1_HIZ_QUAD_PER_TILE_H0 = 0xbc,
1515 SC_P1_HIZ_QUAD_PER_TILE_H1 = 0xbd,
1516 SC_P1_HIZ_QUAD_PER_TILE_H2 = 0xbe,
1517 SC_P1_HIZ_QUAD_PER_TILE_H3 = 0xbf,
1518 SC_P1_HIZ_QUAD_PER_TILE_H4 = 0xc0,
1519 SC_P1_HIZ_QUAD_PER_TILE_H5 = 0xc1,
1520 SC_P1_HIZ_QUAD_PER_TILE_H6 = 0xc2,
1521 SC_P1_HIZ_QUAD_PER_TILE_H7 = 0xc3,
1522 SC_P1_HIZ_QUAD_PER_TILE_H8 = 0xc4,
1523 SC_P1_HIZ_QUAD_PER_TILE_H9 = 0xc5,
1524 SC_P1_HIZ_QUAD_PER_TILE_H10 = 0xc6,
1525 SC_P1_HIZ_QUAD_PER_TILE_H11 = 0xc7,
1526 SC_P1_HIZ_QUAD_PER_TILE_H12 = 0xc8,
1527 SC_P1_HIZ_QUAD_PER_TILE_H13 = 0xc9,
1528 SC_P1_HIZ_QUAD_PER_TILE_H14 = 0xca,
1529 SC_P1_HIZ_QUAD_PER_TILE_H15 = 0xcb,
1530 SC_P1_HIZ_QUAD_PER_TILE_H16 = 0xcc,
1531 SC_P2_HIZ_QUAD_PER_TILE_H0 = 0xcd,
1532 SC_P2_HIZ_QUAD_PER_TILE_H1 = 0xce,
1533 SC_P2_HIZ_QUAD_PER_TILE_H2 = 0xcf,
1534 SC_P2_HIZ_QUAD_PER_TILE_H3 = 0xd0,
1535 SC_P2_HIZ_QUAD_PER_TILE_H4 = 0xd1,
1536 SC_P2_HIZ_QUAD_PER_TILE_H5 = 0xd2,
1537 SC_P2_HIZ_QUAD_PER_TILE_H6 = 0xd3,
1538 SC_P2_HIZ_QUAD_PER_TILE_H7 = 0xd4,
1539 SC_P2_HIZ_QUAD_PER_TILE_H8 = 0xd5,
1540 SC_P2_HIZ_QUAD_PER_TILE_H9 = 0xd6,
1541 SC_P2_HIZ_QUAD_PER_TILE_H10 = 0xd7,
1542 SC_P2_HIZ_QUAD_PER_TILE_H11 = 0xd8,
1543 SC_P2_HIZ_QUAD_PER_TILE_H12 = 0xd9,
1544 SC_P2_HIZ_QUAD_PER_TILE_H13 = 0xda,
1545 SC_P2_HIZ_QUAD_PER_TILE_H14 = 0xdb,
1546 SC_P2_HIZ_QUAD_PER_TILE_H15 = 0xdc,
1547 SC_P2_HIZ_QUAD_PER_TILE_H16 = 0xdd,
1548 SC_P3_HIZ_QUAD_PER_TILE_H0 = 0xde,
1549 SC_P3_HIZ_QUAD_PER_TILE_H1 = 0xdf,
1550 SC_P3_HIZ_QUAD_PER_TILE_H2 = 0xe0,
1551 SC_P3_HIZ_QUAD_PER_TILE_H3 = 0xe1,
1552 SC_P3_HIZ_QUAD_PER_TILE_H4 = 0xe2,
1553 SC_P3_HIZ_QUAD_PER_TILE_H5 = 0xe3,
1554 SC_P3_HIZ_QUAD_PER_TILE_H6 = 0xe4,
1555 SC_P3_HIZ_QUAD_PER_TILE_H7 = 0xe5,
1556 SC_P3_HIZ_QUAD_PER_TILE_H8 = 0xe6,
1557 SC_P3_HIZ_QUAD_PER_TILE_H9 = 0xe7,
1558 SC_P3_HIZ_QUAD_PER_TILE_H10 = 0xe8,
1559 SC_P3_HIZ_QUAD_PER_TILE_H11 = 0xe9,
1560 SC_P3_HIZ_QUAD_PER_TILE_H12 = 0xea,
1561 SC_P3_HIZ_QUAD_PER_TILE_H13 = 0xeb,
1562 SC_P3_HIZ_QUAD_PER_TILE_H14 = 0xec,
1563 SC_P3_HIZ_QUAD_PER_TILE_H15 = 0xed,
1564 SC_P3_HIZ_QUAD_PER_TILE_H16 = 0xee,
1565 SC_P0_HIZ_QUAD_COUNT = 0xef,
1566 SC_P1_HIZ_QUAD_COUNT = 0xf0,
1567 SC_P2_HIZ_QUAD_COUNT = 0xf1,
1568 SC_P3_HIZ_QUAD_COUNT = 0xf2,
1569 SC_P0_DETAIL_QUAD_COUNT = 0xf3,
1570 SC_P1_DETAIL_QUAD_COUNT = 0xf4,
1571 SC_P2_DETAIL_QUAD_COUNT = 0xf5,
1572 SC_P3_DETAIL_QUAD_COUNT = 0xf6,
1573 SC_P0_DETAIL_QUAD_WITH_1_PIX = 0xf7,
1574 SC_P0_DETAIL_QUAD_WITH_2_PIX = 0xf8,
1575 SC_P0_DETAIL_QUAD_WITH_3_PIX = 0xf9,
1576 SC_P0_DETAIL_QUAD_WITH_4_PIX = 0xfa,
1577 SC_P1_DETAIL_QUAD_WITH_1_PIX = 0xfb,
1578 SC_P1_DETAIL_QUAD_WITH_2_PIX = 0xfc,
1579 SC_P1_DETAIL_QUAD_WITH_3_PIX = 0xfd,
1580 SC_P1_DETAIL_QUAD_WITH_4_PIX = 0xfe,
1581 SC_P2_DETAIL_QUAD_WITH_1_PIX = 0xff,
1582 SC_P2_DETAIL_QUAD_WITH_2_PIX = 0x100,
1583 SC_P2_DETAIL_QUAD_WITH_3_PIX = 0x101,
1584 SC_P2_DETAIL_QUAD_WITH_4_PIX = 0x102,
1585 SC_P3_DETAIL_QUAD_WITH_1_PIX = 0x103,
1586 SC_P3_DETAIL_QUAD_WITH_2_PIX = 0x104,
1587 SC_P3_DETAIL_QUAD_WITH_3_PIX = 0x105,
1588 SC_P3_DETAIL_QUAD_WITH_4_PIX = 0x106,
1589 SC_EARLYZ_QUAD_COUNT = 0x107,
1590 SC_EARLYZ_QUAD_WITH_1_PIX = 0x108,
1591 SC_EARLYZ_QUAD_WITH_2_PIX = 0x109,
1592 SC_EARLYZ_QUAD_WITH_3_PIX = 0x10a,
1593 SC_EARLYZ_QUAD_WITH_4_PIX = 0x10b,
1594 SC_PKR_QUAD_PER_ROW_H1 = 0x10c,
1595 SC_PKR_QUAD_PER_ROW_H2 = 0x10d,
1596 SC_PKR_QUAD_PER_ROW_H3 = 0x10e,
1597 SC_PKR_QUAD_PER_ROW_H4 = 0x10f,
1598 SC_PKR_END_OF_VECTOR = 0x110,
1599 SC_PKR_CONTROL_XFER = 0x111,
1600 SC_PKR_DBHANG_FORCE_EOV = 0x112,
1601 SC_REG_SCLK_BUSY = 0x113,
1602 SC_GRP0_DYN_SCLK_BUSY = 0x114,
1603 SC_GRP1_DYN_SCLK_BUSY = 0x115,
1604 SC_GRP2_DYN_SCLK_BUSY = 0x116,
1605 SC_GRP3_DYN_SCLK_BUSY = 0x117,
1606 SC_GRP4_DYN_SCLK_BUSY = 0x118,
1607 SC_PA0_SC_DATA_FIFO_RD = 0x119,
1608 SC_PA0_SC_DATA_FIFO_WE = 0x11a,
1609 SC_PA1_SC_DATA_FIFO_RD = 0x11b,
1610 SC_PA1_SC_DATA_FIFO_WE = 0x11c,
1611 SC_PS_ARB_XFC_ALL_EVENT_OR_PRIM_CYCLES = 0x11d,
1612 SC_PS_ARB_XFC_ONLY_PRIM_CYCLES = 0x11e,
1613 SC_PS_ARB_XFC_ONLY_ONE_INC_PER_PRIM = 0x11f,
1614 SC_PS_ARB_STALLED_FROM_BELOW = 0x120,
1615 SC_PS_ARB_STARVED_FROM_ABOVE = 0x121,
1616 SC_PS_ARB_SC_BUSY = 0x122,
1617 SC_PS_ARB_PA_SC_BUSY = 0x123,
1618 SC_PA2_SC_DATA_FIFO_RD = 0x124,
1619 SC_PA2_SC_DATA_FIFO_WE = 0x125,
1620 SC_PA3_SC_DATA_FIFO_RD = 0x126,
1621 SC_PA3_SC_DATA_FIFO_WE = 0x127,
1622 SC_PA_SC_DEALLOC_0_0_WE = 0x128,
1623 SC_PA_SC_DEALLOC_0_1_WE = 0x129,
1624 SC_PA_SC_DEALLOC_1_0_WE = 0x12a,
1625 SC_PA_SC_DEALLOC_1_1_WE = 0x12b,
1626 SC_PA_SC_DEALLOC_2_0_WE = 0x12c,
1627 SC_PA_SC_DEALLOC_2_1_WE = 0x12d,
1628 SC_PA_SC_DEALLOC_3_0_WE = 0x12e,
1629 SC_PA_SC_DEALLOC_3_1_WE = 0x12f,
1630 SC_PA0_SC_EOP_WE = 0x130,
1631 SC_PA0_SC_EOPG_WE = 0x131,
1632 SC_PA0_SC_EVENT_WE = 0x132,
1633 SC_PA1_SC_EOP_WE = 0x133,
1634 SC_PA1_SC_EOPG_WE = 0x134,
1635 SC_PA1_SC_EVENT_WE = 0x135,
1636 SC_PA2_SC_EOP_WE = 0x136,
1637 SC_PA2_SC_EOPG_WE = 0x137,
1638 SC_PA2_SC_EVENT_WE = 0x138,
1639 SC_PA3_SC_EOP_WE = 0x139,
1640 SC_PA3_SC_EOPG_WE = 0x13a,
1641 SC_PA3_SC_EVENT_WE = 0x13b,
1642 SC_PS_ARB_OOO_THRESHOLD_SWITCH_TO_DESIRED_FIFO = 0x13c,
1643 SC_PS_ARB_OOO_FIFO_EMPTY_SWITCH = 0x13d,
1644 SC_PS_ARB_NULL_PRIM_BUBBLE_POP = 0x13e,
1645 SC_PS_ARB_EOP_POP_SYNC_POP = 0x13f,
1646 SC_PS_ARB_EVENT_SYNC_POP = 0x140,
1647 SC_SC_PS_ENG_MULTICYCLE_BUBBLE = 0x141,
1648 SC_PA0_SC_FPOV_WE = 0x142,
1649 SC_PA1_SC_FPOV_WE = 0x143,
1650 SC_PA2_SC_FPOV_WE = 0x144,
1651 SC_PA3_SC_FPOV_WE = 0x145,
1652 SC_PA0_SC_LPOV_WE = 0x146,
1653 SC_PA1_SC_LPOV_WE = 0x147,
1654 SC_PA2_SC_LPOV_WE = 0x148,
1655 SC_PA3_SC_LPOV_WE = 0x149,
1656 SC_SC_SPI_DEALLOC_0_0 = 0x14a,
1657 SC_SC_SPI_DEALLOC_0_1 = 0x14b,
1658 SC_SC_SPI_DEALLOC_0_2 = 0x14c,
1659 SC_SC_SPI_DEALLOC_1_0 = 0x14d,
1660 SC_SC_SPI_DEALLOC_1_1 = 0x14e,
1661 SC_SC_SPI_DEALLOC_1_2 = 0x14f,
1662 SC_SC_SPI_DEALLOC_2_0 = 0x150,
1663 SC_SC_SPI_DEALLOC_2_1 = 0x151,
1664 SC_SC_SPI_DEALLOC_2_2 = 0x152,
1665 SC_SC_SPI_DEALLOC_3_0 = 0x153,
1666 SC_SC_SPI_DEALLOC_3_1 = 0x154,
1667 SC_SC_SPI_DEALLOC_3_2 = 0x155,
1668 SC_SC_SPI_FPOV_0 = 0x156,
1669 SC_SC_SPI_FPOV_1 = 0x157,
1670 SC_SC_SPI_FPOV_2 = 0x158,
1671 SC_SC_SPI_FPOV_3 = 0x159,
1672 SC_SC_SPI_EVENT = 0x15a,
1673 SC_PS_TS_EVENT_FIFO_PUSH = 0x15b,
1674 SC_PS_TS_EVENT_FIFO_POP = 0x15c,
1675 SC_PS_CTX_DONE_FIFO_PUSH = 0x15d,
1676 SC_PS_CTX_DONE_FIFO_POP = 0x15e,
1677 SC_MULTICYCLE_BUBBLE_FREEZE = 0x15f,
1678 SC_EOP_SYNC_WINDOW = 0x160,
1679 SC_PA0_SC_NULL_WE = 0x161,
1680 SC_PA0_SC_NULL_DEALLOC_WE = 0x162,
1681 SC_PA0_SC_DATA_FIFO_EOPG_RD = 0x163,
1682 SC_PA0_SC_DATA_FIFO_EOP_RD = 0x164,
1683 SC_PA0_SC_DEALLOC_0_RD = 0x165,
1684 SC_PA0_SC_DEALLOC_1_RD = 0x166,
1685 SC_PA1_SC_DATA_FIFO_EOPG_RD = 0x167,
1686 SC_PA1_SC_DATA_FIFO_EOP_RD = 0x168,
1687 SC_PA1_SC_DEALLOC_0_RD = 0x169,
1688 SC_PA1_SC_DEALLOC_1_RD = 0x16a,
1689 SC_PA1_SC_NULL_WE = 0x16b,
1690 SC_PA1_SC_NULL_DEALLOC_WE = 0x16c,
1691 SC_PA2_SC_DATA_FIFO_EOPG_RD = 0x16d,
1692 SC_PA2_SC_DATA_FIFO_EOP_RD = 0x16e,
1693 SC_PA2_SC_DEALLOC_0_RD = 0x16f,
1694 SC_PA2_SC_DEALLOC_1_RD = 0x170,
1695 SC_PA2_SC_NULL_WE = 0x171,
1696 SC_PA2_SC_NULL_DEALLOC_WE = 0x172,
1697 SC_PA3_SC_DATA_FIFO_EOPG_RD = 0x173,
1698 SC_PA3_SC_DATA_FIFO_EOP_RD = 0x174,
1699 SC_PA3_SC_DEALLOC_0_RD = 0x175,
1700 SC_PA3_SC_DEALLOC_1_RD = 0x176,
1701 SC_PA3_SC_NULL_WE = 0x177,
1702 SC_PA3_SC_NULL_DEALLOC_WE = 0x178,
1703 SC_PS_PA0_SC_FIFO_EMPTY = 0x179,
1704 SC_PS_PA0_SC_FIFO_FULL = 0x17a,
1705 SC_PA0_PS_DATA_SEND = 0x17b,
1706 SC_PS_PA1_SC_FIFO_EMPTY = 0x17c,
1707 SC_PS_PA1_SC_FIFO_FULL = 0x17d,
1708 SC_PA1_PS_DATA_SEND = 0x17e,
1709 SC_PS_PA2_SC_FIFO_EMPTY = 0x17f,
1710 SC_PS_PA2_SC_FIFO_FULL = 0x180,
1711 SC_PA2_PS_DATA_SEND = 0x181,
1712 SC_PS_PA3_SC_FIFO_EMPTY = 0x182,
1713 SC_PS_PA3_SC_FIFO_FULL = 0x183,
1714 SC_PA3_PS_DATA_SEND = 0x184,
1715 SC_BUSY_PROCESSING_MULTICYCLE_PRIM = 0x185,
1716 SC_BUSY_CNT_NOT_ZERO = 0x186,
1717 SC_BM_BUSY = 0x187,
1718 SC_BACKEND_BUSY = 0x188,
1719 SC_SCF_SCB_INTERFACE_BUSY = 0x189,
1720 SC_SCB_BUSY = 0x18a,
1721 SC_STARVED_BY_PA_WITH_UNSELECTED_PA_NOT_EMPTY = 0x18b,
1722 SC_STARVED_BY_PA_WITH_UNSELECTED_PA_FULL = 0x18c,
1723 } SC_PERFCNT_SEL;
1724 typedef enum SePairXsel {
1725 RASTER_CONFIG_SE_PAIR_XSEL_8_WIDE_TILE = 0x0,
1726 RASTER_CONFIG_SE_PAIR_XSEL_16_WIDE_TILE = 0x1,
1727 RASTER_CONFIG_SE_PAIR_XSEL_32_WIDE_TILE = 0x2,
1728 RASTER_CONFIG_SE_PAIR_XSEL_64_WIDE_TILE = 0x3,
1729 } SePairXsel;
1730 typedef enum SePairYsel {
1731 RASTER_CONFIG_SE_PAIR_YSEL_8_WIDE_TILE = 0x0,
1732 RASTER_CONFIG_SE_PAIR_YSEL_16_WIDE_TILE = 0x1,
1733 RASTER_CONFIG_SE_PAIR_YSEL_32_WIDE_TILE = 0x2,
1734 RASTER_CONFIG_SE_PAIR_YSEL_64_WIDE_TILE = 0x3,
1735 } SePairYsel;
1736 typedef enum SePairMap {
1737 RASTER_CONFIG_SE_PAIR_MAP_0 = 0x0,
1738 RASTER_CONFIG_SE_PAIR_MAP_1 = 0x1,
1739 RASTER_CONFIG_SE_PAIR_MAP_2 = 0x2,
1740 RASTER_CONFIG_SE_PAIR_MAP_3 = 0x3,
1741 } SePairMap;
1742 typedef enum SeXsel {
1743 RASTER_CONFIG_SE_XSEL_8_WIDE_TILE = 0x0,
1744 RASTER_CONFIG_SE_XSEL_16_WIDE_TILE = 0x1,
1745 RASTER_CONFIG_SE_XSEL_32_WIDE_TILE = 0x2,
1746 RASTER_CONFIG_SE_XSEL_64_WIDE_TILE = 0x3,
1747 } SeXsel;
1748 typedef enum SeYsel {
1749 RASTER_CONFIG_SE_YSEL_8_WIDE_TILE = 0x0,
1750 RASTER_CONFIG_SE_YSEL_16_WIDE_TILE = 0x1,
1751 RASTER_CONFIG_SE_YSEL_32_WIDE_TILE = 0x2,
1752 RASTER_CONFIG_SE_YSEL_64_WIDE_TILE = 0x3,
1753 } SeYsel;
1754 typedef enum SeMap {
1755 RASTER_CONFIG_SE_MAP_0 = 0x0,
1756 RASTER_CONFIG_SE_MAP_1 = 0x1,
1757 RASTER_CONFIG_SE_MAP_2 = 0x2,
1758 RASTER_CONFIG_SE_MAP_3 = 0x3,
1759 } SeMap;
1760 typedef enum ScXsel {
1761 RASTER_CONFIG_SC_XSEL_8_WIDE_TILE = 0x0,
1762 RASTER_CONFIG_SC_XSEL_16_WIDE_TILE = 0x1,
1763 RASTER_CONFIG_SC_XSEL_32_WIDE_TILE = 0x2,
1764 RASTER_CONFIG_SC_XSEL_64_WIDE_TILE = 0x3,
1765 } ScXsel;
1766 typedef enum ScYsel {
1767 RASTER_CONFIG_SC_YSEL_8_WIDE_TILE = 0x0,
1768 RASTER_CONFIG_SC_YSEL_16_WIDE_TILE = 0x1,
1769 RASTER_CONFIG_SC_YSEL_32_WIDE_TILE = 0x2,
1770 RASTER_CONFIG_SC_YSEL_64_WIDE_TILE = 0x3,
1771 } ScYsel;
1772 typedef enum ScMap {
1773 RASTER_CONFIG_SC_MAP_0 = 0x0,
1774 RASTER_CONFIG_SC_MAP_1 = 0x1,
1775 RASTER_CONFIG_SC_MAP_2 = 0x2,
1776 RASTER_CONFIG_SC_MAP_3 = 0x3,
1777 } ScMap;
1778 typedef enum PkrXsel2 {
1779 RASTER_CONFIG_PKR_XSEL2_0 = 0x0,
1780 RASTER_CONFIG_PKR_XSEL2_1 = 0x1,
1781 RASTER_CONFIG_PKR_XSEL2_2 = 0x2,
1782 RASTER_CONFIG_PKR_XSEL2_3 = 0x3,
1783 } PkrXsel2;
1784 typedef enum PkrXsel {
1785 RASTER_CONFIG_PKR_XSEL_0 = 0x0,
1786 RASTER_CONFIG_PKR_XSEL_1 = 0x1,
1787 RASTER_CONFIG_PKR_XSEL_2 = 0x2,
1788 RASTER_CONFIG_PKR_XSEL_3 = 0x3,
1789 } PkrXsel;
1790 typedef enum PkrYsel {
1791 RASTER_CONFIG_PKR_YSEL_0 = 0x0,
1792 RASTER_CONFIG_PKR_YSEL_1 = 0x1,
1793 RASTER_CONFIG_PKR_YSEL_2 = 0x2,
1794 RASTER_CONFIG_PKR_YSEL_3 = 0x3,
1795 } PkrYsel;
1796 typedef enum PkrMap {
1797 RASTER_CONFIG_PKR_MAP_0 = 0x0,
1798 RASTER_CONFIG_PKR_MAP_1 = 0x1,
1799 RASTER_CONFIG_PKR_MAP_2 = 0x2,
1800 RASTER_CONFIG_PKR_MAP_3 = 0x3,
1801 } PkrMap;
1802 typedef enum RbXsel {
1803 RASTER_CONFIG_RB_XSEL_0 = 0x0,
1804 RASTER_CONFIG_RB_XSEL_1 = 0x1,
1805 } RbXsel;
1806 typedef enum RbYsel {
1807 RASTER_CONFIG_RB_YSEL_0 = 0x0,
1808 RASTER_CONFIG_RB_YSEL_1 = 0x1,
1809 } RbYsel;
1810 typedef enum RbXsel2 {
1811 RASTER_CONFIG_RB_XSEL2_0 = 0x0,
1812 RASTER_CONFIG_RB_XSEL2_1 = 0x1,
1813 RASTER_CONFIG_RB_XSEL2_2 = 0x2,
1814 RASTER_CONFIG_RB_XSEL2_3 = 0x3,
1815 } RbXsel2;
1816 typedef enum RbMap {
1817 RASTER_CONFIG_RB_MAP_0 = 0x0,
1818 RASTER_CONFIG_RB_MAP_1 = 0x1,
1819 RASTER_CONFIG_RB_MAP_2 = 0x2,
1820 RASTER_CONFIG_RB_MAP_3 = 0x3,
1821 } RbMap;
1822 typedef enum CSDATA_TYPE {
1823 CSDATA_TYPE_TG = 0x0,
1824 CSDATA_TYPE_STATE = 0x1,
1825 CSDATA_TYPE_EVENT = 0x2,
1826 CSDATA_TYPE_PRIVATE = 0x3,
1827 } CSDATA_TYPE;
1828 #define CSDATA_TYPE_WIDTH 0x2
1829 #define CSDATA_ADDR_WIDTH 0x7
1830 #define CSDATA_DATA_WIDTH 0x20
1831 typedef enum SPI_SAMPLE_CNTL {
1832 CENTROIDS_ONLY = 0x0,
1833 CENTERS_ONLY = 0x1,
1834 CENTROIDS_AND_CENTERS = 0x2,
1835 UNDEF = 0x3,
1836 } SPI_SAMPLE_CNTL;
1837 typedef enum SPI_FOG_MODE {
1838 SPI_FOG_NONE = 0x0,
1839 SPI_FOG_EXP = 0x1,
1840 SPI_FOG_EXP2 = 0x2,
1841 SPI_FOG_LINEAR = 0x3,
1842 } SPI_FOG_MODE;
1843 typedef enum SPI_PNT_SPRITE_OVERRIDE {
1844 SPI_PNT_SPRITE_SEL_0 = 0x0,
1845 SPI_PNT_SPRITE_SEL_1 = 0x1,
1846 SPI_PNT_SPRITE_SEL_S = 0x2,
1847 SPI_PNT_SPRITE_SEL_T = 0x3,
1848 SPI_PNT_SPRITE_SEL_NONE = 0x4,
1849 } SPI_PNT_SPRITE_OVERRIDE;
1850 typedef enum SPI_PERFCNT_SEL {
1851 SPI_PERF_VS_WINDOW_VALID = 0x0,
1852 SPI_PERF_VS_BUSY = 0x1,
1853 SPI_PERF_VS_FIRST_WAVE = 0x2,
1854 SPI_PERF_VS_LAST_WAVE = 0x3,
1855 SPI_PERF_VS_LSHS_DEALLOC = 0x4,
1856 SPI_PERF_VS_PC_STALL = 0x5,
1857 SPI_PERF_VS_POS0_STALL = 0x6,
1858 SPI_PERF_VS_POS1_STALL = 0x7,
1859 SPI_PERF_VS_CRAWLER_STALL = 0x8,
1860 SPI_PERF_VS_EVENT_WAVE = 0x9,
1861 SPI_PERF_VS_WAVE = 0xa,
1862 SPI_PERF_VS_PERS_UPD_FULL0 = 0xb,
1863 SPI_PERF_VS_PERS_UPD_FULL1 = 0xc,
1864 SPI_PERF_VS_LATE_ALLOC_FULL = 0xd,
1865 SPI_PERF_VS_FIRST_SUBGRP = 0xe,
1866 SPI_PERF_VS_LAST_SUBGRP = 0xf,
1867 SPI_PERF_GS_WINDOW_VALID = 0x10,
1868 SPI_PERF_GS_BUSY = 0x11,
1869 SPI_PERF_GS_CRAWLER_STALL = 0x12,
1870 SPI_PERF_GS_EVENT_WAVE = 0x13,
1871 SPI_PERF_GS_WAVE = 0x14,
1872 SPI_PERF_GS_PERS_UPD_FULL0 = 0x15,
1873 SPI_PERF_GS_PERS_UPD_FULL1 = 0x16,
1874 SPI_PERF_GS_FIRST_SUBGRP = 0x17,
1875 SPI_PERF_GS_LAST_SUBGRP = 0x18,
1876 SPI_PERF_ES_WINDOW_VALID = 0x19,
1877 SPI_PERF_ES_BUSY = 0x1a,
1878 SPI_PERF_ES_CRAWLER_STALL = 0x1b,
1879 SPI_PERF_ES_FIRST_WAVE = 0x1c,
1880 SPI_PERF_ES_LAST_WAVE = 0x1d,
1881 SPI_PERF_ES_LSHS_DEALLOC = 0x1e,
1882 SPI_PERF_ES_EVENT_WAVE = 0x1f,
1883 SPI_PERF_ES_WAVE = 0x20,
1884 SPI_PERF_ES_PERS_UPD_FULL0 = 0x21,
1885 SPI_PERF_ES_PERS_UPD_FULL1 = 0x22,
1886 SPI_PERF_ES_FIRST_SUBGRP = 0x23,
1887 SPI_PERF_ES_LAST_SUBGRP = 0x24,
1888 SPI_PERF_HS_WINDOW_VALID = 0x25,
1889 SPI_PERF_HS_BUSY = 0x26,
1890 SPI_PERF_HS_CRAWLER_STALL = 0x27,
1891 SPI_PERF_HS_FIRST_WAVE = 0x28,
1892 SPI_PERF_HS_LAST_WAVE = 0x29,
1893 SPI_PERF_HS_LSHS_DEALLOC = 0x2a,
1894 SPI_PERF_HS_EVENT_WAVE = 0x2b,
1895 SPI_PERF_HS_WAVE = 0x2c,
1896 SPI_PERF_HS_PERS_UPD_FULL0 = 0x2d,
1897 SPI_PERF_HS_PERS_UPD_FULL1 = 0x2e,
1898 SPI_PERF_LS_WINDOW_VALID = 0x2f,
1899 SPI_PERF_LS_BUSY = 0x30,
1900 SPI_PERF_LS_CRAWLER_STALL = 0x31,
1901 SPI_PERF_LS_FIRST_WAVE = 0x32,
1902 SPI_PERF_LS_LAST_WAVE = 0x33,
1903 SPI_PERF_OFFCHIP_LDS_STALL_LS = 0x34,
1904 SPI_PERF_LS_EVENT_WAVE = 0x35,
1905 SPI_PERF_LS_WAVE = 0x36,
1906 SPI_PERF_LS_PERS_UPD_FULL0 = 0x37,
1907 SPI_PERF_LS_PERS_UPD_FULL1 = 0x38,
1908 SPI_PERF_CSG_WINDOW_VALID = 0x39,
1909 SPI_PERF_CSG_BUSY = 0x3a,
1910 SPI_PERF_CSG_NUM_THREADGROUPS = 0x3b,
1911 SPI_PERF_CSG_CRAWLER_STALL = 0x3c,
1912 SPI_PERF_CSG_EVENT_WAVE = 0x3d,
1913 SPI_PERF_CSG_WAVE = 0x3e,
1914 SPI_PERF_CSN_WINDOW_VALID = 0x3f,
1915 SPI_PERF_CSN_BUSY = 0x40,
1916 SPI_PERF_CSN_NUM_THREADGROUPS = 0x41,
1917 SPI_PERF_CSN_CRAWLER_STALL = 0x42,
1918 SPI_PERF_CSN_EVENT_WAVE = 0x43,
1919 SPI_PERF_CSN_WAVE = 0x44,
1920 SPI_PERF_PS_CTL_WINDOW_VALID = 0x45,
1921 SPI_PERF_PS_CTL_BUSY = 0x46,
1922 SPI_PERF_PS_CTL_ACTIVE = 0x47,
1923 SPI_PERF_PS_CTL_DEALLOC_BIN0 = 0x48,
1924 SPI_PERF_PS_CTL_FPOS_BIN1_STALL = 0x49,
1925 SPI_PERF_PS_CTL_EVENT_WAVE = 0x4a,
1926 SPI_PERF_PS_CTL_WAVE = 0x4b,
1927 SPI_PERF_PS_CTL_OPT_WAVE = 0x4c,
1928 SPI_PERF_PS_CTL_PASS_BIN0 = 0x4d,
1929 SPI_PERF_PS_CTL_PASS_BIN1 = 0x4e,
1930 SPI_PERF_PS_CTL_FPOS_BIN2 = 0x4f,
1931 SPI_PERF_PS_CTL_PRIM_BIN0 = 0x50,
1932 SPI_PERF_PS_CTL_PRIM_BIN1 = 0x51,
1933 SPI_PERF_PS_CTL_CNF_BIN2 = 0x52,
1934 SPI_PERF_PS_CTL_CNF_BIN3 = 0x53,
1935 SPI_PERF_PS_CTL_CRAWLER_STALL = 0x54,
1936 SPI_PERF_PS_CTL_LDS_RES_FULL = 0x55,
1937 SPI_PERF_PS_PERS_UPD_FULL0 = 0x56,
1938 SPI_PERF_PS_PERS_UPD_FULL1 = 0x57,
1939 SPI_PERF_PIX_ALLOC_PEND_CNT = 0x58,
1940 SPI_PERF_PIX_ALLOC_SCB_STALL = 0x59,
1941 SPI_PERF_PIX_ALLOC_DB0_STALL = 0x5a,
1942 SPI_PERF_PIX_ALLOC_DB1_STALL = 0x5b,
1943 SPI_PERF_PIX_ALLOC_DB2_STALL = 0x5c,
1944 SPI_PERF_PIX_ALLOC_DB3_STALL = 0x5d,
1945 SPI_PERF_LDS0_PC_VALID = 0x5e,
1946 SPI_PERF_LDS1_PC_VALID = 0x5f,
1947 SPI_PERF_RA_PIPE_REQ_BIN2 = 0x60,
1948 SPI_PERF_RA_TASK_REQ_BIN3 = 0x61,
1949 SPI_PERF_RA_WR_CTL_FULL = 0x62,
1950 SPI_PERF_RA_REQ_NO_ALLOC = 0x63,
1951 SPI_PERF_RA_REQ_NO_ALLOC_PS = 0x64,
1952 SPI_PERF_RA_REQ_NO_ALLOC_VS = 0x65,
1953 SPI_PERF_RA_REQ_NO_ALLOC_GS = 0x66,
1954 SPI_PERF_RA_REQ_NO_ALLOC_ES = 0x67,
1955 SPI_PERF_RA_REQ_NO_ALLOC_HS = 0x68,
1956 SPI_PERF_RA_REQ_NO_ALLOC_LS = 0x69,
1957 SPI_PERF_RA_REQ_NO_ALLOC_CSG = 0x6a,
1958 SPI_PERF_RA_REQ_NO_ALLOC_CSN = 0x6b,
1959 SPI_PERF_RA_RES_STALL_PS = 0x6c,
1960 SPI_PERF_RA_RES_STALL_VS = 0x6d,
1961 SPI_PERF_RA_RES_STALL_GS = 0x6e,
1962 SPI_PERF_RA_RES_STALL_ES = 0x6f,
1963 SPI_PERF_RA_RES_STALL_HS = 0x70,
1964 SPI_PERF_RA_RES_STALL_LS = 0x71,
1965 SPI_PERF_RA_RES_STALL_CSG = 0x72,
1966 SPI_PERF_RA_RES_STALL_CSN = 0x73,
1967 SPI_PERF_RA_TMP_STALL_PS = 0x74,
1968 SPI_PERF_RA_TMP_STALL_VS = 0x75,
1969 SPI_PERF_RA_TMP_STALL_GS = 0x76,
1970 SPI_PERF_RA_TMP_STALL_ES = 0x77,
1971 SPI_PERF_RA_TMP_STALL_HS = 0x78,
1972 SPI_PERF_RA_TMP_STALL_LS = 0x79,
1973 SPI_PERF_RA_TMP_STALL_CSG = 0x7a,
1974 SPI_PERF_RA_TMP_STALL_CSN = 0x7b,
1975 SPI_PERF_RA_WAVE_SIMD_FULL_PS = 0x7c,
1976 SPI_PERF_RA_WAVE_SIMD_FULL_VS = 0x7d,
1977 SPI_PERF_RA_WAVE_SIMD_FULL_GS = 0x7e,
1978 SPI_PERF_RA_WAVE_SIMD_FULL_ES = 0x7f,
1979 SPI_PERF_RA_WAVE_SIMD_FULL_HS = 0x80,
1980 SPI_PERF_RA_WAVE_SIMD_FULL_LS = 0x81,
1981 SPI_PERF_RA_WAVE_SIMD_FULL_CSG = 0x82,
1982 SPI_PERF_RA_WAVE_SIMD_FULL_CSN = 0x83,
1983 SPI_PERF_RA_VGPR_SIMD_FULL_PS = 0x84,
1984 SPI_PERF_RA_VGPR_SIMD_FULL_VS = 0x85,
1985 SPI_PERF_RA_VGPR_SIMD_FULL_GS = 0x86,
1986 SPI_PERF_RA_VGPR_SIMD_FULL_ES = 0x87,
1987 SPI_PERF_RA_VGPR_SIMD_FULL_HS = 0x88,
1988 SPI_PERF_RA_VGPR_SIMD_FULL_LS = 0x89,
1989 SPI_PERF_RA_VGPR_SIMD_FULL_CSG = 0x8a,
1990 SPI_PERF_RA_VGPR_SIMD_FULL_CSN = 0x8b,
1991 SPI_PERF_RA_SGPR_SIMD_FULL_PS = 0x8c,
1992 SPI_PERF_RA_SGPR_SIMD_FULL_VS = 0x8d,
1993 SPI_PERF_RA_SGPR_SIMD_FULL_GS = 0x8e,
1994 SPI_PERF_RA_SGPR_SIMD_FULL_ES = 0x8f,
1995 SPI_PERF_RA_SGPR_SIMD_FULL_HS = 0x90,
1996 SPI_PERF_RA_SGPR_SIMD_FULL_LS = 0x91,
1997 SPI_PERF_RA_SGPR_SIMD_FULL_CSG = 0x92,
1998 SPI_PERF_RA_SGPR_SIMD_FULL_CSN = 0x93,
1999 SPI_PERF_RA_LDS_CU_FULL_PS = 0x94,
2000 SPI_PERF_RA_LDS_CU_FULL_LS = 0x95,
2001 SPI_PERF_RA_LDS_CU_FULL_ES = 0x96,
2002 SPI_PERF_RA_LDS_CU_FULL_CSG = 0x97,
2003 SPI_PERF_RA_LDS_CU_FULL_CSN = 0x98,
2004 SPI_PERF_RA_BAR_CU_FULL_HS = 0x99,
2005 SPI_PERF_RA_BAR_CU_FULL_CSG = 0x9a,
2006 SPI_PERF_RA_BAR_CU_FULL_CSN = 0x9b,
2007 SPI_PERF_RA_BULKY_CU_FULL_CSG = 0x9c,
2008 SPI_PERF_RA_BULKY_CU_FULL_CSN = 0x9d,
2009 SPI_PERF_RA_TGLIM_CU_FULL_CSG = 0x9e,
2010 SPI_PERF_RA_TGLIM_CU_FULL_CSN = 0x9f,
2011 SPI_PERF_RA_WVLIM_STALL_PS = 0xa0,
2012 SPI_PERF_RA_WVLIM_STALL_VS = 0xa1,
2013 SPI_PERF_RA_WVLIM_STALL_GS = 0xa2,
2014 SPI_PERF_RA_WVLIM_STALL_ES = 0xa3,
2015 SPI_PERF_RA_WVLIM_STALL_HS = 0xa4,
2016 SPI_PERF_RA_WVLIM_STALL_LS = 0xa5,
2017 SPI_PERF_RA_WVLIM_STALL_CSG = 0xa6,
2018 SPI_PERF_RA_WVLIM_STALL_CSN = 0xa7,
2019 SPI_PERF_RA_PS_LOCK_NA = 0xa8,
2020 SPI_PERF_RA_VS_LOCK = 0xa9,
2021 SPI_PERF_RA_GS_LOCK = 0xaa,
2022 SPI_PERF_RA_ES_LOCK = 0xab,
2023 SPI_PERF_RA_HS_LOCK = 0xac,
2024 SPI_PERF_RA_LS_LOCK = 0xad,
2025 SPI_PERF_RA_CSG_LOCK = 0xae,
2026 SPI_PERF_RA_CSN_LOCK = 0xaf,
2027 SPI_PERF_RA_RSV_UPD = 0xb0,
2028 SPI_PERF_EXP_ARB_COL_CNT = 0xb1,
2029 SPI_PERF_EXP_ARB_PAR_CNT = 0xb2,
2030 SPI_PERF_EXP_ARB_POS_CNT = 0xb3,
2031 SPI_PERF_EXP_ARB_GDS_CNT = 0xb4,
2032 SPI_PERF_CLKGATE_BUSY_STALL = 0xb5,
2033 SPI_PERF_CLKGATE_ACTIVE_STALL = 0xb6,
2034 SPI_PERF_CLKGATE_ALL_CLOCKS_ON = 0xb7,
2035 SPI_PERF_CLKGATE_CGTT_DYN_ON = 0xb8,
2036 SPI_PERF_CLKGATE_CGTT_REG_ON = 0xb9,
2037 SPI_PERF_NUM_VS_POS_EXPORTS = 0xba,
2038 SPI_PERF_NUM_VS_PARAM_EXPORTS = 0xbb,
2039 SPI_PERF_NUM_PS_COL_EXPORTS = 0xbc,
2040 SPI_PERF_ES_GRP_FIFO_FULL = 0xbd,
2041 SPI_PERF_GS_GRP_FIFO_FULL = 0xbe,
2042 SPI_PERF_HS_GRP_FIFO_FULL = 0xbf,
2043 SPI_PERF_LS_GRP_FIFO_FULL = 0xc0,
2044 SPI_PERF_VS_ALLOC_CNT = 0xc1,
2045 SPI_PERF_VS_LATE_ALLOC_ACCUM = 0xc2,
2046 SPI_PERF_PC_ALLOC_CNT = 0xc3,
2047 SPI_PERF_PC_ALLOC_ACCUM = 0xc4,
2048 } SPI_PERFCNT_SEL;
2049 typedef enum SPI_SHADER_FORMAT {
2050 SPI_SHADER_NONE = 0x0,
2051 SPI_SHADER_1COMP = 0x1,
2052 SPI_SHADER_2COMP = 0x2,
2053 SPI_SHADER_4COMPRESS = 0x3,
2054 SPI_SHADER_4COMP = 0x4,
2055 } SPI_SHADER_FORMAT;
2056 typedef enum SPI_SHADER_EX_FORMAT {
2057 SPI_SHADER_ZERO = 0x0,
2058 SPI_SHADER_32_R = 0x1,
2059 SPI_SHADER_32_GR = 0x2,
2060 SPI_SHADER_32_AR = 0x3,
2061 SPI_SHADER_FP16_ABGR = 0x4,
2062 SPI_SHADER_UNORM16_ABGR = 0x5,
2063 SPI_SHADER_SNORM16_ABGR = 0x6,
2064 SPI_SHADER_UINT16_ABGR = 0x7,
2065 SPI_SHADER_SINT16_ABGR = 0x8,
2066 SPI_SHADER_32_ABGR = 0x9,
2067 } SPI_SHADER_EX_FORMAT;
2068 typedef enum CLKGATE_SM_MODE {
2069 ON_SEQ = 0x0,
2070 OFF_SEQ = 0x1,
2071 PROG_SEQ = 0x2,
2072 READ_SEQ = 0x3,
2073 SM_MODE_RESERVED = 0x4,
2074 } CLKGATE_SM_MODE;
2075 typedef enum CLKGATE_BASE_MODE {
2076 MULT_8 = 0x0,
2077 MULT_16 = 0x1,
2078 } CLKGATE_BASE_MODE;
2079 typedef enum SQ_TEX_CLAMP {
2080 SQ_TEX_WRAP = 0x0,
2081 SQ_TEX_MIRROR = 0x1,
2082 SQ_TEX_CLAMP_LAST_TEXEL = 0x2,
2083 SQ_TEX_MIRROR_ONCE_LAST_TEXEL = 0x3,
2084 SQ_TEX_CLAMP_HALF_BORDER = 0x4,
2085 SQ_TEX_MIRROR_ONCE_HALF_BORDER = 0x5,
2086 SQ_TEX_CLAMP_BORDER = 0x6,
2087 SQ_TEX_MIRROR_ONCE_BORDER = 0x7,
2088 } SQ_TEX_CLAMP;
2089 typedef enum SQ_TEX_XY_FILTER {
2090 SQ_TEX_XY_FILTER_POINT = 0x0,
2091 SQ_TEX_XY_FILTER_BILINEAR = 0x1,
2092 SQ_TEX_XY_FILTER_ANISO_POINT = 0x2,
2093 SQ_TEX_XY_FILTER_ANISO_BILINEAR = 0x3,
2094 } SQ_TEX_XY_FILTER;
2095 typedef enum SQ_TEX_Z_FILTER {
2096 SQ_TEX_Z_FILTER_NONE = 0x0,
2097 SQ_TEX_Z_FILTER_POINT = 0x1,
2098 SQ_TEX_Z_FILTER_LINEAR = 0x2,
2099 } SQ_TEX_Z_FILTER;
2100 typedef enum SQ_TEX_MIP_FILTER {
2101 SQ_TEX_MIP_FILTER_NONE = 0x0,
2102 SQ_TEX_MIP_FILTER_POINT = 0x1,
2103 SQ_TEX_MIP_FILTER_LINEAR = 0x2,
2104 SQ_TEX_MIP_FILTER_POINT_ANISO_ADJ = 0x3,
2105 } SQ_TEX_MIP_FILTER;
2106 typedef enum SQ_TEX_ANISO_RATIO {
2107 SQ_TEX_ANISO_RATIO_1 = 0x0,
2108 SQ_TEX_ANISO_RATIO_2 = 0x1,
2109 SQ_TEX_ANISO_RATIO_4 = 0x2,
2110 SQ_TEX_ANISO_RATIO_8 = 0x3,
2111 SQ_TEX_ANISO_RATIO_16 = 0x4,
2112 } SQ_TEX_ANISO_RATIO;
2113 typedef enum SQ_TEX_DEPTH_COMPARE {
2114 SQ_TEX_DEPTH_COMPARE_NEVER = 0x0,
2115 SQ_TEX_DEPTH_COMPARE_LESS = 0x1,
2116 SQ_TEX_DEPTH_COMPARE_EQUAL = 0x2,
2117 SQ_TEX_DEPTH_COMPARE_LESSEQUAL = 0x3,
2118 SQ_TEX_DEPTH_COMPARE_GREATER = 0x4,
2119 SQ_TEX_DEPTH_COMPARE_NOTEQUAL = 0x5,
2120 SQ_TEX_DEPTH_COMPARE_GREATEREQUAL = 0x6,
2121 SQ_TEX_DEPTH_COMPARE_ALWAYS = 0x7,
2122 } SQ_TEX_DEPTH_COMPARE;
2123 typedef enum SQ_TEX_BORDER_COLOR {
2124 SQ_TEX_BORDER_COLOR_TRANS_BLACK = 0x0,
2125 SQ_TEX_BORDER_COLOR_OPAQUE_BLACK = 0x1,
2126 SQ_TEX_BORDER_COLOR_OPAQUE_WHITE = 0x2,
2127 SQ_TEX_BORDER_COLOR_REGISTER = 0x3,
2128 } SQ_TEX_BORDER_COLOR;
2129 typedef enum SQ_RSRC_BUF_TYPE {
2130 SQ_RSRC_BUF = 0x0,
2131 SQ_RSRC_BUF_RSVD_1 = 0x1,
2132 SQ_RSRC_BUF_RSVD_2 = 0x2,
2133 SQ_RSRC_BUF_RSVD_3 = 0x3,
2134 } SQ_RSRC_BUF_TYPE;
2135 typedef enum SQ_RSRC_IMG_TYPE {
2136 SQ_RSRC_IMG_RSVD_0 = 0x0,
2137 SQ_RSRC_IMG_RSVD_1 = 0x1,
2138 SQ_RSRC_IMG_RSVD_2 = 0x2,
2139 SQ_RSRC_IMG_RSVD_3 = 0x3,
2140 SQ_RSRC_IMG_RSVD_4 = 0x4,
2141 SQ_RSRC_IMG_RSVD_5 = 0x5,
2142 SQ_RSRC_IMG_RSVD_6 = 0x6,
2143 SQ_RSRC_IMG_RSVD_7 = 0x7,
2144 SQ_RSRC_IMG_1D = 0x8,
2145 SQ_RSRC_IMG_2D = 0x9,
2146 SQ_RSRC_IMG_3D = 0xa,
2147 SQ_RSRC_IMG_CUBE = 0xb,
2148 SQ_RSRC_IMG_1D_ARRAY = 0xc,
2149 SQ_RSRC_IMG_2D_ARRAY = 0xd,
2150 SQ_RSRC_IMG_2D_MSAA = 0xe,
2151 SQ_RSRC_IMG_2D_MSAA_ARRAY = 0xf,
2152 } SQ_RSRC_IMG_TYPE;
2153 typedef enum SQ_RSRC_FLAT_TYPE {
2154 SQ_RSRC_FLAT_RSVD_0 = 0x0,
2155 SQ_RSRC_FLAT = 0x1,
2156 SQ_RSRC_FLAT_RSVD_2 = 0x2,
2157 SQ_RSRC_FLAT_RSVD_3 = 0x3,
2158 } SQ_RSRC_FLAT_TYPE;
2159 typedef enum SQ_IMG_FILTER_TYPE {
2160 SQ_IMG_FILTER_MODE_BLEND = 0x0,
2161 SQ_IMG_FILTER_MODE_MIN = 0x1,
2162 SQ_IMG_FILTER_MODE_MAX = 0x2,
2163 } SQ_IMG_FILTER_TYPE;
2164 typedef enum SQ_SEL_XYZW01 {
2165 SQ_SEL_0 = 0x0,
2166 SQ_SEL_1 = 0x1,
2167 SQ_SEL_RESERVED_0 = 0x2,
2168 SQ_SEL_RESERVED_1 = 0x3,
2169 SQ_SEL_X = 0x4,
2170 SQ_SEL_Y = 0x5,
2171 SQ_SEL_Z = 0x6,
2172 SQ_SEL_W = 0x7,
2173 } SQ_SEL_XYZW01;
2174 typedef enum SQ_WAVE_TYPE {
2175 SQ_WAVE_TYPE_PS = 0x0,
2176 SQ_WAVE_TYPE_VS = 0x1,
2177 SQ_WAVE_TYPE_GS = 0x2,
2178 SQ_WAVE_TYPE_ES = 0x3,
2179 SQ_WAVE_TYPE_HS = 0x4,
2180 SQ_WAVE_TYPE_LS = 0x5,
2181 SQ_WAVE_TYPE_CS = 0x6,
2182 SQ_WAVE_TYPE_PS1 = 0x7,
2183 } SQ_WAVE_TYPE;
2184 typedef enum SQ_THREAD_TRACE_TOKEN_TYPE {
2185 SQ_THREAD_TRACE_TOKEN_MISC = 0x0,
2186 SQ_THREAD_TRACE_TOKEN_TIMESTAMP = 0x1,
2187 SQ_THREAD_TRACE_TOKEN_REG = 0x2,
2188 SQ_THREAD_TRACE_TOKEN_WAVE_START = 0x3,
2189 SQ_THREAD_TRACE_TOKEN_WAVE_ALLOC = 0x4,
2190 SQ_THREAD_TRACE_TOKEN_REG_CSPRIV = 0x5,
2191 SQ_THREAD_TRACE_TOKEN_WAVE_END = 0x6,
2192 SQ_THREAD_TRACE_TOKEN_EVENT = 0x7,
2193 SQ_THREAD_TRACE_TOKEN_EVENT_CS = 0x8,
2194 SQ_THREAD_TRACE_TOKEN_EVENT_GFX1 = 0x9,
2195 SQ_THREAD_TRACE_TOKEN_INST = 0xa,
2196 SQ_THREAD_TRACE_TOKEN_INST_PC = 0xb,
2197 SQ_THREAD_TRACE_TOKEN_INST_USERDATA = 0xc,
2198 SQ_THREAD_TRACE_TOKEN_ISSUE = 0xd,
2199 SQ_THREAD_TRACE_TOKEN_PERF = 0xe,
2200 SQ_THREAD_TRACE_TOKEN_REG_CS = 0xf,
2201 } SQ_THREAD_TRACE_TOKEN_TYPE;
2202 typedef enum SQ_THREAD_TRACE_MISC_TOKEN_TYPE {
2203 SQ_THREAD_TRACE_MISC_TOKEN_TIME = 0x0,
2204 SQ_THREAD_TRACE_MISC_TOKEN_TIME_RESET = 0x1,
2205 SQ_THREAD_TRACE_MISC_TOKEN_PACKET_LOST = 0x2,
2206 SQ_THREAD_TRACE_MISC_TOKEN_SURF_SYNC = 0x3,
2207 SQ_THREAD_TRACE_MISC_TOKEN_TTRACE_STALL_BEGIN = 0x4,
2208 SQ_THREAD_TRACE_MISC_TOKEN_TTRACE_STALL_END = 0x5,
2209 SQ_THREAD_TRACE_MISC_TOKEN_SAVECTX = 0x6,
2210 SQ_THREAD_TRACE_MISC_TOKEN_SHOOT_DOWN = 0x7,
2211 } SQ_THREAD_TRACE_MISC_TOKEN_TYPE;
2212 typedef enum SQ_THREAD_TRACE_INST_TYPE {
2213 SQ_THREAD_TRACE_INST_TYPE_SMEM_RD = 0x0,
2214 SQ_THREAD_TRACE_INST_TYPE_SALU_32 = 0x1,
2215 SQ_THREAD_TRACE_INST_TYPE_VMEM_RD = 0x2,
2216 SQ_THREAD_TRACE_INST_TYPE_VMEM_WR = 0x3,
2217 SQ_THREAD_TRACE_INST_TYPE_FLAT_WR = 0x4,
2218 SQ_THREAD_TRACE_INST_TYPE_VALU_32 = 0x5,
2219 SQ_THREAD_TRACE_INST_TYPE_LDS = 0x6,
2220 SQ_THREAD_TRACE_INST_TYPE_PC = 0x7,
2221 SQ_THREAD_TRACE_INST_TYPE_EXPREQ_GDS = 0x8,
2222 SQ_THREAD_TRACE_INST_TYPE_EXPREQ_GFX = 0x9,
2223 SQ_THREAD_TRACE_INST_TYPE_EXPGNT_PAR_COL = 0xa,
2224 SQ_THREAD_TRACE_INST_TYPE_EXPGNT_POS_GDS = 0xb,
2225 SQ_THREAD_TRACE_INST_TYPE_JUMP = 0xc,
2226 SQ_THREAD_TRACE_INST_TYPE_NEXT = 0xd,
2227 SQ_THREAD_TRACE_INST_TYPE_FLAT_RD = 0xe,
2228 SQ_THREAD_TRACE_INST_TYPE_OTHER_MSG = 0xf,
2229 SQ_THREAD_TRACE_INST_TYPE_SMEM_WR = 0x10,
2230 SQ_THREAD_TRACE_INST_TYPE_SALU_64 = 0x11,
2231 SQ_THREAD_TRACE_INST_TYPE_VALU_64 = 0x12,
2232 SQ_THREAD_TRACE_INST_TYPE_SMEM_RD_REPLAY = 0x13,
2233 SQ_THREAD_TRACE_INST_TYPE_SMEM_WR_REPLAY = 0x14,
2234 SQ_THREAD_TRACE_INST_TYPE_VMEM_RD_REPLAY = 0x15,
2235 SQ_THREAD_TRACE_INST_TYPE_VMEM_WR_REPLAY = 0x16,
2236 SQ_THREAD_TRACE_INST_TYPE_FLAT_RD_REPLAY = 0x17,
2237 SQ_THREAD_TRACE_INST_TYPE_FLAT_WR_REPLAY = 0x18,
2238 } SQ_THREAD_TRACE_INST_TYPE;
2239 typedef enum SQ_THREAD_TRACE_REG_TYPE {
2240 SQ_THREAD_TRACE_REG_TYPE_EVENT = 0x0,
2241 SQ_THREAD_TRACE_REG_TYPE_DRAW = 0x1,
2242 SQ_THREAD_TRACE_REG_TYPE_DISPATCH = 0x2,
2243 SQ_THREAD_TRACE_REG_TYPE_USERDATA = 0x3,
2244 SQ_THREAD_TRACE_REG_TYPE_MARKER = 0x4,
2245 SQ_THREAD_TRACE_REG_TYPE_GFXDEC = 0x5,
2246 SQ_THREAD_TRACE_REG_TYPE_SHDEC = 0x6,
2247 SQ_THREAD_TRACE_REG_TYPE_OTHER = 0x7,
2248 } SQ_THREAD_TRACE_REG_TYPE;
2249 typedef enum SQ_THREAD_TRACE_REG_OP {
2250 SQ_THREAD_TRACE_REG_OP_READ = 0x0,
2251 SQ_THREAD_TRACE_REG_OP_WRITE = 0x1,
2252 } SQ_THREAD_TRACE_REG_OP;
2253 typedef enum SQ_THREAD_TRACE_MODE_SEL {
2254 SQ_THREAD_TRACE_MODE_OFF = 0x0,
2255 SQ_THREAD_TRACE_MODE_ON = 0x1,
2256 } SQ_THREAD_TRACE_MODE_SEL;
2257 typedef enum SQ_THREAD_TRACE_CAPTURE_MODE {
2258 SQ_THREAD_TRACE_CAPTURE_MODE_ALL = 0x0,
2259 SQ_THREAD_TRACE_CAPTURE_MODE_SELECT = 0x1,
2260 SQ_THREAD_TRACE_CAPTURE_MODE_SELECT_DETAIL = 0x2,
2261 } SQ_THREAD_TRACE_CAPTURE_MODE;
2262 typedef enum SQ_THREAD_TRACE_VM_ID_MASK {
2263 SQ_THREAD_TRACE_VM_ID_MASK_SINGLE = 0x0,
2264 SQ_THREAD_TRACE_VM_ID_MASK_ALL = 0x1,
2265 SQ_THREAD_TRACE_VM_ID_MASK_SINGLE_DETAIL = 0x2,
2266 } SQ_THREAD_TRACE_VM_ID_MASK;
2267 typedef enum SQ_THREAD_TRACE_WAVE_MASK {
2268 SQ_THREAD_TRACE_WAVE_MASK_NONE = 0x0,
2269 SQ_THREAD_TRACE_WAVE_MASK_ALL = 0x1,
2270 } SQ_THREAD_TRACE_WAVE_MASK;
2271 typedef enum SQ_THREAD_TRACE_ISSUE {
2272 SQ_THREAD_TRACE_ISSUE_NULL = 0x0,
2273 SQ_THREAD_TRACE_ISSUE_STALL = 0x1,
2274 SQ_THREAD_TRACE_ISSUE_INST = 0x2,
2275 SQ_THREAD_TRACE_ISSUE_IMMED = 0x3,
2276 } SQ_THREAD_TRACE_ISSUE;
2277 typedef enum SQ_THREAD_TRACE_ISSUE_MASK {
2278 SQ_THREAD_TRACE_ISSUE_MASK_ALL = 0x0,
2279 SQ_THREAD_TRACE_ISSUE_MASK_STALLED = 0x1,
2280 SQ_THREAD_TRACE_ISSUE_MASK_STALLED_AND_IMMED = 0x2,
2281 SQ_THREAD_TRACE_ISSUE_MASK_IMMED = 0x3,
2282 } SQ_THREAD_TRACE_ISSUE_MASK;
2283 typedef enum SQ_PERF_SEL {
2284 SQ_PERF_SEL_NONE = 0x0,
2285 SQ_PERF_SEL_ACCUM_PREV = 0x1,
2286 SQ_PERF_SEL_CYCLES = 0x2,
2287 SQ_PERF_SEL_BUSY_CYCLES = 0x3,
2288 SQ_PERF_SEL_WAVES = 0x4,
2289 SQ_PERF_SEL_LEVEL_WAVES = 0x5,
2290 SQ_PERF_SEL_WAVES_EQ_64 = 0x6,
2291 SQ_PERF_SEL_WAVES_LT_64 = 0x7,
2292 SQ_PERF_SEL_WAVES_LT_48 = 0x8,
2293 SQ_PERF_SEL_WAVES_LT_32 = 0x9,
2294 SQ_PERF_SEL_WAVES_LT_16 = 0xa,
2295 SQ_PERF_SEL_WAVES_CU = 0xb,
2296 SQ_PERF_SEL_LEVEL_WAVES_CU = 0xc,
2297 SQ_PERF_SEL_BUSY_CU_CYCLES = 0xd,
2298 SQ_PERF_SEL_ITEMS = 0xe,
2299 SQ_PERF_SEL_QUADS = 0xf,
2300 SQ_PERF_SEL_EVENTS = 0x10,
2301 SQ_PERF_SEL_SURF_SYNCS = 0x11,
2302 SQ_PERF_SEL_TTRACE_REQS = 0x12,
2303 SQ_PERF_SEL_TTRACE_INFLIGHT_REQS = 0x13,
2304 SQ_PERF_SEL_TTRACE_STALL = 0x14,
2305 SQ_PERF_SEL_MSG_CNTR = 0x15,
2306 SQ_PERF_SEL_MSG_PERF = 0x16,
2307 SQ_PERF_SEL_MSG_GSCNT = 0x17,
2308 SQ_PERF_SEL_MSG_INTERRUPT = 0x18,
2309 SQ_PERF_SEL_INSTS = 0x19,
2310 SQ_PERF_SEL_INSTS_VALU = 0x1a,
2311 SQ_PERF_SEL_INSTS_VMEM_WR = 0x1b,
2312 SQ_PERF_SEL_INSTS_VMEM_RD = 0x1c,
2313 SQ_PERF_SEL_INSTS_VMEM = 0x1d,
2314 SQ_PERF_SEL_INSTS_SALU = 0x1e,
2315 SQ_PERF_SEL_INSTS_SMEM = 0x1f,
2316 SQ_PERF_SEL_INSTS_FLAT = 0x20,
2317 SQ_PERF_SEL_INSTS_FLAT_LDS_ONLY = 0x21,
2318 SQ_PERF_SEL_INSTS_LDS = 0x22,
2319 SQ_PERF_SEL_INSTS_GDS = 0x23,
2320 SQ_PERF_SEL_INSTS_EXP = 0x24,
2321 SQ_PERF_SEL_INSTS_EXP_GDS = 0x25,
2322 SQ_PERF_SEL_INSTS_BRANCH = 0x26,
2323 SQ_PERF_SEL_INSTS_SENDMSG = 0x27,
2324 SQ_PERF_SEL_INSTS_VSKIPPED = 0x28,
2325 SQ_PERF_SEL_INST_LEVEL_VMEM = 0x29,
2326 SQ_PERF_SEL_INST_LEVEL_SMEM = 0x2a,
2327 SQ_PERF_SEL_INST_LEVEL_LDS = 0x2b,
2328 SQ_PERF_SEL_INST_LEVEL_GDS = 0x2c,
2329 SQ_PERF_SEL_INST_LEVEL_EXP = 0x2d,
2330 SQ_PERF_SEL_WAVE_CYCLES = 0x2e,
2331 SQ_PERF_SEL_WAVE_READY = 0x2f,
2332 SQ_PERF_SEL_WAIT_CNT_VM = 0x30,
2333 SQ_PERF_SEL_WAIT_CNT_LGKM = 0x31,
2334 SQ_PERF_SEL_WAIT_CNT_EXP = 0x32,
2335 SQ_PERF_SEL_WAIT_CNT_ANY = 0x33,
2336 SQ_PERF_SEL_WAIT_BARRIER = 0x34,
2337 SQ_PERF_SEL_WAIT_EXP_ALLOC = 0x35,
2338 SQ_PERF_SEL_WAIT_SLEEP = 0x36,
2339 SQ_PERF_SEL_WAIT_OTHER = 0x37,
2340 SQ_PERF_SEL_WAIT_ANY = 0x38,
2341 SQ_PERF_SEL_WAIT_TTRACE = 0x39,
2342 SQ_PERF_SEL_WAIT_IFETCH = 0x3a,
2343 SQ_PERF_SEL_WAIT_INST_VMEM = 0x3b,
2344 SQ_PERF_SEL_WAIT_INST_SCA = 0x3c,
2345 SQ_PERF_SEL_WAIT_INST_LDS = 0x3d,
2346 SQ_PERF_SEL_WAIT_INST_VALU = 0x3e,
2347 SQ_PERF_SEL_WAIT_INST_EXP_GDS = 0x3f,
2348 SQ_PERF_SEL_WAIT_INST_MISC = 0x40,
2349 SQ_PERF_SEL_WAIT_INST_FLAT = 0x41,
2350 SQ_PERF_SEL_ACTIVE_INST_ANY = 0x42,
2351 SQ_PERF_SEL_ACTIVE_INST_VMEM = 0x43,
2352 SQ_PERF_SEL_ACTIVE_INST_LDS = 0x44,
2353 SQ_PERF_SEL_ACTIVE_INST_VALU = 0x45,
2354 SQ_PERF_SEL_ACTIVE_INST_SCA = 0x46,
2355 SQ_PERF_SEL_ACTIVE_INST_EXP_GDS = 0x47,
2356 SQ_PERF_SEL_ACTIVE_INST_MISC = 0x48,
2357 SQ_PERF_SEL_ACTIVE_INST_FLAT = 0x49,
2358 SQ_PERF_SEL_INST_CYCLES_VMEM_WR = 0x4a,
2359 SQ_PERF_SEL_INST_CYCLES_VMEM_RD = 0x4b,
2360 SQ_PERF_SEL_INST_CYCLES_VMEM_ADDR = 0x4c,
2361 SQ_PERF_SEL_INST_CYCLES_VMEM_DATA = 0x4d,
2362 SQ_PERF_SEL_INST_CYCLES_VMEM_CMD = 0x4e,
2363 SQ_PERF_SEL_INST_CYCLES_VMEM = 0x4f,
2364 SQ_PERF_SEL_INST_CYCLES_LDS = 0x50,
2365 SQ_PERF_SEL_INST_CYCLES_VALU = 0x51,
2366 SQ_PERF_SEL_INST_CYCLES_EXP = 0x52,
2367 SQ_PERF_SEL_INST_CYCLES_GDS = 0x53,
2368 SQ_PERF_SEL_INST_CYCLES_SCA = 0x54,
2369 SQ_PERF_SEL_INST_CYCLES_SMEM = 0x55,
2370 SQ_PERF_SEL_INST_CYCLES_SALU = 0x56,
2371 SQ_PERF_SEL_INST_CYCLES_EXP_GDS = 0x57,
2372 SQ_PERF_SEL_INST_CYCLES_MISC = 0x58,
2373 SQ_PERF_SEL_THREAD_CYCLES_VALU = 0x59,
2374 SQ_PERF_SEL_THREAD_CYCLES_VALU_MAX = 0x5a,
2375 SQ_PERF_SEL_IFETCH = 0x5b,
2376 SQ_PERF_SEL_IFETCH_LEVEL = 0x5c,
2377 SQ_PERF_SEL_CBRANCH_FORK = 0x5d,
2378 SQ_PERF_SEL_CBRANCH_FORK_SPLIT = 0x5e,
2379 SQ_PERF_SEL_VALU_LDS_DIRECT_RD = 0x5f,
2380 SQ_PERF_SEL_VALU_LDS_INTERP_OP = 0x60,
2381 SQ_PERF_SEL_LDS_BANK_CONFLICT = 0x61,
2382 SQ_PERF_SEL_LDS_ADDR_CONFLICT = 0x62,
2383 SQ_PERF_SEL_LDS_UNALIGNED_STALL = 0x63,
2384 SQ_PERF_SEL_LDS_MEM_VIOLATIONS = 0x64,
2385 SQ_PERF_SEL_LDS_ATOMIC_RETURN = 0x65,
2386 SQ_PERF_SEL_LDS_IDX_ACTIVE = 0x66,
2387 SQ_PERF_SEL_VALU_DEP_STALL = 0x67,
2388 SQ_PERF_SEL_VALU_STARVE = 0x68,
2389 SQ_PERF_SEL_EXP_REQ_FIFO_FULL = 0x69,
2390 SQ_PERF_SEL_LDS_BACK2BACK_STALL = 0x6a,
2391 SQ_PERF_SEL_LDS_DATA_FIFO_FULL = 0x6b,
2392 SQ_PERF_SEL_LDS_CMD_FIFO_FULL = 0x6c,
2393 SQ_PERF_SEL_VMEM_BACK2BACK_STALL = 0x6d,
2394 SQ_PERF_SEL_VMEM_TA_ADDR_FIFO_FULL = 0x6e,
2395 SQ_PERF_SEL_VMEM_TA_CMD_FIFO_FULL = 0x6f,
2396 SQ_PERF_SEL_VMEM_EX_DATA_REG_BUSY = 0x70,
2397 SQ_PERF_SEL_VMEM_WR_BACK2BACK_STALL = 0x71,
2398 SQ_PERF_SEL_VMEM_WR_TA_DATA_FIFO_FULL = 0x72,
2399 SQ_PERF_SEL_VALU_SRC_C_CONFLICT = 0x73,
2400 SQ_PERF_SEL_VMEM_RD_SRC_CD_CONFLICT = 0x74,
2401 SQ_PERF_SEL_VMEM_WR_SRC_CD_CONFLICT = 0x75,
2402 SQ_PERF_SEL_FLAT_SRC_CD_CONFLICT = 0x76,
2403 SQ_PERF_SEL_LDS_SRC_CD_CONFLICT = 0x77,
2404 SQ_PERF_SEL_SRC_CD_BUSY = 0x78,
2405 SQ_PERF_SEL_PT_POWER_STALL = 0x79,
2406 SQ_PERF_SEL_USER0 = 0x7a,
2407 SQ_PERF_SEL_USER1 = 0x7b,
2408 SQ_PERF_SEL_USER2 = 0x7c,
2409 SQ_PERF_SEL_USER3 = 0x7d,
2410 SQ_PERF_SEL_USER4 = 0x7e,
2411 SQ_PERF_SEL_USER5 = 0x7f,
2412 SQ_PERF_SEL_USER6 = 0x80,
2413 SQ_PERF_SEL_USER7 = 0x81,
2414 SQ_PERF_SEL_USER8 = 0x82,
2415 SQ_PERF_SEL_USER9 = 0x83,
2416 SQ_PERF_SEL_USER10 = 0x84,
2417 SQ_PERF_SEL_USER11 = 0x85,
2418 SQ_PERF_SEL_USER12 = 0x86,
2419 SQ_PERF_SEL_USER13 = 0x87,
2420 SQ_PERF_SEL_USER14 = 0x88,
2421 SQ_PERF_SEL_USER15 = 0x89,
2422 SQ_PERF_SEL_USER_LEVEL0 = 0x8a,
2423 SQ_PERF_SEL_USER_LEVEL1 = 0x8b,
2424 SQ_PERF_SEL_USER_LEVEL2 = 0x8c,
2425 SQ_PERF_SEL_USER_LEVEL3 = 0x8d,
2426 SQ_PERF_SEL_USER_LEVEL4 = 0x8e,
2427 SQ_PERF_SEL_USER_LEVEL5 = 0x8f,
2428 SQ_PERF_SEL_USER_LEVEL6 = 0x90,
2429 SQ_PERF_SEL_USER_LEVEL7 = 0x91,
2430 SQ_PERF_SEL_USER_LEVEL8 = 0x92,
2431 SQ_PERF_SEL_USER_LEVEL9 = 0x93,
2432 SQ_PERF_SEL_USER_LEVEL10 = 0x94,
2433 SQ_PERF_SEL_USER_LEVEL11 = 0x95,
2434 SQ_PERF_SEL_USER_LEVEL12 = 0x96,
2435 SQ_PERF_SEL_USER_LEVEL13 = 0x97,
2436 SQ_PERF_SEL_USER_LEVEL14 = 0x98,
2437 SQ_PERF_SEL_USER_LEVEL15 = 0x99,
2438 SQ_PERF_SEL_POWER_VALU = 0x9a,
2439 SQ_PERF_SEL_POWER_VALU0 = 0x9b,
2440 SQ_PERF_SEL_POWER_VALU1 = 0x9c,
2441 SQ_PERF_SEL_POWER_VALU2 = 0x9d,
2442 SQ_PERF_SEL_POWER_GPR_RD = 0x9e,
2443 SQ_PERF_SEL_POWER_GPR_WR = 0x9f,
2444 SQ_PERF_SEL_POWER_LDS_BUSY = 0xa0,
2445 SQ_PERF_SEL_POWER_ALU_BUSY = 0xa1,
2446 SQ_PERF_SEL_POWER_TEX_BUSY = 0xa2,
2447 SQ_PERF_SEL_ACCUM_PREV_HIRES = 0xa3,
2448 SQ_PERF_SEL_WAVES_RESTORED = 0xa4,
2449 SQ_PERF_SEL_WAVES_SAVED = 0xa5,
2450 SQ_PERF_SEL_DUMMY_LAST = 0xa7,
2451 SQC_PERF_SEL_ICACHE_INPUT_VALID_READY = 0xa8,
2452 SQC_PERF_SEL_ICACHE_INPUT_VALID_READYB = 0xa9,
2453 SQC_PERF_SEL_ICACHE_INPUT_VALIDB = 0xaa,
2454 SQC_PERF_SEL_DCACHE_INPUT_VALID_READY = 0xab,
2455 SQC_PERF_SEL_DCACHE_INPUT_VALID_READYB = 0xac,
2456 SQC_PERF_SEL_DCACHE_INPUT_VALIDB = 0xad,
2457 SQC_PERF_SEL_TC_REQ = 0xae,
2458 SQC_PERF_SEL_TC_INST_REQ = 0xaf,
2459 SQC_PERF_SEL_TC_DATA_READ_REQ = 0xb0,
2460 SQC_PERF_SEL_TC_DATA_WRITE_REQ = 0xb1,
2461 SQC_PERF_SEL_TC_DATA_ATOMIC_REQ = 0xb2,
2462 SQC_PERF_SEL_TC_STALL = 0xb3,
2463 SQC_PERF_SEL_TC_STARVE = 0xb4,
2464 SQC_PERF_SEL_ICACHE_BUSY_CYCLES = 0xb5,
2465 SQC_PERF_SEL_ICACHE_REQ = 0xb6,
2466 SQC_PERF_SEL_ICACHE_HITS = 0xb7,
2467 SQC_PERF_SEL_ICACHE_MISSES = 0xb8,
2468 SQC_PERF_SEL_ICACHE_MISSES_DUPLICATE = 0xb9,
2469 SQC_PERF_SEL_ICACHE_INVAL_INST = 0xba,
2470 SQC_PERF_SEL_ICACHE_INVAL_ASYNC = 0xbb,
2471 SQC_PERF_SEL_ICACHE_INPUT_STALL_ARB_NO_GRANT = 0xbc,
2472 SQC_PERF_SEL_ICACHE_INPUT_STALL_BANK_READYB = 0xbd,
2473 SQC_PERF_SEL_ICACHE_CACHE_STALLED = 0xbe,
2474 SQC_PERF_SEL_ICACHE_CACHE_STALL_INFLIGHT_NONZERO = 0xbf,
2475 SQC_PERF_SEL_ICACHE_CACHE_STALL_INFLIGHT_MAX = 0xc0,
2476 SQC_PERF_SEL_ICACHE_CACHE_STALL_OUTPUT = 0xc1,
2477 SQC_PERF_SEL_ICACHE_CACHE_STALL_OUTPUT_MISS_FIFO = 0xc2,
2478 SQC_PERF_SEL_ICACHE_CACHE_STALL_OUTPUT_HIT_FIFO = 0xc3,
2479 SQC_PERF_SEL_ICACHE_CACHE_STALL_OUTPUT_TC_IF = 0xc4,
2480 SQC_PERF_SEL_ICACHE_STALL_OUTXBAR_ARB_NO_GRANT = 0xc5,
2481 SQC_PERF_SEL_DCACHE_BUSY_CYCLES = 0xc6,
2482 SQC_PERF_SEL_DCACHE_REQ = 0xc7,
2483 SQC_PERF_SEL_DCACHE_HITS = 0xc8,
2484 SQC_PERF_SEL_DCACHE_MISSES = 0xc9,
2485 SQC_PERF_SEL_DCACHE_MISSES_DUPLICATE = 0xca,
2486 SQC_PERF_SEL_DCACHE_HIT_LRU_READ = 0xcb,
2487 SQC_PERF_SEL_DCACHE_MISS_EVICT_READ = 0xcc,
2488 SQC_PERF_SEL_DCACHE_WC_LRU_WRITE = 0xcd,
2489 SQC_PERF_SEL_DCACHE_WT_EVICT_WRITE = 0xce,
2490 SQC_PERF_SEL_DCACHE_ATOMIC = 0xcf,
2491 SQC_PERF_SEL_DCACHE_VOLATILE = 0xd0,
2492 SQC_PERF_SEL_DCACHE_INVAL_INST = 0xd1,
2493 SQC_PERF_SEL_DCACHE_INVAL_ASYNC = 0xd2,
2494 SQC_PERF_SEL_DCACHE_INVAL_VOLATILE_INST = 0xd3,
2495 SQC_PERF_SEL_DCACHE_INVAL_VOLATILE_ASYNC = 0xd4,
2496 SQC_PERF_SEL_DCACHE_WB_INST = 0xd5,
2497 SQC_PERF_SEL_DCACHE_WB_ASYNC = 0xd6,
2498 SQC_PERF_SEL_DCACHE_WB_VOLATILE_INST = 0xd7,
2499 SQC_PERF_SEL_DCACHE_WB_VOLATILE_ASYNC = 0xd8,
2500 SQC_PERF_SEL_DCACHE_INPUT_STALL_ARB_NO_GRANT = 0xd9,
2501 SQC_PERF_SEL_DCACHE_INPUT_STALL_BANK_READYB = 0xda,
2502 SQC_PERF_SEL_DCACHE_CACHE_STALLED = 0xdb,
2503 SQC_PERF_SEL_DCACHE_CACHE_STALL_INFLIGHT_MAX = 0xdc,
2504 SQC_PERF_SEL_DCACHE_CACHE_STALL_OUTPUT = 0xdd,
2505 SQC_PERF_SEL_DCACHE_CACHE_STALL_EVICT = 0xde,
2506 SQC_PERF_SEL_DCACHE_CACHE_STALL_UNORDERED = 0xdf,
2507 SQC_PERF_SEL_DCACHE_CACHE_STALL_ALLOC_UNAVAILABLE= 0xe0,
2508 SQC_PERF_SEL_DCACHE_CACHE_STALL_FORCE_EVICT = 0xe1,
2509 SQC_PERF_SEL_DCACHE_CACHE_STALL_MULTI_FLUSH = 0xe2,
2510 SQC_PERF_SEL_DCACHE_CACHE_STALL_FLUSH_DONE = 0xe3,
2511 SQC_PERF_SEL_DCACHE_CACHE_STALL_OUTPUT_MISS_FIFO = 0xe4,
2512 SQC_PERF_SEL_DCACHE_CACHE_STALL_OUTPUT_HIT_FIFO = 0xe5,
2513 SQC_PERF_SEL_DCACHE_CACHE_STALL_OUTPUT_TC_IF = 0xe6,
2514 SQC_PERF_SEL_DCACHE_STALL_OUTXBAR_ARB_NO_GRANT = 0xe7,
2515 SQC_PERF_SEL_DCACHE_REQ_READ_1 = 0xe8,
2516 SQC_PERF_SEL_DCACHE_REQ_READ_2 = 0xe9,
2517 SQC_PERF_SEL_DCACHE_REQ_READ_4 = 0xea,
2518 SQC_PERF_SEL_DCACHE_REQ_READ_8 = 0xeb,
2519 SQC_PERF_SEL_DCACHE_REQ_READ_16 = 0xec,
2520 SQC_PERF_SEL_DCACHE_REQ_TIME = 0xed,
2521 SQC_PERF_SEL_DCACHE_REQ_WRITE_1 = 0xee,
2522 SQC_PERF_SEL_DCACHE_REQ_WRITE_2 = 0xef,
2523 SQC_PERF_SEL_DCACHE_REQ_WRITE_4 = 0xf0,
2524 SQC_PERF_SEL_DCACHE_REQ_ATC_PROBE = 0xf1,
2525 SQC_PERF_SEL_SQ_DCACHE_REQS = 0xf2,
2526 SQC_PERF_SEL_DCACHE_FLAT_REQ = 0xf3,
2527 SQC_PERF_SEL_DCACHE_NONFLAT_REQ = 0xf4,
2528 SQC_PERF_SEL_ICACHE_INFLIGHT_LEVEL = 0xf5,
2529 SQC_PERF_SEL_DCACHE_INFLIGHT_LEVEL = 0xf6,
2530 SQC_PERF_SEL_TC_INFLIGHT_LEVEL = 0xf7,
2531 SQC_PERF_SEL_ICACHE_TC_INFLIGHT_LEVEL = 0xf8,
2532 SQC_PERF_SEL_DCACHE_TC_INFLIGHT_LEVEL = 0xf9,
2533 SQC_PERF_SEL_ICACHE_GATCL1_TRANSLATION_MISS = 0xfa,
2534 SQC_PERF_SEL_ICACHE_GATCL1_PERMISSION_MISS = 0xfb,
2535 SQC_PERF_SEL_ICACHE_GATCL1_REQUEST = 0xfc,
2536 SQC_PERF_SEL_ICACHE_GATCL1_STALL_INFLIGHT_MAX = 0xfd,
2537 SQC_PERF_SEL_ICACHE_GATCL1_STALL_LRU_INFLIGHT = 0xfe,
2538 SQC_PERF_SEL_ICACHE_GATCL1_LFIFO_FULL = 0xff,
2539 SQC_PERF_SEL_ICACHE_GATCL1_STALL_LFIFO_NOT_RES = 0x100,
2540 SQC_PERF_SEL_ICACHE_GATCL1_STALL_ATCL2_REQ_OUT_OF_CREDITS= 0x101,
2541 SQC_PERF_SEL_ICACHE_GATCL1_ATCL2_INFLIGHT = 0x102,
2542 SQC_PERF_SEL_ICACHE_GATCL1_STALL_MISSFIFO_FULL = 0x103,
2543 SQC_PERF_SEL_DCACHE_GATCL1_TRANSLATION_MISS = 0x104,
2544 SQC_PERF_SEL_DCACHE_GATCL1_PERMISSION_MISS = 0x105,
2545 SQC_PERF_SEL_DCACHE_GATCL1_REQUEST = 0x106,
2546 SQC_PERF_SEL_DCACHE_GATCL1_STALL_INFLIGHT_MAX = 0x107,
2547 SQC_PERF_SEL_DCACHE_GATCL1_STALL_LRU_INFLIGHT = 0x108,
2548 SQC_PERF_SEL_DCACHE_GATCL1_LFIFO_FULL = 0x109,
2549 SQC_PERF_SEL_DCACHE_GATCL1_STALL_LFIFO_NOT_RES = 0x10a,
2550 SQC_PERF_SEL_DCACHE_GATCL1_STALL_ATCL2_REQ_OUT_OF_CREDITS= 0x10b,
2551 SQC_PERF_SEL_DCACHE_GATCL1_ATCL2_INFLIGHT = 0x10c,
2552 SQC_PERF_SEL_DCACHE_GATCL1_STALL_MISSFIFO_FULL = 0x10d,
2553 SQC_PERF_SEL_DCACHE_GATCL1_STALL_MULTI_MISS = 0x10e,
2554 SQC_PERF_SEL_DCACHE_GATCL1_HIT_FIFO_FULL = 0x10f,
2555 SQC_PERF_SEL_DUMMY_LAST = 0x110,
2556 SQ_PERF_SEL_INSTS_SMEM_NORM = 0x111,
2557 SQ_PERF_SEL_ATC_INSTS_VMEM = 0x112,
2558 SQ_PERF_SEL_ATC_INST_LEVEL_VMEM = 0x113,
2559 SQ_PERF_SEL_ATC_XNACK_FIRST = 0x114,
2560 SQ_PERF_SEL_ATC_XNACK_ALL = 0x115,
2561 SQ_PERF_SEL_ATC_XNACK_FIFO_FULL = 0x116,
2562 SQ_PERF_SEL_ATC_INSTS_SMEM = 0x117,
2563 SQ_PERF_SEL_ATC_INST_LEVEL_SMEM = 0x118,
2564 SQ_PERF_SEL_IFETCH_XNACK = 0x119,
2565 SQ_PERF_SEL_TLB_SHOOTDOWN = 0x11a,
2566 SQ_PERF_SEL_TLB_SHOOTDOWN_CYCLES = 0x11b,
2567 SQ_PERF_SEL_INSTS_VMEM_WR_REPLAY = 0x11c,
2568 SQ_PERF_SEL_INSTS_VMEM_RD_REPLAY = 0x11d,
2569 SQ_PERF_SEL_INSTS_VMEM_REPLAY = 0x11e,
2570 SQ_PERF_SEL_INSTS_SMEM_REPLAY = 0x11f,
2571 SQ_PERF_SEL_INSTS_SMEM_NORM_REPLAY = 0x120,
2572 SQ_PERF_SEL_INSTS_FLAT_REPLAY = 0x121,
2573 SQ_PERF_SEL_ATC_INSTS_VMEM_REPLAY = 0x122,
2574 SQ_PERF_SEL_ATC_INSTS_SMEM_REPLAY = 0x123,
2575 SQ_PERF_SEL_DUMMY_LAST1 = 0x12a,
2576 } SQ_PERF_SEL;
2577 typedef enum SQ_CAC_POWER_SEL {
2578 SQ_CAC_POWER_VALU = 0x0,
2579 SQ_CAC_POWER_VALU0 = 0x1,
2580 SQ_CAC_POWER_VALU1 = 0x2,
2581 SQ_CAC_POWER_VALU2 = 0x3,
2582 SQ_CAC_POWER_GPR_RD = 0x4,
2583 SQ_CAC_POWER_GPR_WR = 0x5,
2584 SQ_CAC_POWER_LDS_BUSY = 0x6,
2585 SQ_CAC_POWER_ALU_BUSY = 0x7,
2586 SQ_CAC_POWER_TEX_BUSY = 0x8,
2587 } SQ_CAC_POWER_SEL;
2588 typedef enum SQ_IND_CMD_CMD {
2589 SQ_IND_CMD_CMD_NULL = 0x0,
2590 SQ_IND_CMD_CMD_SETHALT = 0x1,
2591 SQ_IND_CMD_CMD_SAVECTX = 0x2,
2592 SQ_IND_CMD_CMD_KILL = 0x3,
2593 SQ_IND_CMD_CMD_DEBUG = 0x4,
2594 SQ_IND_CMD_CMD_TRAP = 0x5,
2595 SQ_IND_CMD_CMD_SET_SPI_PRIO = 0x6,
2596 } SQ_IND_CMD_CMD;
2597 typedef enum SQ_IND_CMD_MODE {
2598 SQ_IND_CMD_MODE_SINGLE = 0x0,
2599 SQ_IND_CMD_MODE_BROADCAST = 0x1,
2600 SQ_IND_CMD_MODE_BROADCAST_QUEUE = 0x2,
2601 SQ_IND_CMD_MODE_BROADCAST_PIPE = 0x3,
2602 SQ_IND_CMD_MODE_BROADCAST_ME = 0x4,
2603 } SQ_IND_CMD_MODE;
2604 typedef enum SQ_EDC_INFO_SOURCE {
2605 SQ_EDC_INFO_SOURCE_INVALID = 0x0,
2606 SQ_EDC_INFO_SOURCE_INST = 0x1,
2607 SQ_EDC_INFO_SOURCE_SGPR = 0x2,
2608 SQ_EDC_INFO_SOURCE_VGPR = 0x3,
2609 SQ_EDC_INFO_SOURCE_LDS = 0x4,
2610 SQ_EDC_INFO_SOURCE_GDS = 0x5,
2611 SQ_EDC_INFO_SOURCE_TA = 0x6,
2612 } SQ_EDC_INFO_SOURCE;
2613 typedef enum SQ_ROUND_MODE {
2614 SQ_ROUND_NEAREST_EVEN = 0x0,
2615 SQ_ROUND_PLUS_INFINITY = 0x1,
2616 SQ_ROUND_MINUS_INFINITY = 0x2,
2617 SQ_ROUND_TO_ZERO = 0x3,
2618 } SQ_ROUND_MODE;
2619 typedef enum SQ_INTERRUPT_WORD_ENCODING {
2620 SQ_INTERRUPT_WORD_ENCODING_AUTO = 0x0,
2621 SQ_INTERRUPT_WORD_ENCODING_INST = 0x1,
2622 SQ_INTERRUPT_WORD_ENCODING_ERROR = 0x2,
2623 } SQ_INTERRUPT_WORD_ENCODING;
2624 typedef enum ENUM_SQ_EXPORT_RAT_INST {
2625 SQ_EXPORT_RAT_INST_NOP = 0x0,
2626 SQ_EXPORT_RAT_INST_STORE_TYPED = 0x1,
2627 SQ_EXPORT_RAT_INST_STORE_RAW = 0x2,
2628 SQ_EXPORT_RAT_INST_STORE_RAW_FDENORM = 0x3,
2629 SQ_EXPORT_RAT_INST_CMPXCHG_INT = 0x4,
2630 SQ_EXPORT_RAT_INST_CMPXCHG_FLT = 0x5,
2631 SQ_EXPORT_RAT_INST_CMPXCHG_FDENORM = 0x6,
2632 SQ_EXPORT_RAT_INST_ADD = 0x7,
2633 SQ_EXPORT_RAT_INST_SUB = 0x8,
2634 SQ_EXPORT_RAT_INST_RSUB = 0x9,
2635 SQ_EXPORT_RAT_INST_MIN_INT = 0xa,
2636 SQ_EXPORT_RAT_INST_MIN_UINT = 0xb,
2637 SQ_EXPORT_RAT_INST_MAX_INT = 0xc,
2638 SQ_EXPORT_RAT_INST_MAX_UINT = 0xd,
2639 SQ_EXPORT_RAT_INST_AND = 0xe,
2640 SQ_EXPORT_RAT_INST_OR = 0xf,
2641 SQ_EXPORT_RAT_INST_XOR = 0x10,
2642 SQ_EXPORT_RAT_INST_MSKOR = 0x11,
2643 SQ_EXPORT_RAT_INST_INC_UINT = 0x12,
2644 SQ_EXPORT_RAT_INST_DEC_UINT = 0x13,
2645 SQ_EXPORT_RAT_INST_STORE_DWORD = 0x14,
2646 SQ_EXPORT_RAT_INST_STORE_SHORT = 0x15,
2647 SQ_EXPORT_RAT_INST_STORE_BYTE = 0x16,
2648 SQ_EXPORT_RAT_INST_NOP_RTN = 0x20,
2649 SQ_EXPORT_RAT_INST_XCHG_RTN = 0x22,
2650 SQ_EXPORT_RAT_INST_XCHG_FDENORM_RTN = 0x23,
2651 SQ_EXPORT_RAT_INST_CMPXCHG_INT_RTN = 0x24,
2652 SQ_EXPORT_RAT_INST_CMPXCHG_FLT_RTN = 0x25,
2653 SQ_EXPORT_RAT_INST_CMPXCHG_FDENORM_RTN = 0x26,
2654 SQ_EXPORT_RAT_INST_ADD_RTN = 0x27,
2655 SQ_EXPORT_RAT_INST_SUB_RTN = 0x28,
2656 SQ_EXPORT_RAT_INST_RSUB_RTN = 0x29,
2657 SQ_EXPORT_RAT_INST_MIN_INT_RTN = 0x2a,
2658 SQ_EXPORT_RAT_INST_MIN_UINT_RTN = 0x2b,
2659 SQ_EXPORT_RAT_INST_MAX_INT_RTN = 0x2c,
2660 SQ_EXPORT_RAT_INST_MAX_UINT_RTN = 0x2d,
2661 SQ_EXPORT_RAT_INST_AND_RTN = 0x2e,
2662 SQ_EXPORT_RAT_INST_OR_RTN = 0x2f,
2663 SQ_EXPORT_RAT_INST_XOR_RTN = 0x30,
2664 SQ_EXPORT_RAT_INST_MSKOR_RTN = 0x31,
2665 SQ_EXPORT_RAT_INST_INC_UINT_RTN = 0x32,
2666 SQ_EXPORT_RAT_INST_DEC_UINT_RTN = 0x33,
2667 } ENUM_SQ_EXPORT_RAT_INST;
2668 typedef enum SQ_IBUF_ST {
2669 SQ_IBUF_IB_IDLE = 0x0,
2670 SQ_IBUF_IB_INI_WAIT_GNT = 0x1,
2671 SQ_IBUF_IB_INI_WAIT_DRET = 0x2,
2672 SQ_IBUF_IB_LE_4DW = 0x3,
2673 SQ_IBUF_IB_WAIT_DRET = 0x4,
2674 SQ_IBUF_IB_EMPTY_WAIT_DRET = 0x5,
2675 SQ_IBUF_IB_DRET = 0x6,
2676 SQ_IBUF_IB_EMPTY_WAIT_GNT = 0x7,
2677 } SQ_IBUF_ST;
2678 typedef enum SQ_INST_STR_ST {
2679 SQ_INST_STR_IB_WAVE_NORML = 0x0,
2680 SQ_INST_STR_IB_WAVE2ID_NORMAL_INST_AV = 0x1,
2681 SQ_INST_STR_IB_WAVE_INTERNAL_INST_AV = 0x2,
2682 SQ_INST_STR_IB_WAVE_INST_SKIP_AV = 0x3,
2683 SQ_INST_STR_IB_WAVE_SETVSKIP_ST0 = 0x4,
2684 SQ_INST_STR_IB_WAVE_SETVSKIP_ST1 = 0x5,
2685 SQ_INST_STR_IB_WAVE_NOP_SLEEP_WAIT = 0x6,
2686 SQ_INST_STR_IB_WAVE_PC_FROM_SGPR_MSG_WAIT = 0x7,
2687 } SQ_INST_STR_ST;
2688 typedef enum SQ_WAVE_IB_ECC_ST {
2689 SQ_WAVE_IB_ECC_CLEAN = 0x0,
2690 SQ_WAVE_IB_ECC_ERR_CONTINUE = 0x1,
2691 SQ_WAVE_IB_ECC_ERR_HALT = 0x2,
2692 SQ_WAVE_IB_ECC_WITH_ERR_MSG = 0x3,
2693 } SQ_WAVE_IB_ECC_ST;
2694 typedef enum SH_MEM_ADDRESS_MODE {
2695 SH_MEM_ADDRESS_MODE_GPUVM64 = 0x0,
2696 SH_MEM_ADDRESS_MODE_GPUVM32 = 0x1,
2697 SH_MEM_ADDRESS_MODE_HSA64 = 0x2,
2698 SH_MEM_ADDRESS_MODE_HSA32 = 0x3,
2699 } SH_MEM_ADDRESS_MODE;
2700 typedef enum SH_MEM_ALIGNMENT_MODE {
2701 SH_MEM_ALIGNMENT_MODE_DWORD = 0x0,
2702 SH_MEM_ALIGNMENT_MODE_DWORD_STRICT = 0x1,
2703 SH_MEM_ALIGNMENT_MODE_STRICT = 0x2,
2704 SH_MEM_ALIGNMENT_MODE_UNALIGNED = 0x3,
2705 } SH_MEM_ALIGNMENT_MODE;
2706 typedef enum SQ_THREAD_TRACE_WAVE_START_COUNT_PREFIX {
2707 SQ_THREAD_TRACE_WAVE_START_COUNT_PREFIX_WREXEC = 0x18,
2708 SQ_THREAD_TRACE_WAVE_START_COUNT_PREFIX_RESTORE = 0x19,
2709 } SQ_THREAD_TRACE_WAVE_START_COUNT_PREFIX;
2710 #define SQ_WAVE_TYPE_PS0 0x0
2711 #define SQIND_GLOBAL_REGS_OFFSET 0x0
2712 #define SQIND_GLOBAL_REGS_SIZE 0x8
2713 #define SQIND_LOCAL_REGS_OFFSET 0x8
2714 #define SQIND_LOCAL_REGS_SIZE 0x8
2715 #define SQIND_WAVE_HWREGS_OFFSET 0x10
2716 #define SQIND_WAVE_HWREGS_SIZE 0x1f0
2717 #define SQIND_WAVE_SGPRS_OFFSET 0x200
2718 #define SQIND_WAVE_SGPRS_SIZE 0x200
2719 #define SQ_GFXDEC_BEGIN 0xa000
2720 #define SQ_GFXDEC_END 0xc000
2721 #define SQ_GFXDEC_STATE_ID_SHIFT 0xa
2722 #define SQDEC_BEGIN 0x2300
2723 #define SQDEC_END 0x23ff
2724 #define SQPERFSDEC_BEGIN 0xd9c0
2725 #define SQPERFSDEC_END 0xda40
2726 #define SQPERFDDEC_BEGIN 0xd1c0
2727 #define SQPERFDDEC_END 0xd240
2728 #define SQGFXUDEC_BEGIN 0xc330
2729 #define SQGFXUDEC_END 0xc380
2730 #define SQPWRDEC_BEGIN 0xf08c
2731 #define SQPWRDEC_END 0xf094
2732 #define SQ_DISPATCHER_GFX_MIN 0x10
2733 #define SQ_DISPATCHER_GFX_CNT_PER_RING 0x8
2734 #define SQ_MAX_PGM_SGPRS 0x68
2735 #define SQ_MAX_PGM_VGPRS 0x100
2736 #define SQ_THREAD_TRACE_TIME_UNIT 0x4
2737 #define SQ_EX_MODE_EXCP_VALU_BASE 0x0
2738 #define SQ_EX_MODE_EXCP_VALU_SIZE 0x7
2739 #define SQ_EX_MODE_EXCP_INVALID 0x0
2740 #define SQ_EX_MODE_EXCP_INPUT_DENORM 0x1
2741 #define SQ_EX_MODE_EXCP_DIV0 0x2
2742 #define SQ_EX_MODE_EXCP_OVERFLOW 0x3
2743 #define SQ_EX_MODE_EXCP_UNDERFLOW 0x4
2744 #define SQ_EX_MODE_EXCP_INEXACT 0x5
2745 #define SQ_EX_MODE_EXCP_INT_DIV0 0x6
2746 #define SQ_EX_MODE_EXCP_ADDR_WATCH 0x7
2747 #define SQ_EX_MODE_EXCP_MEM_VIOL 0x8
2748 #define INST_ID_PRIV_START 0x80000000
2749 #define INST_ID_ECC_INTERRUPT_MSG 0xfffffff0
2750 #define INST_ID_TTRACE_NEW_PC_MSG 0xfffffff1
2751 #define INST_ID_HW_TRAP 0xfffffff2
2752 #define INST_ID_KILL_SEQ 0xfffffff3
2753 #define INST_ID_SPI_WREXEC 0xfffffff4
2754 #define INST_ID_HOST_REG_TRAP_MSG 0xfffffffe
2755 #define SQ_ENC_SOP1_BITS 0xbe800000
2756 #define SQ_ENC_SOP1_MASK 0xff800000
2757 #define SQ_ENC_SOP1_FIELD 0x17d
2758 #define SQ_ENC_SOPC_BITS 0xbf000000
2759 #define SQ_ENC_SOPC_MASK 0xff800000
2760 #define SQ_ENC_SOPC_FIELD 0x17e
2761 #define SQ_ENC_SOPP_BITS 0xbf800000
2762 #define SQ_ENC_SOPP_MASK 0xff800000
2763 #define SQ_ENC_SOPP_FIELD 0x17f
2764 #define SQ_ENC_SOPK_BITS 0xb0000000
2765 #define SQ_ENC_SOPK_MASK 0xf0000000
2766 #define SQ_ENC_SOPK_FIELD 0xb
2767 #define SQ_ENC_SOP2_BITS 0x80000000
2768 #define SQ_ENC_SOP2_MASK 0xc0000000
2769 #define SQ_ENC_SOP2_FIELD 0x2
2770 #define SQ_ENC_SMEM_BITS 0xc0000000
2771 #define SQ_ENC_SMEM_MASK 0xfc000000
2772 #define SQ_ENC_SMEM_FIELD 0x30
2773 #define SQ_ENC_VOP1_BITS 0x7e000000
2774 #define SQ_ENC_VOP1_MASK 0xfe000000
2775 #define SQ_ENC_VOP1_FIELD 0x3f
2776 #define SQ_ENC_VOPC_BITS 0x7c000000
2777 #define SQ_ENC_VOPC_MASK 0xfe000000
2778 #define SQ_ENC_VOPC_FIELD 0x3e
2779 #define SQ_ENC_VOP2_BITS 0x0
2780 #define SQ_ENC_VOP2_MASK 0x80000000
2781 #define SQ_ENC_VOP2_FIELD 0x0
2782 #define SQ_ENC_VINTRP_BITS 0xd4000000
2783 #define SQ_ENC_VINTRP_MASK 0xfc000000
2784 #define SQ_ENC_VINTRP_FIELD 0x35
2785 #define SQ_ENC_VOP3_BITS 0xd0000000
2786 #define SQ_ENC_VOP3_MASK 0xfc000000
2787 #define SQ_ENC_VOP3_FIELD 0x34
2788 #define SQ_ENC_DS_BITS 0xd8000000
2789 #define SQ_ENC_DS_MASK 0xfc000000
2790 #define SQ_ENC_DS_FIELD 0x36
2791 #define SQ_ENC_MUBUF_BITS 0xe0000000
2792 #define SQ_ENC_MUBUF_MASK 0xfc000000
2793 #define SQ_ENC_MUBUF_FIELD 0x38
2794 #define SQ_ENC_MTBUF_BITS 0xe8000000
2795 #define SQ_ENC_MTBUF_MASK 0xfc000000
2796 #define SQ_ENC_MTBUF_FIELD 0x3a
2797 #define SQ_ENC_MIMG_BITS 0xf0000000
2798 #define SQ_ENC_MIMG_MASK 0xfc000000
2799 #define SQ_ENC_MIMG_FIELD 0x3c
2800 #define SQ_ENC_EXP_BITS 0xc4000000
2801 #define SQ_ENC_EXP_MASK 0xfc000000
2802 #define SQ_ENC_EXP_FIELD 0x31
2803 #define SQ_ENC_FLAT_BITS 0xdc000000
2804 #define SQ_ENC_FLAT_MASK 0xfc000000
2805 #define SQ_ENC_FLAT_FIELD 0x37
2806 #define SQ_V_OP3_INTRP_OFFSET 0x274
2807 #define SQ_WAITCNT_VM_SHIFT 0x0
2808 #define SQ_SENDMSG_STREAMID_SIZE 0x2
2809 #define SQ_V_OPC_COUNT 0x100
2810 #define SQ_V_OP3_INTRP_COUNT 0xc
2811 #define SQ_XLATE_VOP3_TO_VOP2_OFFSET 0x100
2812 #define SQ_HWREG_OFFSET_SIZE 0x5
2813 #define SQ_HWREG_OFFSET_SHIFT 0x6
2814 #define SQ_V_OP3_3IN_OFFSET 0x1c0
2815 #define SQ_NUM_ATTR 0x21
2816 #define SQ_NUM_VGPR 0x100
2817 #define SQ_XLATE_VOP3_TO_VINTRP_COUNT 0x4
2818 #define SQ_SENDMSG_MSG_SIZE 0x4
2819 #define SQ_NUM_TTMP 0xc
2820 #define SQ_HWREG_ID_SIZE 0x6
2821 #define SQ_SENDMSG_GSOP_SIZE 0x2
2822 #define SQ_NUM_SGPR 0x66
2823 #define SQ_EXP_NUM_MRT 0x8
2824 #define SQ_SENDMSG_SYSTEM_SIZE 0x3
2825 #define SQ_WAITCNT_LGKM_SHIFT 0x8
2826 #define SQ_XLATE_VOP3_TO_VOP2_COUNT 0x40
2827 #define SQ_V_OP3_3IN_COUNT 0xb0
2828 #define SQ_V_INTRP_COUNT 0x4
2829 #define SQ_WAITCNT_EXP_SIZE 0x3
2830 #define SQ_SENDMSG_SYSTEM_SHIFT 0x4
2831 #define SQ_EXP_NUM_GDS 0x5
2832 #define SQ_HWREG_SIZE_SHIFT 0xb
2833 #define SQ_XLATE_VOP3_TO_VOPC_OFFSET 0x0
2834 #define SQ_V_OP3_2IN_COUNT 0x80
2835 #define SQ_XLATE_VOP3_TO_VINTRP_OFFSET 0x270
2836 #define SQ_SENDMSG_MSG_SHIFT 0x0
2837 #define SQ_WAITCNT_EXP_SHIFT 0x4
2838 #define SQ_WAITCNT_VM_SIZE 0x4
2839 #define SQ_XLATE_VOP3_TO_VOP1_OFFSET 0x140
2840 #define SQ_SENDMSG_GSOP_SHIFT 0x4
2841 #define SQ_XLATE_VOP3_TO_VOP1_COUNT 0x80
2842 #define SQ_SRC_VGPR_BIT 0x100
2843 #define SQ_V_OP2_COUNT 0x40
2844 #define SQ_EXP_NUM_PARAM 0x20
2845 #define SQ_V_OP1_COUNT 0x80
2846 #define SQ_SENDMSG_STREAMID_SHIFT 0x8
2847 #define SQ_V_OP3_2IN_OFFSET 0x280
2848 #define SQ_WAITCNT_LGKM_SIZE 0x4
2849 #define SQ_XLATE_VOP3_TO_VOPC_COUNT 0x100
2850 #define SQ_EXP_NUM_POS 0x4
2851 #define SQ_HWREG_SIZE_SIZE 0x5
2852 #define SQ_HWREG_ID_SHIFT 0x0
2853 #define SQ_S_MOV_B32 0x0
2854 #define SQ_S_MOV_B64 0x1
2855 #define SQ_S_CMOV_B32 0x2
2856 #define SQ_S_CMOV_B64 0x3
2857 #define SQ_S_NOT_B32 0x4
2858 #define SQ_S_NOT_B64 0x5
2859 #define SQ_S_WQM_B32 0x6
2860 #define SQ_S_WQM_B64 0x7
2861 #define SQ_S_BREV_B32 0x8
2862 #define SQ_S_BREV_B64 0x9
2863 #define SQ_S_BCNT0_I32_B32 0xa
2864 #define SQ_S_BCNT0_I32_B64 0xb
2865 #define SQ_S_BCNT1_I32_B32 0xc
2866 #define SQ_S_BCNT1_I32_B64 0xd
2867 #define SQ_S_FF0_I32_B32 0xe
2868 #define SQ_S_FF0_I32_B64 0xf
2869 #define SQ_S_FF1_I32_B32 0x10
2870 #define SQ_S_FF1_I32_B64 0x11
2871 #define SQ_S_FLBIT_I32_B32 0x12
2872 #define SQ_S_FLBIT_I32_B64 0x13
2873 #define SQ_S_FLBIT_I32 0x14
2874 #define SQ_S_FLBIT_I32_I64 0x15
2875 #define SQ_S_SEXT_I32_I8 0x16
2876 #define SQ_S_SEXT_I32_I16 0x17
2877 #define SQ_S_BITSET0_B32 0x18
2878 #define SQ_S_BITSET0_B64 0x19
2879 #define SQ_S_BITSET1_B32 0x1a
2880 #define SQ_S_BITSET1_B64 0x1b
2881 #define SQ_S_GETPC_B64 0x1c
2882 #define SQ_S_SETPC_B64 0x1d
2883 #define SQ_S_SWAPPC_B64 0x1e
2884 #define SQ_S_RFE_B64 0x1f
2885 #define SQ_S_AND_SAVEEXEC_B64 0x20
2886 #define SQ_S_OR_SAVEEXEC_B64 0x21
2887 #define SQ_S_XOR_SAVEEXEC_B64 0x22
2888 #define SQ_S_ANDN2_SAVEEXEC_B64 0x23
2889 #define SQ_S_ORN2_SAVEEXEC_B64 0x24
2890 #define SQ_S_NAND_SAVEEXEC_B64 0x25
2891 #define SQ_S_NOR_SAVEEXEC_B64 0x26
2892 #define SQ_S_XNOR_SAVEEXEC_B64 0x27
2893 #define SQ_S_QUADMASK_B32 0x28
2894 #define SQ_S_QUADMASK_B64 0x29
2895 #define SQ_S_MOVRELS_B32 0x2a
2896 #define SQ_S_MOVRELS_B64 0x2b
2897 #define SQ_S_MOVRELD_B32 0x2c
2898 #define SQ_S_MOVRELD_B64 0x2d
2899 #define SQ_S_CBRANCH_JOIN 0x2e
2900 #define SQ_S_MOV_REGRD_B32 0x2f
2901 #define SQ_S_ABS_I32 0x30
2902 #define SQ_S_MOV_FED_B32 0x31
2903 #define SQ_S_SET_GPR_IDX_IDX 0x32
2904 #define SQ_ATTR0 0x0
2905 #define SQ_S_MOVK_I32 0x0
2906 #define SQ_S_CMOVK_I32 0x1
2907 #define SQ_S_CMPK_EQ_I32 0x2
2908 #define SQ_S_CMPK_LG_I32 0x3
2909 #define SQ_S_CMPK_GT_I32 0x4
2910 #define SQ_S_CMPK_GE_I32 0x5
2911 #define SQ_S_CMPK_LT_I32 0x6
2912 #define SQ_S_CMPK_LE_I32 0x7
2913 #define SQ_S_CMPK_EQ_U32 0x8
2914 #define SQ_S_CMPK_LG_U32 0x9
2915 #define SQ_S_CMPK_GT_U32 0xa
2916 #define SQ_S_CMPK_GE_U32 0xb
2917 #define SQ_S_CMPK_LT_U32 0xc
2918 #define SQ_S_CMPK_LE_U32 0xd
2919 #define SQ_S_ADDK_I32 0xe
2920 #define SQ_S_MULK_I32 0xf
2921 #define SQ_S_CBRANCH_I_FORK 0x10
2922 #define SQ_S_GETREG_B32 0x11
2923 #define SQ_S_SETREG_B32 0x12
2924 #define SQ_S_GETREG_REGRD_B32 0x13
2925 #define SQ_S_SETREG_IMM32_B32 0x14
2926 #define SQ_TBA_LO 0x6c
2927 #define SQ_TBA_HI 0x6d
2928 #define SQ_TMA_LO 0x6e
2929 #define SQ_TMA_HI 0x6f
2930 #define SQ_TTMP0 0x70
2931 #define SQ_TTMP1 0x71
2932 #define SQ_TTMP2 0x72
2933 #define SQ_TTMP3 0x73
2934 #define SQ_TTMP4 0x74
2935 #define SQ_TTMP5 0x75
2936 #define SQ_TTMP6 0x76
2937 #define SQ_TTMP7 0x77
2938 #define SQ_TTMP8 0x78
2939 #define SQ_TTMP9 0x79
2940 #define SQ_TTMP10 0x7a
2941 #define SQ_TTMP11 0x7b
2942 #define SQ_VGPR0 0x0
2943 #define SQ_EXP 0x0
2944 #define SQ_EXP_MRT0 0x0
2945 #define SQ_EXP_MRTZ 0x8
2946 #define SQ_EXP_NULL 0x9
2947 #define SQ_EXP_POS0 0xc
2948 #define SQ_EXP_PARAM0 0x20
2949 #define SQ_CNT1 0x0
2950 #define SQ_CNT2 0x1
2951 #define SQ_CNT3 0x2
2952 #define SQ_CNT4 0x3
2953 #define SQ_S_LOAD_DWORD 0x0
2954 #define SQ_S_LOAD_DWORDX2 0x1
2955 #define SQ_S_LOAD_DWORDX4 0x2
2956 #define SQ_S_LOAD_DWORDX8 0x3
2957 #define SQ_S_LOAD_DWORDX16 0x4
2958 #define SQ_S_BUFFER_LOAD_DWORD 0x8
2959 #define SQ_S_BUFFER_LOAD_DWORDX2 0x9
2960 #define SQ_S_BUFFER_LOAD_DWORDX4 0xa
2961 #define SQ_S_BUFFER_LOAD_DWORDX8 0xb
2962 #define SQ_S_BUFFER_LOAD_DWORDX16 0xc
2963 #define SQ_S_STORE_DWORD 0x10
2964 #define SQ_S_STORE_DWORDX2 0x11
2965 #define SQ_S_STORE_DWORDX4 0x12
2966 #define SQ_S_BUFFER_STORE_DWORD 0x18
2967 #define SQ_S_BUFFER_STORE_DWORDX2 0x19
2968 #define SQ_S_BUFFER_STORE_DWORDX4 0x1a
2969 #define SQ_S_DCACHE_INV 0x20
2970 #define SQ_S_DCACHE_WB 0x21
2971 #define SQ_S_DCACHE_INV_VOL 0x22
2972 #define SQ_S_DCACHE_WB_VOL 0x23
2973 #define SQ_S_MEMTIME 0x24
2974 #define SQ_S_MEMREALTIME 0x25
2975 #define SQ_S_ATC_PROBE 0x26
2976 #define SQ_S_ATC_PROBE_BUFFER 0x27
2977 #define SQ_S_BUFFER_ATOMIC_SWAP 0x40
2978 #define SQ_S_BUFFER_ATOMIC_CMPSWAP 0x41
2979 #define SQ_S_BUFFER_ATOMIC_ADD 0x42
2980 #define SQ_S_BUFFER_ATOMIC_SUB 0x43
2981 #define SQ_S_BUFFER_ATOMIC_SMIN 0x44
2982 #define SQ_S_BUFFER_ATOMIC_UMIN 0x45
2983 #define SQ_S_BUFFER_ATOMIC_SMAX 0x46
2984 #define SQ_S_BUFFER_ATOMIC_UMAX 0x47
2985 #define SQ_S_BUFFER_ATOMIC_AND 0x48
2986 #define SQ_S_BUFFER_ATOMIC_OR 0x49
2987 #define SQ_S_BUFFER_ATOMIC_XOR 0x4a
2988 #define SQ_S_BUFFER_ATOMIC_INC 0x4b
2989 #define SQ_S_BUFFER_ATOMIC_DEC 0x4c
2990 #define SQ_S_BUFFER_ATOMIC_SWAP_X2 0x60
2991 #define SQ_S_BUFFER_ATOMIC_CMPSWAP_X2 0x61
2992 #define SQ_S_BUFFER_ATOMIC_ADD_X2 0x62
2993 #define SQ_S_BUFFER_ATOMIC_SUB_X2 0x63
2994 #define SQ_S_BUFFER_ATOMIC_SMIN_X2 0x64
2995 #define SQ_S_BUFFER_ATOMIC_UMIN_X2 0x65
2996 #define SQ_S_BUFFER_ATOMIC_SMAX_X2 0x66
2997 #define SQ_S_BUFFER_ATOMIC_UMAX_X2 0x67
2998 #define SQ_S_BUFFER_ATOMIC_AND_X2 0x68
2999 #define SQ_S_BUFFER_ATOMIC_OR_X2 0x69
3000 #define SQ_S_BUFFER_ATOMIC_XOR_X2 0x6a
3001 #define SQ_S_BUFFER_ATOMIC_INC_X2 0x6b
3002 #define SQ_S_BUFFER_ATOMIC_DEC_X2 0x6c
3003 #define SQ_F 0x0
3004 #define SQ_LT 0x1
3005 #define SQ_EQ 0x2
3006 #define SQ_LE 0x3
3007 #define SQ_GT 0x4
3008 #define SQ_LG 0x5
3009 #define SQ_GE 0x6
3010 #define SQ_O 0x7
3011 #define SQ_U 0x8
3012 #define SQ_NGE 0x9
3013 #define SQ_NLG 0xa
3014 #define SQ_NGT 0xb
3015 #define SQ_NLE 0xc
3016 #define SQ_NEQ 0xd
3017 #define SQ_NLT 0xe
3018 #define SQ_TRU 0xf
3019 #define SQ_V_CMP_CLASS_F32 0x10
3020 #define SQ_V_CMPX_CLASS_F32 0x11
3021 #define SQ_V_CMP_CLASS_F64 0x12
3022 #define SQ_V_CMPX_CLASS_F64 0x13
3023 #define SQ_V_CMP_CLASS_F16 0x14
3024 #define SQ_V_CMPX_CLASS_F16 0x15
3025 #define SQ_V_CMP_F_F16 0x20
3026 #define SQ_V_CMP_LT_F16 0x21
3027 #define SQ_V_CMP_EQ_F16 0x22
3028 #define SQ_V_CMP_LE_F16 0x23
3029 #define SQ_V_CMP_GT_F16 0x24
3030 #define SQ_V_CMP_LG_F16 0x25
3031 #define SQ_V_CMP_GE_F16 0x26
3032 #define SQ_V_CMP_O_F16 0x27
3033 #define SQ_V_CMP_U_F16 0x28
3034 #define SQ_V_CMP_NGE_F16 0x29
3035 #define SQ_V_CMP_NLG_F16 0x2a
3036 #define SQ_V_CMP_NGT_F16 0x2b
3037 #define SQ_V_CMP_NLE_F16 0x2c
3038 #define SQ_V_CMP_NEQ_F16 0x2d
3039 #define SQ_V_CMP_NLT_F16 0x2e
3040 #define SQ_V_CMP_TRU_F16 0x2f
3041 #define SQ_V_CMPX_F_F16 0x30
3042 #define SQ_V_CMPX_LT_F16 0x31
3043 #define SQ_V_CMPX_EQ_F16 0x32
3044 #define SQ_V_CMPX_LE_F16 0x33
3045 #define SQ_V_CMPX_GT_F16 0x34
3046 #define SQ_V_CMPX_LG_F16 0x35
3047 #define SQ_V_CMPX_GE_F16 0x36
3048 #define SQ_V_CMPX_O_F16 0x37
3049 #define SQ_V_CMPX_U_F16 0x38
3050 #define SQ_V_CMPX_NGE_F16 0x39
3051 #define SQ_V_CMPX_NLG_F16 0x3a
3052 #define SQ_V_CMPX_NGT_F16 0x3b
3053 #define SQ_V_CMPX_NLE_F16 0x3c
3054 #define SQ_V_CMPX_NEQ_F16 0x3d
3055 #define SQ_V_CMPX_NLT_F16 0x3e
3056 #define SQ_V_CMPX_TRU_F16 0x3f
3057 #define SQ_V_CMP_F_F32 0x40
3058 #define SQ_V_CMP_LT_F32 0x41
3059 #define SQ_V_CMP_EQ_F32 0x42
3060 #define SQ_V_CMP_LE_F32 0x43
3061 #define SQ_V_CMP_GT_F32 0x44
3062 #define SQ_V_CMP_LG_F32 0x45
3063 #define SQ_V_CMP_GE_F32 0x46
3064 #define SQ_V_CMP_O_F32 0x47
3065 #define SQ_V_CMP_U_F32 0x48
3066 #define SQ_V_CMP_NGE_F32 0x49
3067 #define SQ_V_CMP_NLG_F32 0x4a
3068 #define SQ_V_CMP_NGT_F32 0x4b
3069 #define SQ_V_CMP_NLE_F32 0x4c
3070 #define SQ_V_CMP_NEQ_F32 0x4d
3071 #define SQ_V_CMP_NLT_F32 0x4e
3072 #define SQ_V_CMP_TRU_F32 0x4f
3073 #define SQ_V_CMPX_F_F32 0x50
3074 #define SQ_V_CMPX_LT_F32 0x51
3075 #define SQ_V_CMPX_EQ_F32 0x52
3076 #define SQ_V_CMPX_LE_F32 0x53
3077 #define SQ_V_CMPX_GT_F32 0x54
3078 #define SQ_V_CMPX_LG_F32 0x55
3079 #define SQ_V_CMPX_GE_F32 0x56
3080 #define SQ_V_CMPX_O_F32 0x57
3081 #define SQ_V_CMPX_U_F32 0x58
3082 #define SQ_V_CMPX_NGE_F32 0x59
3083 #define SQ_V_CMPX_NLG_F32 0x5a
3084 #define SQ_V_CMPX_NGT_F32 0x5b
3085 #define SQ_V_CMPX_NLE_F32 0x5c
3086 #define SQ_V_CMPX_NEQ_F32 0x5d
3087 #define SQ_V_CMPX_NLT_F32 0x5e
3088 #define SQ_V_CMPX_TRU_F32 0x5f
3089 #define SQ_V_CMP_F_F64 0x60
3090 #define SQ_V_CMP_LT_F64 0x61
3091 #define SQ_V_CMP_EQ_F64 0x62
3092 #define SQ_V_CMP_LE_F64 0x63
3093 #define SQ_V_CMP_GT_F64 0x64
3094 #define SQ_V_CMP_LG_F64 0x65
3095 #define SQ_V_CMP_GE_F64 0x66
3096 #define SQ_V_CMP_O_F64 0x67
3097 #define SQ_V_CMP_U_F64 0x68
3098 #define SQ_V_CMP_NGE_F64 0x69
3099 #define SQ_V_CMP_NLG_F64 0x6a
3100 #define SQ_V_CMP_NGT_F64 0x6b
3101 #define SQ_V_CMP_NLE_F64 0x6c
3102 #define SQ_V_CMP_NEQ_F64 0x6d
3103 #define SQ_V_CMP_NLT_F64 0x6e
3104 #define SQ_V_CMP_TRU_F64 0x6f
3105 #define SQ_V_CMPX_F_F64 0x70
3106 #define SQ_V_CMPX_LT_F64 0x71
3107 #define SQ_V_CMPX_EQ_F64 0x72
3108 #define SQ_V_CMPX_LE_F64 0x73
3109 #define SQ_V_CMPX_GT_F64 0x74
3110 #define SQ_V_CMPX_LG_F64 0x75
3111 #define SQ_V_CMPX_GE_F64 0x76
3112 #define SQ_V_CMPX_O_F64 0x77
3113 #define SQ_V_CMPX_U_F64 0x78
3114 #define SQ_V_CMPX_NGE_F64 0x79
3115 #define SQ_V_CMPX_NLG_F64 0x7a
3116 #define SQ_V_CMPX_NGT_F64 0x7b
3117 #define SQ_V_CMPX_NLE_F64 0x7c
3118 #define SQ_V_CMPX_NEQ_F64 0x7d
3119 #define SQ_V_CMPX_NLT_F64 0x7e
3120 #define SQ_V_CMPX_TRU_F64 0x7f
3121 #define SQ_V_CMP_F_I16 0xa0
3122 #define SQ_V_CMP_LT_I16 0xa1
3123 #define SQ_V_CMP_EQ_I16 0xa2
3124 #define SQ_V_CMP_LE_I16 0xa3
3125 #define SQ_V_CMP_GT_I16 0xa4
3126 #define SQ_V_CMP_NE_I16 0xa5
3127 #define SQ_V_CMP_GE_I16 0xa6
3128 #define SQ_V_CMP_T_I16 0xa7
3129 #define SQ_V_CMP_F_U16 0xa8
3130 #define SQ_V_CMP_LT_U16 0xa9
3131 #define SQ_V_CMP_EQ_U16 0xaa
3132 #define SQ_V_CMP_LE_U16 0xab
3133 #define SQ_V_CMP_GT_U16 0xac
3134 #define SQ_V_CMP_NE_U16 0xad
3135 #define SQ_V_CMP_GE_U16 0xae
3136 #define SQ_V_CMP_T_U16 0xaf
3137 #define SQ_V_CMPX_F_I16 0xb0
3138 #define SQ_V_CMPX_LT_I16 0xb1
3139 #define SQ_V_CMPX_EQ_I16 0xb2
3140 #define SQ_V_CMPX_LE_I16 0xb3
3141 #define SQ_V_CMPX_GT_I16 0xb4
3142 #define SQ_V_CMPX_NE_I16 0xb5
3143 #define SQ_V_CMPX_GE_I16 0xb6
3144 #define SQ_V_CMPX_T_I16 0xb7
3145 #define SQ_V_CMPX_F_U16 0xb8
3146 #define SQ_V_CMPX_LT_U16 0xb9
3147 #define SQ_V_CMPX_EQ_U16 0xba
3148 #define SQ_V_CMPX_LE_U16 0xbb
3149 #define SQ_V_CMPX_GT_U16 0xbc
3150 #define SQ_V_CMPX_NE_U16 0xbd
3151 #define SQ_V_CMPX_GE_U16 0xbe
3152 #define SQ_V_CMPX_T_U16 0xbf
3153 #define SQ_V_CMP_F_I32 0xc0
3154 #define SQ_V_CMP_LT_I32 0xc1
3155 #define SQ_V_CMP_EQ_I32 0xc2
3156 #define SQ_V_CMP_LE_I32 0xc3
3157 #define SQ_V_CMP_GT_I32 0xc4
3158 #define SQ_V_CMP_NE_I32 0xc5
3159 #define SQ_V_CMP_GE_I32 0xc6
3160 #define SQ_V_CMP_T_I32 0xc7
3161 #define SQ_V_CMP_F_U32 0xc8
3162 #define SQ_V_CMP_LT_U32 0xc9
3163 #define SQ_V_CMP_EQ_U32 0xca
3164 #define SQ_V_CMP_LE_U32 0xcb
3165 #define SQ_V_CMP_GT_U32 0xcc
3166 #define SQ_V_CMP_NE_U32 0xcd
3167 #define SQ_V_CMP_GE_U32 0xce
3168 #define SQ_V_CMP_T_U32 0xcf
3169 #define SQ_V_CMPX_F_I32 0xd0
3170 #define SQ_V_CMPX_LT_I32 0xd1
3171 #define SQ_V_CMPX_EQ_I32 0xd2
3172 #define SQ_V_CMPX_LE_I32 0xd3
3173 #define SQ_V_CMPX_GT_I32 0xd4
3174 #define SQ_V_CMPX_NE_I32 0xd5
3175 #define SQ_V_CMPX_GE_I32 0xd6
3176 #define SQ_V_CMPX_T_I32 0xd7
3177 #define SQ_V_CMPX_F_U32 0xd8
3178 #define SQ_V_CMPX_LT_U32 0xd9
3179 #define SQ_V_CMPX_EQ_U32 0xda
3180 #define SQ_V_CMPX_LE_U32 0xdb
3181 #define SQ_V_CMPX_GT_U32 0xdc
3182 #define SQ_V_CMPX_NE_U32 0xdd
3183 #define SQ_V_CMPX_GE_U32 0xde
3184 #define SQ_V_CMPX_T_U32 0xdf
3185 #define SQ_V_CMP_F_I64 0xe0
3186 #define SQ_V_CMP_LT_I64 0xe1
3187 #define SQ_V_CMP_EQ_I64 0xe2
3188 #define SQ_V_CMP_LE_I64 0xe3
3189 #define SQ_V_CMP_GT_I64 0xe4
3190 #define SQ_V_CMP_NE_I64 0xe5
3191 #define SQ_V_CMP_GE_I64 0xe6
3192 #define SQ_V_CMP_T_I64 0xe7
3193 #define SQ_V_CMP_F_U64 0xe8
3194 #define SQ_V_CMP_LT_U64 0xe9
3195 #define SQ_V_CMP_EQ_U64 0xea
3196 #define SQ_V_CMP_LE_U64 0xeb
3197 #define SQ_V_CMP_GT_U64 0xec
3198 #define SQ_V_CMP_NE_U64 0xed
3199 #define SQ_V_CMP_GE_U64 0xee
3200 #define SQ_V_CMP_T_U64 0xef
3201 #define SQ_V_CMPX_F_I64 0xf0
3202 #define SQ_V_CMPX_LT_I64 0xf1
3203 #define SQ_V_CMPX_EQ_I64 0xf2
3204 #define SQ_V_CMPX_LE_I64 0xf3
3205 #define SQ_V_CMPX_GT_I64 0xf4
3206 #define SQ_V_CMPX_NE_I64 0xf5
3207 #define SQ_V_CMPX_GE_I64 0xf6
3208 #define SQ_V_CMPX_T_I64 0xf7
3209 #define SQ_V_CMPX_F_U64 0xf8
3210 #define SQ_V_CMPX_LT_U64 0xf9
3211 #define SQ_V_CMPX_EQ_U64 0xfa
3212 #define SQ_V_CMPX_LE_U64 0xfb
3213 #define SQ_V_CMPX_GT_U64 0xfc
3214 #define SQ_V_CMPX_NE_U64 0xfd
3215 #define SQ_V_CMPX_GE_U64 0xfe
3216 #define SQ_V_CMPX_T_U64 0xff
3217 #define SQ_L1 0x1
3218 #define SQ_L2 0x2
3219 #define SQ_L3 0x3
3220 #define SQ_L4 0x4
3221 #define SQ_L5 0x5
3222 #define SQ_L6 0x6
3223 #define SQ_L7 0x7
3224 #define SQ_L8 0x8
3225 #define SQ_L9 0x9
3226 #define SQ_L10 0xa
3227 #define SQ_L11 0xb
3228 #define SQ_L12 0xc
3229 #define SQ_L13 0xd
3230 #define SQ_L14 0xe
3231 #define SQ_L15 0xf
3232 #define SQ_SGPR0 0x0
3233 #define SQ_SDWA_UNUSED_PAD 0x0
3234 #define SQ_SDWA_UNUSED_SEXT 0x1
3235 #define SQ_SDWA_UNUSED_PRESERVE 0x2
3236 #define SQ_F 0x0
3237 #define SQ_LT 0x1
3238 #define SQ_EQ 0x2
3239 #define SQ_LE 0x3
3240 #define SQ_GT 0x4
3241 #define SQ_NE 0x5
3242 #define SQ_GE 0x6
3243 #define SQ_T 0x7
3244 #define SQ_SRC_64_INT 0xc0
3245 #define SQ_SRC_M_1_INT 0xc1
3246 #define SQ_SRC_M_2_INT 0xc2
3247 #define SQ_SRC_M_3_INT 0xc3
3248 #define SQ_SRC_M_4_INT 0xc4
3249 #define SQ_SRC_M_5_INT 0xc5
3250 #define SQ_SRC_M_6_INT 0xc6
3251 #define SQ_SRC_M_7_INT 0xc7
3252 #define SQ_SRC_M_8_INT 0xc8
3253 #define SQ_SRC_M_9_INT 0xc9
3254 #define SQ_SRC_M_10_INT 0xca
3255 #define SQ_SRC_M_11_INT 0xcb
3256 #define SQ_SRC_M_12_INT 0xcc
3257 #define SQ_SRC_M_13_INT 0xcd
3258 #define SQ_SRC_M_14_INT 0xce
3259 #define SQ_SRC_M_15_INT 0xcf
3260 #define SQ_SRC_M_16_INT 0xd0
3261 #define SQ_SRC_0_5 0xf0
3262 #define SQ_SRC_M_0_5 0xf1
3263 #define SQ_SRC_1 0xf2
3264 #define SQ_SRC_M_1 0xf3
3265 #define SQ_SRC_2 0xf4
3266 #define SQ_SRC_M_2 0xf5
3267 #define SQ_SRC_4 0xf6
3268 #define SQ_SRC_M_4 0xf7
3269 #define SQ_SRC_INV_2PI 0xf8
3270 #define SQ_SRC_0 0x80
3271 #define SQ_SRC_1_INT 0x81
3272 #define SQ_SRC_2_INT 0x82
3273 #define SQ_SRC_3_INT 0x83
3274 #define SQ_SRC_4_INT 0x84
3275 #define SQ_SRC_5_INT 0x85
3276 #define SQ_SRC_6_INT 0x86
3277 #define SQ_SRC_7_INT 0x87
3278 #define SQ_SRC_8_INT 0x88
3279 #define SQ_SRC_9_INT 0x89
3280 #define SQ_SRC_10_INT 0x8a
3281 #define SQ_SRC_11_INT 0x8b
3282 #define SQ_SRC_12_INT 0x8c
3283 #define SQ_SRC_13_INT 0x8d
3284 #define SQ_SRC_14_INT 0x8e
3285 #define SQ_SRC_15_INT 0x8f
3286 #define SQ_SRC_16_INT 0x90
3287 #define SQ_SRC_17_INT 0x91
3288 #define SQ_SRC_18_INT 0x92
3289 #define SQ_SRC_19_INT 0x93
3290 #define SQ_SRC_20_INT 0x94
3291 #define SQ_SRC_21_INT 0x95
3292 #define SQ_SRC_22_INT 0x96
3293 #define SQ_SRC_23_INT 0x97
3294 #define SQ_SRC_24_INT 0x98
3295 #define SQ_SRC_25_INT 0x99
3296 #define SQ_SRC_26_INT 0x9a
3297 #define SQ_SRC_27_INT 0x9b
3298 #define SQ_SRC_28_INT 0x9c
3299 #define SQ_SRC_29_INT 0x9d
3300 #define SQ_SRC_30_INT 0x9e
3301 #define SQ_SRC_31_INT 0x9f
3302 #define SQ_SRC_32_INT 0xa0
3303 #define SQ_SRC_33_INT 0xa1
3304 #define SQ_SRC_34_INT 0xa2
3305 #define SQ_SRC_35_INT 0xa3
3306 #define SQ_SRC_36_INT 0xa4
3307 #define SQ_SRC_37_INT 0xa5
3308 #define SQ_SRC_38_INT 0xa6
3309 #define SQ_SRC_39_INT 0xa7
3310 #define SQ_SRC_40_INT 0xa8
3311 #define SQ_SRC_41_INT 0xa9
3312 #define SQ_SRC_42_INT 0xaa
3313 #define SQ_SRC_43_INT 0xab
3314 #define SQ_SRC_44_INT 0xac
3315 #define SQ_SRC_45_INT 0xad
3316 #define SQ_SRC_46_INT 0xae
3317 #define SQ_SRC_47_INT 0xaf
3318 #define SQ_SRC_48_INT 0xb0
3319 #define SQ_SRC_49_INT 0xb1
3320 #define SQ_SRC_50_INT 0xb2
3321 #define SQ_SRC_51_INT 0xb3
3322 #define SQ_SRC_52_INT 0xb4
3323 #define SQ_SRC_53_INT 0xb5
3324 #define SQ_SRC_54_INT 0xb6
3325 #define SQ_SRC_55_INT 0xb7
3326 #define SQ_SRC_56_INT 0xb8
3327 #define SQ_SRC_57_INT 0xb9
3328 #define SQ_SRC_58_INT 0xba
3329 #define SQ_SRC_59_INT 0xbb
3330 #define SQ_SRC_60_INT 0xbc
3331 #define SQ_SRC_61_INT 0xbd
3332 #define SQ_SRC_62_INT 0xbe
3333 #define SQ_SRC_63_INT 0xbf
3334 #define SQ_DS_ADD_U32 0x0
3335 #define SQ_DS_SUB_U32 0x1
3336 #define SQ_DS_RSUB_U32 0x2
3337 #define SQ_DS_INC_U32 0x3
3338 #define SQ_DS_DEC_U32 0x4
3339 #define SQ_DS_MIN_I32 0x5
3340 #define SQ_DS_MAX_I32 0x6
3341 #define SQ_DS_MIN_U32 0x7
3342 #define SQ_DS_MAX_U32 0x8
3343 #define SQ_DS_AND_B32 0x9
3344 #define SQ_DS_OR_B32 0xa
3345 #define SQ_DS_XOR_B32 0xb
3346 #define SQ_DS_MSKOR_B32 0xc
3347 #define SQ_DS_WRITE_B32 0xd
3348 #define SQ_DS_WRITE2_B32 0xe
3349 #define SQ_DS_WRITE2ST64_B32 0xf
3350 #define SQ_DS_CMPST_B32 0x10
3351 #define SQ_DS_CMPST_F32 0x11
3352 #define SQ_DS_MIN_F32 0x12
3353 #define SQ_DS_MAX_F32 0x13
3354 #define SQ_DS_NOP 0x14
3355 #define SQ_DS_ADD_F32 0x15
3356 #define SQ_DS_WRITE_B8 0x1e
3357 #define SQ_DS_WRITE_B16 0x1f
3358 #define SQ_DS_ADD_RTN_U32 0x20
3359 #define SQ_DS_SUB_RTN_U32 0x21
3360 #define SQ_DS_RSUB_RTN_U32 0x22
3361 #define SQ_DS_INC_RTN_U32 0x23
3362 #define SQ_DS_DEC_RTN_U32 0x24
3363 #define SQ_DS_MIN_RTN_I32 0x25
3364 #define SQ_DS_MAX_RTN_I32 0x26
3365 #define SQ_DS_MIN_RTN_U32 0x27
3366 #define SQ_DS_MAX_RTN_U32 0x28
3367 #define SQ_DS_AND_RTN_B32 0x29
3368 #define SQ_DS_OR_RTN_B32 0x2a
3369 #define SQ_DS_XOR_RTN_B32 0x2b
3370 #define SQ_DS_MSKOR_RTN_B32 0x2c
3371 #define SQ_DS_WRXCHG_RTN_B32 0x2d
3372 #define SQ_DS_WRXCHG2_RTN_B32 0x2e
3373 #define SQ_DS_WRXCHG2ST64_RTN_B32 0x2f
3374 #define SQ_DS_CMPST_RTN_B32 0x30
3375 #define SQ_DS_CMPST_RTN_F32 0x31
3376 #define SQ_DS_MIN_RTN_F32 0x32
3377 #define SQ_DS_MAX_RTN_F32 0x33
3378 #define SQ_DS_WRAP_RTN_B32 0x34
3379 #define SQ_DS_ADD_RTN_F32 0x35
3380 #define SQ_DS_READ_B32 0x36
3381 #define SQ_DS_READ2_B32 0x37
3382 #define SQ_DS_READ2ST64_B32 0x38
3383 #define SQ_DS_READ_I8 0x39
3384 #define SQ_DS_READ_U8 0x3a
3385 #define SQ_DS_READ_I16 0x3b
3386 #define SQ_DS_READ_U16 0x3c
3387 #define SQ_DS_SWIZZLE_B32 0x3d
3388 #define SQ_DS_PERMUTE_B32 0x3e
3389 #define SQ_DS_BPERMUTE_B32 0x3f
3390 #define SQ_DS_ADD_U64 0x40
3391 #define SQ_DS_SUB_U64 0x41
3392 #define SQ_DS_RSUB_U64 0x42
3393 #define SQ_DS_INC_U64 0x43
3394 #define SQ_DS_DEC_U64 0x44
3395 #define SQ_DS_MIN_I64 0x45
3396 #define SQ_DS_MAX_I64 0x46
3397 #define SQ_DS_MIN_U64 0x47
3398 #define SQ_DS_MAX_U64 0x48
3399 #define SQ_DS_AND_B64 0x49
3400 #define SQ_DS_OR_B64 0x4a
3401 #define SQ_DS_XOR_B64 0x4b
3402 #define SQ_DS_MSKOR_B64 0x4c
3403 #define SQ_DS_WRITE_B64 0x4d
3404 #define SQ_DS_WRITE2_B64 0x4e
3405 #define SQ_DS_WRITE2ST64_B64 0x4f
3406 #define SQ_DS_CMPST_B64 0x50
3407 #define SQ_DS_CMPST_F64 0x51
3408 #define SQ_DS_MIN_F64 0x52
3409 #define SQ_DS_MAX_F64 0x53
3410 #define SQ_DS_ADD_RTN_U64 0x60
3411 #define SQ_DS_SUB_RTN_U64 0x61
3412 #define SQ_DS_RSUB_RTN_U64 0x62
3413 #define SQ_DS_INC_RTN_U64 0x63
3414 #define SQ_DS_DEC_RTN_U64 0x64
3415 #define SQ_DS_MIN_RTN_I64 0x65
3416 #define SQ_DS_MAX_RTN_I64 0x66
3417 #define SQ_DS_MIN_RTN_U64 0x67
3418 #define SQ_DS_MAX_RTN_U64 0x68
3419 #define SQ_DS_AND_RTN_B64 0x69
3420 #define SQ_DS_OR_RTN_B64 0x6a
3421 #define SQ_DS_XOR_RTN_B64 0x6b
3422 #define SQ_DS_MSKOR_RTN_B64 0x6c
3423 #define SQ_DS_WRXCHG_RTN_B64 0x6d
3424 #define SQ_DS_WRXCHG2_RTN_B64 0x6e
3425 #define SQ_DS_WRXCHG2ST64_RTN_B64 0x6f
3426 #define SQ_DS_CMPST_RTN_B64 0x70
3427 #define SQ_DS_CMPST_RTN_F64 0x71
3428 #define SQ_DS_MIN_RTN_F64 0x72
3429 #define SQ_DS_MAX_RTN_F64 0x73
3430 #define SQ_DS_READ_B64 0x76
3431 #define SQ_DS_READ2_B64 0x77
3432 #define SQ_DS_READ2ST64_B64 0x78
3433 #define SQ_DS_CONDXCHG32_RTN_B64 0x7e
3434 #define SQ_DS_ADD_SRC2_U32 0x80
3435 #define SQ_DS_SUB_SRC2_U32 0x81
3436 #define SQ_DS_RSUB_SRC2_U32 0x82
3437 #define SQ_DS_INC_SRC2_U32 0x83
3438 #define SQ_DS_DEC_SRC2_U32 0x84
3439 #define SQ_DS_MIN_SRC2_I32 0x85
3440 #define SQ_DS_MAX_SRC2_I32 0x86
3441 #define SQ_DS_MIN_SRC2_U32 0x87
3442 #define SQ_DS_MAX_SRC2_U32 0x88
3443 #define SQ_DS_AND_SRC2_B32 0x89
3444 #define SQ_DS_OR_SRC2_B32 0x8a
3445 #define SQ_DS_XOR_SRC2_B32 0x8b
3446 #define SQ_DS_WRITE_SRC2_B32 0x8d
3447 #define SQ_DS_MIN_SRC2_F32 0x92
3448 #define SQ_DS_MAX_SRC2_F32 0x93
3449 #define SQ_DS_ADD_SRC2_F32 0x95
3450 #define SQ_DS_GWS_SEMA_RELEASE_ALL 0x98
3451 #define SQ_DS_GWS_INIT 0x99
3452 #define SQ_DS_GWS_SEMA_V 0x9a
3453 #define SQ_DS_GWS_SEMA_BR 0x9b
3454 #define SQ_DS_GWS_SEMA_P 0x9c
3455 #define SQ_DS_GWS_BARRIER 0x9d
3456 #define SQ_DS_CONSUME 0xbd
3457 #define SQ_DS_APPEND 0xbe
3458 #define SQ_DS_ORDERED_COUNT 0xbf
3459 #define SQ_DS_ADD_SRC2_U64 0xc0
3460 #define SQ_DS_SUB_SRC2_U64 0xc1
3461 #define SQ_DS_RSUB_SRC2_U64 0xc2
3462 #define SQ_DS_INC_SRC2_U64 0xc3
3463 #define SQ_DS_DEC_SRC2_U64 0xc4
3464 #define SQ_DS_MIN_SRC2_I64 0xc5
3465 #define SQ_DS_MAX_SRC2_I64 0xc6
3466 #define SQ_DS_MIN_SRC2_U64 0xc7
3467 #define SQ_DS_MAX_SRC2_U64 0xc8
3468 #define SQ_DS_AND_SRC2_B64 0xc9
3469 #define SQ_DS_OR_SRC2_B64 0xca
3470 #define SQ_DS_XOR_SRC2_B64 0xcb
3471 #define SQ_DS_WRITE_SRC2_B64 0xcd
3472 #define SQ_DS_MIN_SRC2_F64 0xd2
3473 #define SQ_DS_MAX_SRC2_F64 0xd3
3474 #define SQ_DS_WRITE_B96 0xde
3475 #define SQ_DS_WRITE_B128 0xdf
3476 #define SQ_DS_CONDXCHG32_RTN_B128 0xfd
3477 #define SQ_DS_READ_B96 0xfe
3478 #define SQ_DS_READ_B128 0xff
3479 #define SQ_BUFFER_LOAD_FORMAT_X 0x0
3480 #define SQ_BUFFER_LOAD_FORMAT_XY 0x1
3481 #define SQ_BUFFER_LOAD_FORMAT_XYZ 0x2
3482 #define SQ_BUFFER_LOAD_FORMAT_XYZW 0x3
3483 #define SQ_BUFFER_STORE_FORMAT_X 0x4
3484 #define SQ_BUFFER_STORE_FORMAT_XY 0x5
3485 #define SQ_BUFFER_STORE_FORMAT_XYZ 0x6
3486 #define SQ_BUFFER_STORE_FORMAT_XYZW 0x7
3487 #define SQ_BUFFER_LOAD_FORMAT_D16_X 0x8
3488 #define SQ_BUFFER_LOAD_FORMAT_D16_XY 0x9
3489 #define SQ_BUFFER_LOAD_FORMAT_D16_XYZ 0xa
3490 #define SQ_BUFFER_LOAD_FORMAT_D16_XYZW 0xb
3491 #define SQ_BUFFER_STORE_FORMAT_D16_X 0xc
3492 #define SQ_BUFFER_STORE_FORMAT_D16_XY 0xd
3493 #define SQ_BUFFER_STORE_FORMAT_D16_XYZ 0xe
3494 #define SQ_BUFFER_STORE_FORMAT_D16_XYZW 0xf
3495 #define SQ_BUFFER_LOAD_UBYTE 0x10
3496 #define SQ_BUFFER_LOAD_SBYTE 0x11
3497 #define SQ_BUFFER_LOAD_USHORT 0x12
3498 #define SQ_BUFFER_LOAD_SSHORT 0x13
3499 #define SQ_BUFFER_LOAD_DWORD 0x14
3500 #define SQ_BUFFER_LOAD_DWORDX2 0x15
3501 #define SQ_BUFFER_LOAD_DWORDX3 0x16
3502 #define SQ_BUFFER_LOAD_DWORDX4 0x17
3503 #define SQ_BUFFER_STORE_BYTE 0x18
3504 #define SQ_BUFFER_STORE_SHORT 0x1a
3505 #define SQ_BUFFER_STORE_DWORD 0x1c
3506 #define SQ_BUFFER_STORE_DWORDX2 0x1d
3507 #define SQ_BUFFER_STORE_DWORDX3 0x1e
3508 #define SQ_BUFFER_STORE_DWORDX4 0x1f
3509 #define SQ_BUFFER_STORE_LDS_DWORD 0x3d
3510 #define SQ_BUFFER_WBINVL1 0x3e
3511 #define SQ_BUFFER_WBINVL1_VOL 0x3f
3512 #define SQ_BUFFER_ATOMIC_SWAP 0x40
3513 #define SQ_BUFFER_ATOMIC_CMPSWAP 0x41
3514 #define SQ_BUFFER_ATOMIC_ADD 0x42
3515 #define SQ_BUFFER_ATOMIC_SUB 0x43
3516 #define SQ_BUFFER_ATOMIC_SMIN 0x44
3517 #define SQ_BUFFER_ATOMIC_UMIN 0x45
3518 #define SQ_BUFFER_ATOMIC_SMAX 0x46
3519 #define SQ_BUFFER_ATOMIC_UMAX 0x47
3520 #define SQ_BUFFER_ATOMIC_AND 0x48
3521 #define SQ_BUFFER_ATOMIC_OR 0x49
3522 #define SQ_BUFFER_ATOMIC_XOR 0x4a
3523 #define SQ_BUFFER_ATOMIC_INC 0x4b
3524 #define SQ_BUFFER_ATOMIC_DEC 0x4c
3525 #define SQ_BUFFER_ATOMIC_SWAP_X2 0x60
3526 #define SQ_BUFFER_ATOMIC_CMPSWAP_X2 0x61
3527 #define SQ_BUFFER_ATOMIC_ADD_X2 0x62
3528 #define SQ_BUFFER_ATOMIC_SUB_X2 0x63
3529 #define SQ_BUFFER_ATOMIC_SMIN_X2 0x64
3530 #define SQ_BUFFER_ATOMIC_UMIN_X2 0x65
3531 #define SQ_BUFFER_ATOMIC_SMAX_X2 0x66
3532 #define SQ_BUFFER_ATOMIC_UMAX_X2 0x67
3533 #define SQ_BUFFER_ATOMIC_AND_X2 0x68
3534 #define SQ_BUFFER_ATOMIC_OR_X2 0x69
3535 #define SQ_BUFFER_ATOMIC_XOR_X2 0x6a
3536 #define SQ_BUFFER_ATOMIC_INC_X2 0x6b
3537 #define SQ_BUFFER_ATOMIC_DEC_X2 0x6c
3538 #define SQ_EXEC_LO 0x7e
3539 #define SQ_EXEC_HI 0x7f
3540 #define SQ_SRC_SCC 0xfd
3541 #define SQ_OMOD_OFF 0x0
3542 #define SQ_OMOD_M2 0x1
3543 #define SQ_OMOD_M4 0x2
3544 #define SQ_OMOD_D2 0x3
3545 #define SQ_DPP_QUAD_PERM 0x0
3546 #define SQ_DPP_ROW_SL1 0x101
3547 #define SQ_DPP_ROW_SL2 0x102
3548 #define SQ_DPP_ROW_SL3 0x103
3549 #define SQ_DPP_ROW_SL4 0x104
3550 #define SQ_DPP_ROW_SL5 0x105
3551 #define SQ_DPP_ROW_SL6 0x106
3552 #define SQ_DPP_ROW_SL7 0x107
3553 #define SQ_DPP_ROW_SL8 0x108
3554 #define SQ_DPP_ROW_SL9 0x109
3555 #define SQ_DPP_ROW_SL10 0x10a
3556 #define SQ_DPP_ROW_SL11 0x10b
3557 #define SQ_DPP_ROW_SL12 0x10c
3558 #define SQ_DPP_ROW_SL13 0x10d
3559 #define SQ_DPP_ROW_SL14 0x10e
3560 #define SQ_DPP_ROW_SL15 0x10f
3561 #define SQ_DPP_ROW_SR1 0x111
3562 #define SQ_DPP_ROW_SR2 0x112
3563 #define SQ_DPP_ROW_SR3 0x113
3564 #define SQ_DPP_ROW_SR4 0x114
3565 #define SQ_DPP_ROW_SR5 0x115
3566 #define SQ_DPP_ROW_SR6 0x116
3567 #define SQ_DPP_ROW_SR7 0x117
3568 #define SQ_DPP_ROW_SR8 0x118
3569 #define SQ_DPP_ROW_SR9 0x119
3570 #define SQ_DPP_ROW_SR10 0x11a
3571 #define SQ_DPP_ROW_SR11 0x11b
3572 #define SQ_DPP_ROW_SR12 0x11c
3573 #define SQ_DPP_ROW_SR13 0x11d
3574 #define SQ_DPP_ROW_SR14 0x11e
3575 #define SQ_DPP_ROW_SR15 0x11f
3576 #define SQ_DPP_ROW_RR1 0x121
3577 #define SQ_DPP_ROW_RR2 0x122
3578 #define SQ_DPP_ROW_RR3 0x123
3579 #define SQ_DPP_ROW_RR4 0x124
3580 #define SQ_DPP_ROW_RR5 0x125
3581 #define SQ_DPP_ROW_RR6 0x126
3582 #define SQ_DPP_ROW_RR7 0x127
3583 #define SQ_DPP_ROW_RR8 0x128
3584 #define SQ_DPP_ROW_RR9 0x129
3585 #define SQ_DPP_ROW_RR10 0x12a
3586 #define SQ_DPP_ROW_RR11 0x12b
3587 #define SQ_DPP_ROW_RR12 0x12c
3588 #define SQ_DPP_ROW_RR13 0x12d
3589 #define SQ_DPP_ROW_RR14 0x12e
3590 #define SQ_DPP_ROW_RR15 0x12f
3591 #define SQ_DPP_WF_SL1 0x130
3592 #define SQ_DPP_WF_RL1 0x134
3593 #define SQ_DPP_WF_SR1 0x138
3594 #define SQ_DPP_WF_RR1 0x13c
3595 #define SQ_DPP_ROW_MIRROR 0x140
3596 #define SQ_DPP_ROW_HALF_MIRROR 0x141
3597 #define SQ_DPP_ROW_BCAST15 0x142
3598 #define SQ_DPP_ROW_BCAST31 0x143
3599 #define SQ_EXP_GDS0 0x18
3600 #define SQ_GS_OP_NOP 0x0
3601 #define SQ_GS_OP_CUT 0x1
3602 #define SQ_GS_OP_EMIT 0x2
3603 #define SQ_GS_OP_EMIT_CUT 0x3
3604 #define SQ_IMAGE_LOAD 0x0
3605 #define SQ_IMAGE_LOAD_MIP 0x1
3606 #define SQ_IMAGE_LOAD_PCK 0x2
3607 #define SQ_IMAGE_LOAD_PCK_SGN 0x3
3608 #define SQ_IMAGE_LOAD_MIP_PCK 0x4
3609 #define SQ_IMAGE_LOAD_MIP_PCK_SGN 0x5
3610 #define SQ_IMAGE_STORE 0x8
3611 #define SQ_IMAGE_STORE_MIP 0x9
3612 #define SQ_IMAGE_STORE_PCK 0xa
3613 #define SQ_IMAGE_STORE_MIP_PCK 0xb
3614 #define SQ_IMAGE_GET_RESINFO 0xe
3615 #define SQ_IMAGE_ATOMIC_SWAP 0x10
3616 #define SQ_IMAGE_ATOMIC_CMPSWAP 0x11
3617 #define SQ_IMAGE_ATOMIC_ADD 0x12
3618 #define SQ_IMAGE_ATOMIC_SUB 0x13
3619 #define SQ_IMAGE_ATOMIC_SMIN 0x14
3620 #define SQ_IMAGE_ATOMIC_UMIN 0x15
3621 #define SQ_IMAGE_ATOMIC_SMAX 0x16
3622 #define SQ_IMAGE_ATOMIC_UMAX 0x17
3623 #define SQ_IMAGE_ATOMIC_AND 0x18
3624 #define SQ_IMAGE_ATOMIC_OR 0x19
3625 #define SQ_IMAGE_ATOMIC_XOR 0x1a
3626 #define SQ_IMAGE_ATOMIC_INC 0x1b
3627 #define SQ_IMAGE_ATOMIC_DEC 0x1c
3628 #define SQ_IMAGE_SAMPLE 0x20
3629 #define SQ_IMAGE_SAMPLE_CL 0x21
3630 #define SQ_IMAGE_SAMPLE_D 0x22
3631 #define SQ_IMAGE_SAMPLE_D_CL 0x23
3632 #define SQ_IMAGE_SAMPLE_L 0x24
3633 #define SQ_IMAGE_SAMPLE_B 0x25
3634 #define SQ_IMAGE_SAMPLE_B_CL 0x26
3635 #define SQ_IMAGE_SAMPLE_LZ 0x27
3636 #define SQ_IMAGE_SAMPLE_C 0x28
3637 #define SQ_IMAGE_SAMPLE_C_CL 0x29
3638 #define SQ_IMAGE_SAMPLE_C_D 0x2a
3639 #define SQ_IMAGE_SAMPLE_C_D_CL 0x2b
3640 #define SQ_IMAGE_SAMPLE_C_L 0x2c
3641 #define SQ_IMAGE_SAMPLE_C_B 0x2d
3642 #define SQ_IMAGE_SAMPLE_C_B_CL 0x2e
3643 #define SQ_IMAGE_SAMPLE_C_LZ 0x2f
3644 #define SQ_IMAGE_SAMPLE_O 0x30
3645 #define SQ_IMAGE_SAMPLE_CL_O 0x31
3646 #define SQ_IMAGE_SAMPLE_D_O 0x32
3647 #define SQ_IMAGE_SAMPLE_D_CL_O 0x33
3648 #define SQ_IMAGE_SAMPLE_L_O 0x34
3649 #define SQ_IMAGE_SAMPLE_B_O 0x35
3650 #define SQ_IMAGE_SAMPLE_B_CL_O 0x36
3651 #define SQ_IMAGE_SAMPLE_LZ_O 0x37
3652 #define SQ_IMAGE_SAMPLE_C_O 0x38
3653 #define SQ_IMAGE_SAMPLE_C_CL_O 0x39
3654 #define SQ_IMAGE_SAMPLE_C_D_O 0x3a
3655 #define SQ_IMAGE_SAMPLE_C_D_CL_O 0x3b
3656 #define SQ_IMAGE_SAMPLE_C_L_O 0x3c
3657 #define SQ_IMAGE_SAMPLE_C_B_O 0x3d
3658 #define SQ_IMAGE_SAMPLE_C_B_CL_O 0x3e
3659 #define SQ_IMAGE_SAMPLE_C_LZ_O 0x3f
3660 #define SQ_IMAGE_GATHER4 0x40
3661 #define SQ_IMAGE_GATHER4_CL 0x41
3662 #define SQ_IMAGE_GATHER4_L 0x44
3663 #define SQ_IMAGE_GATHER4_B 0x45
3664 #define SQ_IMAGE_GATHER4_B_CL 0x46
3665 #define SQ_IMAGE_GATHER4_LZ 0x47
3666 #define SQ_IMAGE_GATHER4_C 0x48
3667 #define SQ_IMAGE_GATHER4_C_CL 0x49
3668 #define SQ_IMAGE_GATHER4_C_L 0x4c
3669 #define SQ_IMAGE_GATHER4_C_B 0x4d
3670 #define SQ_IMAGE_GATHER4_C_B_CL 0x4e
3671 #define SQ_IMAGE_GATHER4_C_LZ 0x4f
3672 #define SQ_IMAGE_GATHER4_O 0x50
3673 #define SQ_IMAGE_GATHER4_CL_O 0x51
3674 #define SQ_IMAGE_GATHER4_L_O 0x54
3675 #define SQ_IMAGE_GATHER4_B_O 0x55
3676 #define SQ_IMAGE_GATHER4_B_CL_O 0x56
3677 #define SQ_IMAGE_GATHER4_LZ_O 0x57
3678 #define SQ_IMAGE_GATHER4_C_O 0x58
3679 #define SQ_IMAGE_GATHER4_C_CL_O 0x59
3680 #define SQ_IMAGE_GATHER4_C_L_O 0x5c
3681 #define SQ_IMAGE_GATHER4_C_B_O 0x5d
3682 #define SQ_IMAGE_GATHER4_C_B_CL_O 0x5e
3683 #define SQ_IMAGE_GATHER4_C_LZ_O 0x5f
3684 #define SQ_IMAGE_GET_LOD 0x60
3685 #define SQ_IMAGE_SAMPLE_CD 0x68
3686 #define SQ_IMAGE_SAMPLE_CD_CL 0x69
3687 #define SQ_IMAGE_SAMPLE_C_CD 0x6a
3688 #define SQ_IMAGE_SAMPLE_C_CD_CL 0x6b
3689 #define SQ_IMAGE_SAMPLE_CD_O 0x6c
3690 #define SQ_IMAGE_SAMPLE_CD_CL_O 0x6d
3691 #define SQ_IMAGE_SAMPLE_C_CD_O 0x6e
3692 #define SQ_IMAGE_SAMPLE_C_CD_CL_O 0x6f
3693 #define SQ_IMAGE_RSRC256 0x7e
3694 #define SQ_IMAGE_SAMPLER 0x7f
3695 #define SQ_SRC_VCCZ 0xfb
3696 #define SQ_SRC_VGPR0 0x100
3697 #define SQ_SDWA_BYTE_0 0x0
3698 #define SQ_SDWA_BYTE_1 0x1
3699 #define SQ_SDWA_BYTE_2 0x2
3700 #define SQ_SDWA_BYTE_3 0x3
3701 #define SQ_SDWA_WORD_0 0x4
3702 #define SQ_SDWA_WORD_1 0x5
3703 #define SQ_SDWA_DWORD 0x6
3704 #define SQ_XNACK_MASK_LO 0x68
3705 #define SQ_XNACK_MASK_HI 0x69
3706 #define SQ_TBUFFER_LOAD_FORMAT_X 0x0
3707 #define SQ_TBUFFER_LOAD_FORMAT_XY 0x1
3708 #define SQ_TBUFFER_LOAD_FORMAT_XYZ 0x2
3709 #define SQ_TBUFFER_LOAD_FORMAT_XYZW 0x3
3710 #define SQ_TBUFFER_STORE_FORMAT_X 0x4
3711 #define SQ_TBUFFER_STORE_FORMAT_XY 0x5
3712 #define SQ_TBUFFER_STORE_FORMAT_XYZ 0x6
3713 #define SQ_TBUFFER_STORE_FORMAT_XYZW 0x7
3714 #define SQ_TBUFFER_LOAD_FORMAT_D16_X 0x8
3715 #define SQ_TBUFFER_LOAD_FORMAT_D16_XY 0x9
3716 #define SQ_TBUFFER_LOAD_FORMAT_D16_XYZ 0xa
3717 #define SQ_TBUFFER_LOAD_FORMAT_D16_XYZW 0xb
3718 #define SQ_TBUFFER_STORE_FORMAT_D16_X 0xc
3719 #define SQ_TBUFFER_STORE_FORMAT_D16_XY 0xd
3720 #define SQ_TBUFFER_STORE_FORMAT_D16_XYZ 0xe
3721 #define SQ_TBUFFER_STORE_FORMAT_D16_XYZW 0xf
3722 #define SQ_CHAN_X 0x0
3723 #define SQ_CHAN_Y 0x1
3724 #define SQ_CHAN_Z 0x2
3725 #define SQ_CHAN_W 0x3
3726 #define SQ_V_NOP 0x0
3727 #define SQ_V_MOV_B32 0x1
3728 #define SQ_V_READFIRSTLANE_B32 0x2
3729 #define SQ_V_CVT_I32_F64 0x3
3730 #define SQ_V_CVT_F64_I32 0x4
3731 #define SQ_V_CVT_F32_I32 0x5
3732 #define SQ_V_CVT_F32_U32 0x6
3733 #define SQ_V_CVT_U32_F32 0x7
3734 #define SQ_V_CVT_I32_F32 0x8
3735 #define SQ_V_MOV_FED_B32 0x9
3736 #define SQ_V_CVT_F16_F32 0xa
3737 #define SQ_V_CVT_F32_F16 0xb
3738 #define SQ_V_CVT_RPI_I32_F32 0xc
3739 #define SQ_V_CVT_FLR_I32_F32 0xd
3740 #define SQ_V_CVT_OFF_F32_I4 0xe
3741 #define SQ_V_CVT_F32_F64 0xf
3742 #define SQ_V_CVT_F64_F32 0x10
3743 #define SQ_V_CVT_F32_UBYTE0 0x11
3744 #define SQ_V_CVT_F32_UBYTE1 0x12
3745 #define SQ_V_CVT_F32_UBYTE2 0x13
3746 #define SQ_V_CVT_F32_UBYTE3 0x14
3747 #define SQ_V_CVT_U32_F64 0x15
3748 #define SQ_V_CVT_F64_U32 0x16
3749 #define SQ_V_TRUNC_F64 0x17
3750 #define SQ_V_CEIL_F64 0x18
3751 #define SQ_V_RNDNE_F64 0x19
3752 #define SQ_V_FLOOR_F64 0x1a
3753 #define SQ_V_FRACT_F32 0x1b
3754 #define SQ_V_TRUNC_F32 0x1c
3755 #define SQ_V_CEIL_F32 0x1d
3756 #define SQ_V_RNDNE_F32 0x1e
3757 #define SQ_V_FLOOR_F32 0x1f
3758 #define SQ_V_EXP_F32 0x20
3759 #define SQ_V_LOG_F32 0x21
3760 #define SQ_V_RCP_F32 0x22
3761 #define SQ_V_RCP_IFLAG_F32 0x23
3762 #define SQ_V_RSQ_F32 0x24
3763 #define SQ_V_RCP_F64 0x25
3764 #define SQ_V_RSQ_F64 0x26
3765 #define SQ_V_SQRT_F32 0x27
3766 #define SQ_V_SQRT_F64 0x28
3767 #define SQ_V_SIN_F32 0x29
3768 #define SQ_V_COS_F32 0x2a
3769 #define SQ_V_NOT_B32 0x2b
3770 #define SQ_V_BFREV_B32 0x2c
3771 #define SQ_V_FFBH_U32 0x2d
3772 #define SQ_V_FFBL_B32 0x2e
3773 #define SQ_V_FFBH_I32 0x2f
3774 #define SQ_V_FREXP_EXP_I32_F64 0x30
3775 #define SQ_V_FREXP_MANT_F64 0x31
3776 #define SQ_V_FRACT_F64 0x32
3777 #define SQ_V_FREXP_EXP_I32_F32 0x33
3778 #define SQ_V_FREXP_MANT_F32 0x34
3779 #define SQ_V_CLREXCP 0x35
3780 #define SQ_V_MOVRELD_B32 0x36
3781 #define SQ_V_MOVRELS_B32 0x37
3782 #define SQ_V_MOVRELSD_B32 0x38
3783 #define SQ_V_CVT_F16_U16 0x39
3784 #define SQ_V_CVT_F16_I16 0x3a
3785 #define SQ_V_CVT_U16_F16 0x3b
3786 #define SQ_V_CVT_I16_F16 0x3c
3787 #define SQ_V_RCP_F16 0x3d
3788 #define SQ_V_SQRT_F16 0x3e
3789 #define SQ_V_RSQ_F16 0x3f
3790 #define SQ_V_LOG_F16 0x40
3791 #define SQ_V_EXP_F16 0x41
3792 #define SQ_V_FREXP_MANT_F16 0x42
3793 #define SQ_V_FREXP_EXP_I16_F16 0x43
3794 #define SQ_V_FLOOR_F16 0x44
3795 #define SQ_V_CEIL_F16 0x45
3796 #define SQ_V_TRUNC_F16 0x46
3797 #define SQ_V_RNDNE_F16 0x47
3798 #define SQ_V_FRACT_F16 0x48
3799 #define SQ_V_SIN_F16 0x49
3800 #define SQ_V_COS_F16 0x4a
3801 #define SQ_V_EXP_LEGACY_F32 0x4b
3802 #define SQ_V_LOG_LEGACY_F32 0x4c
3803 #define SQ_SRC_SDWA 0xf9
3804 #define SQ_V_OPC_OFFSET 0x0
3805 #define SQ_V_OP2_OFFSET 0x100
3806 #define SQ_V_OP1_OFFSET 0x140
3807 #define SQ_V_INTRP_OFFSET 0x270
3808 #define SQ_V_INTERP_P1_F32 0x0
3809 #define SQ_V_INTERP_P2_F32 0x1
3810 #define SQ_V_INTERP_MOV_F32 0x2
3811 #define SQ_S_NOP 0x0
3812 #define SQ_S_ENDPGM 0x1
3813 #define SQ_S_BRANCH 0x2
3814 #define SQ_S_WAKEUP 0x3
3815 #define SQ_S_CBRANCH_SCC0 0x4
3816 #define SQ_S_CBRANCH_SCC1 0x5
3817 #define SQ_S_CBRANCH_VCCZ 0x6
3818 #define SQ_S_CBRANCH_VCCNZ 0x7
3819 #define SQ_S_CBRANCH_EXECZ 0x8
3820 #define SQ_S_CBRANCH_EXECNZ 0x9
3821 #define SQ_S_BARRIER 0xa
3822 #define SQ_S_SETKILL 0xb
3823 #define SQ_S_WAITCNT 0xc
3824 #define SQ_S_SETHALT 0xd
3825 #define SQ_S_SLEEP 0xe
3826 #define SQ_S_SETPRIO 0xf
3827 #define SQ_S_SENDMSG 0x10
3828 #define SQ_S_SENDMSGHALT 0x11
3829 #define SQ_S_TRAP 0x12
3830 #define SQ_S_ICACHE_INV 0x13
3831 #define SQ_S_INCPERFLEVEL 0x14
3832 #define SQ_S_DECPERFLEVEL 0x15
3833 #define SQ_S_TTRACEDATA 0x16
3834 #define SQ_S_CBRANCH_CDBGSYS 0x17
3835 #define SQ_S_CBRANCH_CDBGUSER 0x18
3836 #define SQ_S_CBRANCH_CDBGSYS_OR_USER 0x19
3837 #define SQ_S_CBRANCH_CDBGSYS_AND_USER 0x1a
3838 #define SQ_S_ENDPGM_SAVED 0x1b
3839 #define SQ_S_SET_GPR_IDX_OFF 0x1c
3840 #define SQ_S_SET_GPR_IDX_MODE 0x1d
3841 #define SQ_SRC_DPP 0xfa
3842 #define SQ_SRC_LITERAL 0xff
3843 #define SQ_VCC_LO 0x6a
3844 #define SQ_VCC_HI 0x6b
3845 #define SQ_PARAM_P10 0x0
3846 #define SQ_PARAM_P20 0x1
3847 #define SQ_PARAM_P0 0x2
3848 #define SQ_SRC_LDS_DIRECT 0xfe
3849 #define SQ_V_CNDMASK_B32 0x0
3850 #define SQ_V_ADD_F32 0x1
3851 #define SQ_V_SUB_F32 0x2
3852 #define SQ_V_SUBREV_F32 0x3
3853 #define SQ_V_MUL_LEGACY_F32 0x4
3854 #define SQ_V_MUL_F32 0x5
3855 #define SQ_V_MUL_I32_I24 0x6
3856 #define SQ_V_MUL_HI_I32_I24 0x7
3857 #define SQ_V_MUL_U32_U24 0x8
3858 #define SQ_V_MUL_HI_U32_U24 0x9
3859 #define SQ_V_MIN_F32 0xa
3860 #define SQ_V_MAX_F32 0xb
3861 #define SQ_V_MIN_I32 0xc
3862 #define SQ_V_MAX_I32 0xd
3863 #define SQ_V_MIN_U32 0xe
3864 #define SQ_V_MAX_U32 0xf
3865 #define SQ_V_LSHRREV_B32 0x10
3866 #define SQ_V_ASHRREV_I32 0x11
3867 #define SQ_V_LSHLREV_B32 0x12
3868 #define SQ_V_AND_B32 0x13
3869 #define SQ_V_OR_B32 0x14
3870 #define SQ_V_XOR_B32 0x15
3871 #define SQ_V_MAC_F32 0x16
3872 #define SQ_V_MADMK_F32 0x17
3873 #define SQ_V_MADAK_F32 0x18
3874 #define SQ_V_ADD_U32 0x19
3875 #define SQ_V_SUB_U32 0x1a
3876 #define SQ_V_SUBREV_U32 0x1b
3877 #define SQ_V_ADDC_U32 0x1c
3878 #define SQ_V_SUBB_U32 0x1d
3879 #define SQ_V_SUBBREV_U32 0x1e
3880 #define SQ_V_ADD_F16 0x1f
3881 #define SQ_V_SUB_F16 0x20
3882 #define SQ_V_SUBREV_F16 0x21
3883 #define SQ_V_MUL_F16 0x22
3884 #define SQ_V_MAC_F16 0x23
3885 #define SQ_V_MADMK_F16 0x24
3886 #define SQ_V_MADAK_F16 0x25
3887 #define SQ_V_ADD_U16 0x26
3888 #define SQ_V_SUB_U16 0x27
3889 #define SQ_V_SUBREV_U16 0x28
3890 #define SQ_V_MUL_LO_U16 0x29
3891 #define SQ_V_LSHLREV_B16 0x2a
3892 #define SQ_V_LSHRREV_B16 0x2b
3893 #define SQ_V_ASHRREV_I16 0x2c
3894 #define SQ_V_MAX_F16 0x2d
3895 #define SQ_V_MIN_F16 0x2e
3896 #define SQ_V_MAX_U16 0x2f
3897 #define SQ_V_MAX_I16 0x30
3898 #define SQ_V_MIN_U16 0x31
3899 #define SQ_V_MIN_I16 0x32
3900 #define SQ_V_LDEXP_F16 0x33
3901 #define SQ_FLAT_LOAD_UBYTE 0x10
3902 #define SQ_FLAT_LOAD_SBYTE 0x11
3903 #define SQ_FLAT_LOAD_USHORT 0x12
3904 #define SQ_FLAT_LOAD_SSHORT 0x13
3905 #define SQ_FLAT_LOAD_DWORD 0x14
3906 #define SQ_FLAT_LOAD_DWORDX2 0x15
3907 #define SQ_FLAT_LOAD_DWORDX3 0x16
3908 #define SQ_FLAT_LOAD_DWORDX4 0x17
3909 #define SQ_FLAT_STORE_BYTE 0x18
3910 #define SQ_FLAT_STORE_SHORT 0x1a
3911 #define SQ_FLAT_STORE_DWORD 0x1c
3912 #define SQ_FLAT_STORE_DWORDX2 0x1d
3913 #define SQ_FLAT_STORE_DWORDX3 0x1e
3914 #define SQ_FLAT_STORE_DWORDX4 0x1f
3915 #define SQ_FLAT_ATOMIC_SWAP 0x40
3916 #define SQ_FLAT_ATOMIC_CMPSWAP 0x41
3917 #define SQ_FLAT_ATOMIC_ADD 0x42
3918 #define SQ_FLAT_ATOMIC_SUB 0x43
3919 #define SQ_FLAT_ATOMIC_SMIN 0x44
3920 #define SQ_FLAT_ATOMIC_UMIN 0x45
3921 #define SQ_FLAT_ATOMIC_SMAX 0x46
3922 #define SQ_FLAT_ATOMIC_UMAX 0x47
3923 #define SQ_FLAT_ATOMIC_AND 0x48
3924 #define SQ_FLAT_ATOMIC_OR 0x49
3925 #define SQ_FLAT_ATOMIC_XOR 0x4a
3926 #define SQ_FLAT_ATOMIC_INC 0x4b
3927 #define SQ_FLAT_ATOMIC_DEC 0x4c
3928 #define SQ_FLAT_ATOMIC_SWAP_X2 0x60
3929 #define SQ_FLAT_ATOMIC_CMPSWAP_X2 0x61
3930 #define SQ_FLAT_ATOMIC_ADD_X2 0x62
3931 #define SQ_FLAT_ATOMIC_SUB_X2 0x63
3932 #define SQ_FLAT_ATOMIC_SMIN_X2 0x64
3933 #define SQ_FLAT_ATOMIC_UMIN_X2 0x65
3934 #define SQ_FLAT_ATOMIC_SMAX_X2 0x66
3935 #define SQ_FLAT_ATOMIC_UMAX_X2 0x67
3936 #define SQ_FLAT_ATOMIC_AND_X2 0x68
3937 #define SQ_FLAT_ATOMIC_OR_X2 0x69
3938 #define SQ_FLAT_ATOMIC_XOR_X2 0x6a
3939 #define SQ_FLAT_ATOMIC_INC_X2 0x6b
3940 #define SQ_FLAT_ATOMIC_DEC_X2 0x6c
3941 #define SQ_S_CMP_EQ_I32 0x0
3942 #define SQ_S_CMP_LG_I32 0x1
3943 #define SQ_S_CMP_GT_I32 0x2
3944 #define SQ_S_CMP_GE_I32 0x3
3945 #define SQ_S_CMP_LT_I32 0x4
3946 #define SQ_S_CMP_LE_I32 0x5
3947 #define SQ_S_CMP_EQ_U32 0x6
3948 #define SQ_S_CMP_LG_U32 0x7
3949 #define SQ_S_CMP_GT_U32 0x8
3950 #define SQ_S_CMP_GE_U32 0x9
3951 #define SQ_S_CMP_LT_U32 0xa
3952 #define SQ_S_CMP_LE_U32 0xb
3953 #define SQ_S_BITCMP0_B32 0xc
3954 #define SQ_S_BITCMP1_B32 0xd
3955 #define SQ_S_BITCMP0_B64 0xe
3956 #define SQ_S_BITCMP1_B64 0xf
3957 #define SQ_S_SETVSKIP 0x10
3958 #define SQ_S_SET_GPR_IDX_ON 0x11
3959 #define SQ_S_CMP_EQ_U64 0x12
3960 #define SQ_S_CMP_LG_U64 0x13
3961 #define SQ_M0 0x7c
3962 #define SQ_V_MAD_LEGACY_F32 0x1c0
3963 #define SQ_V_MAD_F32 0x1c1
3964 #define SQ_V_MAD_I32_I24 0x1c2
3965 #define SQ_V_MAD_U32_U24 0x1c3
3966 #define SQ_V_CUBEID_F32 0x1c4
3967 #define SQ_V_CUBESC_F32 0x1c5
3968 #define SQ_V_CUBETC_F32 0x1c6
3969 #define SQ_V_CUBEMA_F32 0x1c7
3970 #define SQ_V_BFE_U32 0x1c8
3971 #define SQ_V_BFE_I32 0x1c9
3972 #define SQ_V_BFI_B32 0x1ca
3973 #define SQ_V_FMA_F32 0x1cb
3974 #define SQ_V_FMA_F64 0x1cc
3975 #define SQ_V_LERP_U8 0x1cd
3976 #define SQ_V_ALIGNBIT_B32 0x1ce
3977 #define SQ_V_ALIGNBYTE_B32 0x1cf
3978 #define SQ_V_MIN3_F32 0x1d0
3979 #define SQ_V_MIN3_I32 0x1d1
3980 #define SQ_V_MIN3_U32 0x1d2
3981 #define SQ_V_MAX3_F32 0x1d3
3982 #define SQ_V_MAX3_I32 0x1d4
3983 #define SQ_V_MAX3_U32 0x1d5
3984 #define SQ_V_MED3_F32 0x1d6
3985 #define SQ_V_MED3_I32 0x1d7
3986 #define SQ_V_MED3_U32 0x1d8
3987 #define SQ_V_SAD_U8 0x1d9
3988 #define SQ_V_SAD_HI_U8 0x1da
3989 #define SQ_V_SAD_U16 0x1db
3990 #define SQ_V_SAD_U32 0x1dc
3991 #define SQ_V_CVT_PK_U8_F32 0x1dd
3992 #define SQ_V_DIV_FIXUP_F32 0x1de
3993 #define SQ_V_DIV_FIXUP_F64 0x1df
3994 #define SQ_V_DIV_SCALE_F32 0x1e0
3995 #define SQ_V_DIV_SCALE_F64 0x1e1
3996 #define SQ_V_DIV_FMAS_F32 0x1e2
3997 #define SQ_V_DIV_FMAS_F64 0x1e3
3998 #define SQ_V_MSAD_U8 0x1e4
3999 #define SQ_V_QSAD_PK_U16_U8 0x1e5
4000 #define SQ_V_MQSAD_PK_U16_U8 0x1e6
4001 #define SQ_V_MQSAD_U32_U8 0x1e7
4002 #define SQ_V_MAD_U64_U32 0x1e8
4003 #define SQ_V_MAD_I64_I32 0x1e9
4004 #define SQ_V_MAD_F16 0x1ea
4005 #define SQ_V_MAD_U16 0x1eb
4006 #define SQ_V_MAD_I16 0x1ec
4007 #define SQ_V_PERM_B32 0x1ed
4008 #define SQ_V_FMA_F16 0x1ee
4009 #define SQ_V_DIV_FIXUP_F16 0x1ef
4010 #define SQ_V_CVT_PKACCUM_U8_F32 0x1f0
4011 #define SQ_V_INTERP_P1LL_F16 0x274
4012 #define SQ_V_INTERP_P1LV_F16 0x275
4013 #define SQ_V_INTERP_P2_F16 0x276
4014 #define SQ_V_ADD_F64 0x280
4015 #define SQ_V_MUL_F64 0x281
4016 #define SQ_V_MIN_F64 0x282
4017 #define SQ_V_MAX_F64 0x283
4018 #define SQ_V_LDEXP_F64 0x284
4019 #define SQ_V_MUL_LO_U32 0x285
4020 #define SQ_V_MUL_HI_U32 0x286
4021 #define SQ_V_MUL_HI_I32 0x287
4022 #define SQ_V_LDEXP_F32 0x288
4023 #define SQ_V_READLANE_B32 0x289
4024 #define SQ_V_WRITELANE_B32 0x28a
4025 #define SQ_V_BCNT_U32_B32 0x28b
4026 #define SQ_V_MBCNT_LO_U32_B32 0x28c
4027 #define SQ_V_MBCNT_HI_U32_B32 0x28d
4028 #define SQ_V_MAC_LEGACY_F32 0x28e
4029 #define SQ_V_LSHLREV_B64 0x28f
4030 #define SQ_V_LSHRREV_B64 0x290
4031 #define SQ_V_ASHRREV_I64 0x291
4032 #define SQ_V_TRIG_PREOP_F64 0x292
4033 #define SQ_V_BFM_B32 0x293
4034 #define SQ_V_CVT_PKNORM_I16_F32 0x294
4035 #define SQ_V_CVT_PKNORM_U16_F32 0x295
4036 #define SQ_V_CVT_PKRTZ_F16_F32 0x296
4037 #define SQ_V_CVT_PK_U16_U32 0x297
4038 #define SQ_V_CVT_PK_I16_I32 0x298
4039 #define SQ_VCC_ALL 0x0
4040 #define SQ_SRC_EXECZ 0xfc
4041 #define SQ_FLAT_SCRATCH_LO 0x66
4042 #define SQ_FLAT_SCRATCH_HI 0x67
4043 #define SQ_SYSMSG_OP_ECC_ERR_INTERRUPT 0x1
4044 #define SQ_SYSMSG_OP_REG_RD 0x2
4045 #define SQ_SYSMSG_OP_HOST_TRAP_ACK 0x3
4046 #define SQ_SYSMSG_OP_TTRACE_PC 0x4
4047 #define SQ_HW_REG_MODE 0x1
4048 #define SQ_HW_REG_STATUS 0x2
4049 #define SQ_HW_REG_TRAPSTS 0x3
4050 #define SQ_HW_REG_HW_ID 0x4
4051 #define SQ_HW_REG_GPR_ALLOC 0x5
4052 #define SQ_HW_REG_LDS_ALLOC 0x6
4053 #define SQ_HW_REG_IB_STS 0x7
4054 #define SQ_HW_REG_PC_LO 0x8
4055 #define SQ_HW_REG_PC_HI 0x9
4056 #define SQ_HW_REG_INST_DW0 0xa
4057 #define SQ_HW_REG_INST_DW1 0xb
4058 #define SQ_HW_REG_IB_DBG0 0xc
4059 #define SQ_HW_REG_IB_DBG1 0xd
4060 #define SQ_DPP_BOUND_OFF 0x0
4061 #define SQ_DPP_BOUND_ZERO 0x1
4062 #define SQ_R1 0x1
4063 #define SQ_R2 0x2
4064 #define SQ_R3 0x3
4065 #define SQ_R4 0x4
4066 #define SQ_R5 0x5
4067 #define SQ_R6 0x6
4068 #define SQ_R7 0x7
4069 #define SQ_R8 0x8
4070 #define SQ_R9 0x9
4071 #define SQ_R10 0xa
4072 #define SQ_R11 0xb
4073 #define SQ_R12 0xc
4074 #define SQ_R13 0xd
4075 #define SQ_R14 0xe
4076 #define SQ_R15 0xf
4077 #define SQ_S_ADD_U32 0x0
4078 #define SQ_S_SUB_U32 0x1
4079 #define SQ_S_ADD_I32 0x2
4080 #define SQ_S_SUB_I32 0x3
4081 #define SQ_S_ADDC_U32 0x4
4082 #define SQ_S_SUBB_U32 0x5
4083 #define SQ_S_MIN_I32 0x6
4084 #define SQ_S_MIN_U32 0x7
4085 #define SQ_S_MAX_I32 0x8
4086 #define SQ_S_MAX_U32 0x9
4087 #define SQ_S_CSELECT_B32 0xa
4088 #define SQ_S_CSELECT_B64 0xb
4089 #define SQ_S_AND_B32 0xc
4090 #define SQ_S_AND_B64 0xd
4091 #define SQ_S_OR_B32 0xe
4092 #define SQ_S_OR_B64 0xf
4093 #define SQ_S_XOR_B32 0x10
4094 #define SQ_S_XOR_B64 0x11
4095 #define SQ_S_ANDN2_B32 0x12
4096 #define SQ_S_ANDN2_B64 0x13
4097 #define SQ_S_ORN2_B32 0x14
4098 #define SQ_S_ORN2_B64 0x15
4099 #define SQ_S_NAND_B32 0x16
4100 #define SQ_S_NAND_B64 0x17
4101 #define SQ_S_NOR_B32 0x18
4102 #define SQ_S_NOR_B64 0x19
4103 #define SQ_S_XNOR_B32 0x1a
4104 #define SQ_S_XNOR_B64 0x1b
4105 #define SQ_S_LSHL_B32 0x1c
4106 #define SQ_S_LSHL_B64 0x1d
4107 #define SQ_S_LSHR_B32 0x1e
4108 #define SQ_S_LSHR_B64 0x1f
4109 #define SQ_S_ASHR_I32 0x20
4110 #define SQ_S_ASHR_I64 0x21
4111 #define SQ_S_BFM_B32 0x22
4112 #define SQ_S_BFM_B64 0x23
4113 #define SQ_S_MUL_I32 0x24
4114 #define SQ_S_BFE_U32 0x25
4115 #define SQ_S_BFE_I32 0x26
4116 #define SQ_S_BFE_U64 0x27
4117 #define SQ_S_BFE_I64 0x28
4118 #define SQ_S_CBRANCH_G_FORK 0x29
4119 #define SQ_S_ABSDIFF_I32 0x2a
4120 #define SQ_S_RFE_RESTORE_B64 0x2b
4121 #define SQ_MSG_INTERRUPT 0x1
4122 #define SQ_MSG_GS 0x2
4123 #define SQ_MSG_GS_DONE 0x3
4124 #define SQ_MSG_SAVEWAVE 0x4
4125 #define SQ_MSG_SYSMSG 0xf
4126 typedef enum TEX_BORDER_COLOR_TYPE {
4127 TEX_BorderColor_TransparentBlack = 0x0,
4128 TEX_BorderColor_OpaqueBlack = 0x1,
4129 TEX_BorderColor_OpaqueWhite = 0x2,
4130 TEX_BorderColor_Register = 0x3,
4131 } TEX_BORDER_COLOR_TYPE;
4132 typedef enum TEX_CHROMA_KEY {
4133 TEX_ChromaKey_Disabled = 0x0,
4134 TEX_ChromaKey_Kill = 0x1,
4135 TEX_ChromaKey_Blend = 0x2,
4136 TEX_ChromaKey_RESERVED_3 = 0x3,
4137 } TEX_CHROMA_KEY;
4138 typedef enum TEX_CLAMP {
4139 TEX_Clamp_Repeat = 0x0,
4140 TEX_Clamp_Mirror = 0x1,
4141 TEX_Clamp_ClampToLast = 0x2,
4142 TEX_Clamp_MirrorOnceToLast = 0x3,
4143 TEX_Clamp_ClampHalfToBorder = 0x4,
4144 TEX_Clamp_MirrorOnceHalfToBorder = 0x5,
4145 TEX_Clamp_ClampToBorder = 0x6,
4146 TEX_Clamp_MirrorOnceToBorder = 0x7,
4147 } TEX_CLAMP;
4148 typedef enum TEX_COORD_TYPE {
4149 TEX_CoordType_Unnormalized = 0x0,
4150 TEX_CoordType_Normalized = 0x1,
4151 } TEX_COORD_TYPE;
4152 typedef enum TEX_DEPTH_COMPARE_FUNCTION {
4153 TEX_DepthCompareFunction_Never = 0x0,
4154 TEX_DepthCompareFunction_Less = 0x1,
4155 TEX_DepthCompareFunction_Equal = 0x2,
4156 TEX_DepthCompareFunction_LessEqual = 0x3,
4157 TEX_DepthCompareFunction_Greater = 0x4,
4158 TEX_DepthCompareFunction_NotEqual = 0x5,
4159 TEX_DepthCompareFunction_GreaterEqual = 0x6,
4160 TEX_DepthCompareFunction_Always = 0x7,
4161 } TEX_DEPTH_COMPARE_FUNCTION;
4162 typedef enum TEX_DIM {
4163 TEX_Dim_1D = 0x0,
4164 TEX_Dim_2D = 0x1,
4165 TEX_Dim_3D = 0x2,
4166 TEX_Dim_CubeMap = 0x3,
4167 TEX_Dim_1DArray = 0x4,
4168 TEX_Dim_2DArray = 0x5,
4169 TEX_Dim_2D_MSAA = 0x6,
4170 TEX_Dim_2DArray_MSAA = 0x7,
4171 } TEX_DIM;
4172 typedef enum TEX_FORMAT_COMP {
4173 TEX_FormatComp_Unsigned = 0x0,
4174 TEX_FormatComp_Signed = 0x1,
4175 TEX_FormatComp_UnsignedBiased = 0x2,
4176 TEX_FormatComp_RESERVED_3 = 0x3,
4177 } TEX_FORMAT_COMP;
4178 typedef enum TEX_MAX_ANISO_RATIO {
4179 TEX_MaxAnisoRatio_1to1 = 0x0,
4180 TEX_MaxAnisoRatio_2to1 = 0x1,
4181 TEX_MaxAnisoRatio_4to1 = 0x2,
4182 TEX_MaxAnisoRatio_8to1 = 0x3,
4183 TEX_MaxAnisoRatio_16to1 = 0x4,
4184 TEX_MaxAnisoRatio_RESERVED_5 = 0x5,
4185 TEX_MaxAnisoRatio_RESERVED_6 = 0x6,
4186 TEX_MaxAnisoRatio_RESERVED_7 = 0x7,
4187 } TEX_MAX_ANISO_RATIO;
4188 typedef enum TEX_MIP_FILTER {
4189 TEX_MipFilter_None = 0x0,
4190 TEX_MipFilter_Point = 0x1,
4191 TEX_MipFilter_Linear = 0x2,
4192 TEX_MipFilter_Point_Aniso_Adj = 0x3,
4193 } TEX_MIP_FILTER;
4194 typedef enum TEX_REQUEST_SIZE {
4195 TEX_RequestSize_32B = 0x0,
4196 TEX_RequestSize_64B = 0x1,
4197 TEX_RequestSize_128B = 0x2,
4198 TEX_RequestSize_2X64B = 0x3,
4199 } TEX_REQUEST_SIZE;
4200 typedef enum TEX_SAMPLER_TYPE {
4201 TEX_SamplerType_Invalid = 0x0,
4202 TEX_SamplerType_Valid = 0x1,
4203 } TEX_SAMPLER_TYPE;
4204 typedef enum TEX_XY_FILTER {
4205 TEX_XYFilter_Point = 0x0,
4206 TEX_XYFilter_Linear = 0x1,
4207 TEX_XYFilter_AnisoPoint = 0x2,
4208 TEX_XYFilter_AnisoLinear = 0x3,
4209 } TEX_XY_FILTER;
4210 typedef enum TEX_Z_FILTER {
4211 TEX_ZFilter_None = 0x0,
4212 TEX_ZFilter_Point = 0x1,
4213 TEX_ZFilter_Linear = 0x2,
4214 TEX_ZFilter_RESERVED_3 = 0x3,
4215 } TEX_Z_FILTER;
4216 typedef enum VTX_CLAMP {
4217 VTX_Clamp_ClampToZero = 0x0,
4218 VTX_Clamp_ClampToNAN = 0x1,
4219 } VTX_CLAMP;
4220 typedef enum VTX_FETCH_TYPE {
4221 VTX_FetchType_VertexData = 0x0,
4222 VTX_FetchType_InstanceData = 0x1,
4223 VTX_FetchType_NoIndexOffset = 0x2,
4224 VTX_FetchType_RESERVED_3 = 0x3,
4225 } VTX_FETCH_TYPE;
4226 typedef enum VTX_FORMAT_COMP_ALL {
4227 VTX_FormatCompAll_Unsigned = 0x0,
4228 VTX_FormatCompAll_Signed = 0x1,
4229 } VTX_FORMAT_COMP_ALL;
4230 typedef enum VTX_MEM_REQUEST_SIZE {
4231 VTX_MemRequestSize_32B = 0x0,
4232 VTX_MemRequestSize_64B = 0x1,
4233 } VTX_MEM_REQUEST_SIZE;
4234 typedef enum TVX_DATA_FORMAT {
4235 TVX_FMT_INVALID = 0x0,
4236 TVX_FMT_8 = 0x1,
4237 TVX_FMT_4_4 = 0x2,
4238 TVX_FMT_3_3_2 = 0x3,
4239 TVX_FMT_RESERVED_4 = 0x4,
4240 TVX_FMT_16 = 0x5,
4241 TVX_FMT_16_FLOAT = 0x6,
4242 TVX_FMT_8_8 = 0x7,
4243 TVX_FMT_5_6_5 = 0x8,
4244 TVX_FMT_6_5_5 = 0x9,
4245 TVX_FMT_1_5_5_5 = 0xa,
4246 TVX_FMT_4_4_4_4 = 0xb,
4247 TVX_FMT_5_5_5_1 = 0xc,
4248 TVX_FMT_32 = 0xd,
4249 TVX_FMT_32_FLOAT = 0xe,
4250 TVX_FMT_16_16 = 0xf,
4251 TVX_FMT_16_16_FLOAT = 0x10,
4252 TVX_FMT_8_24 = 0x11,
4253 TVX_FMT_8_24_FLOAT = 0x12,
4254 TVX_FMT_24_8 = 0x13,
4255 TVX_FMT_24_8_FLOAT = 0x14,
4256 TVX_FMT_10_11_11 = 0x15,
4257 TVX_FMT_10_11_11_FLOAT = 0x16,
4258 TVX_FMT_11_11_10 = 0x17,
4259 TVX_FMT_11_11_10_FLOAT = 0x18,
4260 TVX_FMT_2_10_10_10 = 0x19,
4261 TVX_FMT_8_8_8_8 = 0x1a,
4262 TVX_FMT_10_10_10_2 = 0x1b,
4263 TVX_FMT_X24_8_32_FLOAT = 0x1c,
4264 TVX_FMT_32_32 = 0x1d,
4265 TVX_FMT_32_32_FLOAT = 0x1e,
4266 TVX_FMT_16_16_16_16 = 0x1f,
4267 TVX_FMT_16_16_16_16_FLOAT = 0x20,
4268 TVX_FMT_RESERVED_33 = 0x21,
4269 TVX_FMT_32_32_32_32 = 0x22,
4270 TVX_FMT_32_32_32_32_FLOAT = 0x23,
4271 TVX_FMT_RESERVED_36 = 0x24,
4272 TVX_FMT_1 = 0x25,
4273 TVX_FMT_1_REVERSED = 0x26,
4274 TVX_FMT_GB_GR = 0x27,
4275 TVX_FMT_BG_RG = 0x28,
4276 TVX_FMT_32_AS_8 = 0x29,
4277 TVX_FMT_32_AS_8_8 = 0x2a,
4278 TVX_FMT_5_9_9_9_SHAREDEXP = 0x2b,
4279 TVX_FMT_8_8_8 = 0x2c,
4280 TVX_FMT_16_16_16 = 0x2d,
4281 TVX_FMT_16_16_16_FLOAT = 0x2e,
4282 TVX_FMT_32_32_32 = 0x2f,
4283 TVX_FMT_32_32_32_FLOAT = 0x30,
4284 TVX_FMT_BC1 = 0x31,
4285 TVX_FMT_BC2 = 0x32,
4286 TVX_FMT_BC3 = 0x33,
4287 TVX_FMT_BC4 = 0x34,
4288 TVX_FMT_BC5 = 0x35,
4289 TVX_FMT_APC0 = 0x36,
4290 TVX_FMT_APC1 = 0x37,
4291 TVX_FMT_APC2 = 0x38,
4292 TVX_FMT_APC3 = 0x39,
4293 TVX_FMT_APC4 = 0x3a,
4294 TVX_FMT_APC5 = 0x3b,
4295 TVX_FMT_APC6 = 0x3c,
4296 TVX_FMT_APC7 = 0x3d,
4297 TVX_FMT_CTX1 = 0x3e,
4298 TVX_FMT_RESERVED_63 = 0x3f,
4299 } TVX_DATA_FORMAT;
4300 typedef enum TVX_DST_SEL {
4301 TVX_DstSel_X = 0x0,
4302 TVX_DstSel_Y = 0x1,
4303 TVX_DstSel_Z = 0x2,
4304 TVX_DstSel_W = 0x3,
4305 TVX_DstSel_0f = 0x4,
4306 TVX_DstSel_1f = 0x5,
4307 TVX_DstSel_RESERVED_6 = 0x6,
4308 TVX_DstSel_Mask = 0x7,
4309 } TVX_DST_SEL;
4310 typedef enum TVX_ENDIAN_SWAP {
4311 TVX_EndianSwap_None = 0x0,
4312 TVX_EndianSwap_8in16 = 0x1,
4313 TVX_EndianSwap_8in32 = 0x2,
4314 TVX_EndianSwap_8in64 = 0x3,
4315 } TVX_ENDIAN_SWAP;
4316 typedef enum TVX_INST {
4317 TVX_Inst_NormalVertexFetch = 0x0,
4318 TVX_Inst_SemanticVertexFetch = 0x1,
4319 TVX_Inst_RESERVED_2 = 0x2,
4320 TVX_Inst_LD = 0x3,
4321 TVX_Inst_GetTextureResInfo = 0x4,
4322 TVX_Inst_GetNumberOfSamples = 0x5,
4323 TVX_Inst_GetLOD = 0x6,
4324 TVX_Inst_GetGradientsH = 0x7,
4325 TVX_Inst_GetGradientsV = 0x8,
4326 TVX_Inst_SetTextureOffsets = 0x9,
4327 TVX_Inst_KeepGradients = 0xa,
4328 TVX_Inst_SetGradientsH = 0xb,
4329 TVX_Inst_SetGradientsV = 0xc,
4330 TVX_Inst_Pass = 0xd,
4331 TVX_Inst_GetBufferResInfo = 0xe,
4332 TVX_Inst_RESERVED_15 = 0xf,
4333 TVX_Inst_Sample = 0x10,
4334 TVX_Inst_Sample_L = 0x11,
4335 TVX_Inst_Sample_LB = 0x12,
4336 TVX_Inst_Sample_LZ = 0x13,
4337 TVX_Inst_Sample_G = 0x14,
4338 TVX_Inst_Gather4 = 0x15,
4339 TVX_Inst_Sample_G_LB = 0x16,
4340 TVX_Inst_Gather4_O = 0x17,
4341 TVX_Inst_Sample_C = 0x18,
4342 TVX_Inst_Sample_C_L = 0x19,
4343 TVX_Inst_Sample_C_LB = 0x1a,
4344 TVX_Inst_Sample_C_LZ = 0x1b,
4345 TVX_Inst_Sample_C_G = 0x1c,
4346 TVX_Inst_Gather4_C = 0x1d,
4347 TVX_Inst_Sample_C_G_LB = 0x1e,
4348 TVX_Inst_Gather4_C_O = 0x1f,
4349 } TVX_INST;
4350 typedef enum TVX_NUM_FORMAT_ALL {
4351 TVX_NumFormatAll_Norm = 0x0,
4352 TVX_NumFormatAll_Int = 0x1,
4353 TVX_NumFormatAll_Scaled = 0x2,
4354 TVX_NumFormatAll_RESERVED_3 = 0x3,
4355 } TVX_NUM_FORMAT_ALL;
4356 typedef enum TVX_SRC_SEL {
4357 TVX_SrcSel_X = 0x0,
4358 TVX_SrcSel_Y = 0x1,
4359 TVX_SrcSel_Z = 0x2,
4360 TVX_SrcSel_W = 0x3,
4361 TVX_SrcSel_0f = 0x4,
4362 TVX_SrcSel_1f = 0x5,
4363 } TVX_SRC_SEL;
4364 typedef enum TVX_SRF_MODE_ALL {
4365 TVX_SRFModeAll_ZCMO = 0x0,
4366 TVX_SRFModeAll_NZ = 0x1,
4367 } TVX_SRF_MODE_ALL;
4368 typedef enum TVX_TYPE {
4369 TVX_Type_InvalidTextureResource = 0x0,
4370 TVX_Type_InvalidVertexBuffer = 0x1,
4371 TVX_Type_ValidTextureResource = 0x2,
4372 TVX_Type_ValidVertexBuffer = 0x3,
4373 } TVX_TYPE;
4374 typedef enum TC_OP_MASKS {
4375 TC_OP_MASK_FLUSH_DENROM = 0x8,
4376 TC_OP_MASK_64 = 0x20,
4377 TC_OP_MASK_NO_RTN = 0x40,
4378 } TC_OP_MASKS;
4379 typedef enum TC_OP {
4380 TC_OP_READ = 0x0,
4381 TC_OP_ATOMIC_FCMPSWAP_RTN_32 = 0x1,
4382 TC_OP_ATOMIC_FMIN_RTN_32 = 0x2,
4383 TC_OP_ATOMIC_FMAX_RTN_32 = 0x3,
4384 TC_OP_RESERVED_FOP_RTN_32_0 = 0x4,
4385 TC_OP_RESERVED_FOP_RTN_32_1 = 0x5,
4386 TC_OP_RESERVED_FOP_RTN_32_2 = 0x6,
4387 TC_OP_ATOMIC_SWAP_RTN_32 = 0x7,
4388 TC_OP_ATOMIC_CMPSWAP_RTN_32 = 0x8,
4389 TC_OP_ATOMIC_FCMPSWAP_FLUSH_DENORM_RTN_32 = 0x9,
4390 TC_OP_ATOMIC_FMIN_FLUSH_DENORM_RTN_32 = 0xa,
4391 TC_OP_ATOMIC_FMAX_FLUSH_DENORM_RTN_32 = 0xb,
4392 TC_OP_RESERVED_FOP_FLUSH_DENORM_RTN_32_0 = 0xc,
4393 TC_OP_RESERVED_FOP_FLUSH_DENORM_RTN_32_1 = 0xd,
4394 TC_OP_RESERVED_FOP_FLUSH_DENORM_RTN_32_2 = 0xe,
4395 TC_OP_ATOMIC_ADD_RTN_32 = 0xf,
4396 TC_OP_ATOMIC_SUB_RTN_32 = 0x10,
4397 TC_OP_ATOMIC_SMIN_RTN_32 = 0x11,
4398 TC_OP_ATOMIC_UMIN_RTN_32 = 0x12,
4399 TC_OP_ATOMIC_SMAX_RTN_32 = 0x13,
4400 TC_OP_ATOMIC_UMAX_RTN_32 = 0x14,
4401 TC_OP_ATOMIC_AND_RTN_32 = 0x15,
4402 TC_OP_ATOMIC_OR_RTN_32 = 0x16,
4403 TC_OP_ATOMIC_XOR_RTN_32 = 0x17,
4404 TC_OP_ATOMIC_INC_RTN_32 = 0x18,
4405 TC_OP_ATOMIC_DEC_RTN_32 = 0x19,
4406 TC_OP_WBINVL1_VOL = 0x1a,
4407 TC_OP_WBINVL1_SD = 0x1b,
4408 TC_OP_RESERVED_NON_FLOAT_RTN_32_0 = 0x1c,
4409 TC_OP_RESERVED_NON_FLOAT_RTN_32_1 = 0x1d,
4410 TC_OP_RESERVED_NON_FLOAT_RTN_32_2 = 0x1e,
4411 TC_OP_RESERVED_NON_FLOAT_RTN_32_3 = 0x1f,
4412 TC_OP_WRITE = 0x20,
4413 TC_OP_ATOMIC_FCMPSWAP_RTN_64 = 0x21,
4414 TC_OP_ATOMIC_FMIN_RTN_64 = 0x22,
4415 TC_OP_ATOMIC_FMAX_RTN_64 = 0x23,
4416 TC_OP_RESERVED_FOP_RTN_64_0 = 0x24,
4417 TC_OP_RESERVED_FOP_RTN_64_1 = 0x25,
4418 TC_OP_RESERVED_FOP_RTN_64_2 = 0x26,
4419 TC_OP_ATOMIC_SWAP_RTN_64 = 0x27,
4420 TC_OP_ATOMIC_CMPSWAP_RTN_64 = 0x28,
4421 TC_OP_ATOMIC_FCMPSWAP_FLUSH_DENORM_RTN_64 = 0x29,
4422 TC_OP_ATOMIC_FMIN_FLUSH_DENORM_RTN_64 = 0x2a,
4423 TC_OP_ATOMIC_FMAX_FLUSH_DENORM_RTN_64 = 0x2b,
4424 TC_OP_WBINVL2_SD = 0x2c,
4425 TC_OP_RESERVED_FOP_FLUSH_DENORM_RTN_64_0 = 0x2d,
4426 TC_OP_RESERVED_FOP_FLUSH_DENORM_RTN_64_1 = 0x2e,
4427 TC_OP_ATOMIC_ADD_RTN_64 = 0x2f,
4428 TC_OP_ATOMIC_SUB_RTN_64 = 0x30,
4429 TC_OP_ATOMIC_SMIN_RTN_64 = 0x31,
4430 TC_OP_ATOMIC_UMIN_RTN_64 = 0x32,
4431 TC_OP_ATOMIC_SMAX_RTN_64 = 0x33,
4432 TC_OP_ATOMIC_UMAX_RTN_64 = 0x34,
4433 TC_OP_ATOMIC_AND_RTN_64 = 0x35,
4434 TC_OP_ATOMIC_OR_RTN_64 = 0x36,
4435 TC_OP_ATOMIC_XOR_RTN_64 = 0x37,
4436 TC_OP_ATOMIC_INC_RTN_64 = 0x38,
4437 TC_OP_ATOMIC_DEC_RTN_64 = 0x39,
4438 TC_OP_WBL2_NC = 0x3a,
4439 TC_OP_RESERVED_NON_FLOAT_RTN_64_0 = 0x3b,
4440 TC_OP_RESERVED_NON_FLOAT_RTN_64_1 = 0x3c,
4441 TC_OP_RESERVED_NON_FLOAT_RTN_64_2 = 0x3d,
4442 TC_OP_RESERVED_NON_FLOAT_RTN_64_3 = 0x3e,
4443 TC_OP_RESERVED_NON_FLOAT_RTN_64_4 = 0x3f,
4444 TC_OP_WBINVL1 = 0x40,
4445 TC_OP_ATOMIC_FCMPSWAP_32 = 0x41,
4446 TC_OP_ATOMIC_FMIN_32 = 0x42,
4447 TC_OP_ATOMIC_FMAX_32 = 0x43,
4448 TC_OP_RESERVED_FOP_32_0 = 0x44,
4449 TC_OP_RESERVED_FOP_32_1 = 0x45,
4450 TC_OP_RESERVED_FOP_32_2 = 0x46,
4451 TC_OP_ATOMIC_SWAP_32 = 0x47,
4452 TC_OP_ATOMIC_CMPSWAP_32 = 0x48,
4453 TC_OP_ATOMIC_FCMPSWAP_FLUSH_DENORM_32 = 0x49,
4454 TC_OP_ATOMIC_FMIN_FLUSH_DENORM_32 = 0x4a,
4455 TC_OP_ATOMIC_FMAX_FLUSH_DENORM_32 = 0x4b,
4456 TC_OP_RESERVED_FOP_FLUSH_DENORM_32_0 = 0x4c,
4457 TC_OP_RESERVED_FOP_FLUSH_DENORM_32_1 = 0x4d,
4458 TC_OP_RESERVED_FOP_FLUSH_DENORM_32_2 = 0x4e,
4459 TC_OP_ATOMIC_ADD_32 = 0x4f,
4460 TC_OP_ATOMIC_SUB_32 = 0x50,
4461 TC_OP_ATOMIC_SMIN_32 = 0x51,
4462 TC_OP_ATOMIC_UMIN_32 = 0x52,
4463 TC_OP_ATOMIC_SMAX_32 = 0x53,
4464 TC_OP_ATOMIC_UMAX_32 = 0x54,
4465 TC_OP_ATOMIC_AND_32 = 0x55,
4466 TC_OP_ATOMIC_OR_32 = 0x56,
4467 TC_OP_ATOMIC_XOR_32 = 0x57,
4468 TC_OP_ATOMIC_INC_32 = 0x58,
4469 TC_OP_ATOMIC_DEC_32 = 0x59,
4470 TC_OP_INVL2_NC = 0x5a,
4471 TC_OP_RESERVED_NON_FLOAT_32_0 = 0x5b,
4472 TC_OP_RESERVED_NON_FLOAT_32_1 = 0x5c,
4473 TC_OP_RESERVED_NON_FLOAT_32_2 = 0x5d,
4474 TC_OP_RESERVED_NON_FLOAT_32_3 = 0x5e,
4475 TC_OP_RESERVED_NON_FLOAT_32_4 = 0x5f,
4476 TC_OP_WBINVL2 = 0x60,
4477 TC_OP_ATOMIC_FCMPSWAP_64 = 0x61,
4478 TC_OP_ATOMIC_FMIN_64 = 0x62,
4479 TC_OP_ATOMIC_FMAX_64 = 0x63,
4480 TC_OP_RESERVED_FOP_64_0 = 0x64,
4481 TC_OP_RESERVED_FOP_64_1 = 0x65,
4482 TC_OP_RESERVED_FOP_64_2 = 0x66,
4483 TC_OP_ATOMIC_SWAP_64 = 0x67,
4484 TC_OP_ATOMIC_CMPSWAP_64 = 0x68,
4485 TC_OP_ATOMIC_FCMPSWAP_FLUSH_DENORM_64 = 0x69,
4486 TC_OP_ATOMIC_FMIN_FLUSH_DENORM_64 = 0x6a,
4487 TC_OP_ATOMIC_FMAX_FLUSH_DENORM_64 = 0x6b,
4488 TC_OP_RESERVED_FOP_FLUSH_DENORM_64_0 = 0x6c,
4489 TC_OP_RESERVED_FOP_FLUSH_DENORM_64_1 = 0x6d,
4490 TC_OP_RESERVED_FOP_FLUSH_DENORM_64_2 = 0x6e,
4491 TC_OP_ATOMIC_ADD_64 = 0x6f,
4492 TC_OP_ATOMIC_SUB_64 = 0x70,
4493 TC_OP_ATOMIC_SMIN_64 = 0x71,
4494 TC_OP_ATOMIC_UMIN_64 = 0x72,
4495 TC_OP_ATOMIC_SMAX_64 = 0x73,
4496 TC_OP_ATOMIC_UMAX_64 = 0x74,
4497 TC_OP_ATOMIC_AND_64 = 0x75,
4498 TC_OP_ATOMIC_OR_64 = 0x76,
4499 TC_OP_ATOMIC_XOR_64 = 0x77,
4500 TC_OP_ATOMIC_INC_64 = 0x78,
4501 TC_OP_ATOMIC_DEC_64 = 0x79,
4502 TC_OP_WBINVL2_NC = 0x7a,
4503 TC_OP_RESERVED_NON_FLOAT_64_0 = 0x7b,
4504 TC_OP_RESERVED_NON_FLOAT_64_1 = 0x7c,
4505 TC_OP_RESERVED_NON_FLOAT_64_2 = 0x7d,
4506 TC_OP_RESERVED_NON_FLOAT_64_3 = 0x7e,
4507 TC_OP_RESERVED_NON_FLOAT_64_4 = 0x7f,
4508 } TC_OP;
4509 typedef enum TC_CHUB_REQ_CREDITS_ENUM {
4510 TC_CHUB_REQ_CREDITS = 0x10,
4511 } TC_CHUB_REQ_CREDITS_ENUM;
4512 typedef enum CHUB_TC_RET_CREDITS_ENUM {
4513 CHUB_TC_RET_CREDITS = 0x20,
4514 } CHUB_TC_RET_CREDITS_ENUM;
4515 typedef enum TC_NACKS {
4516 TC_NACK_NO_FAULT = 0x0,
4517 TC_NACK_PAGE_FAULT = 0x1,
4518 TC_NACK_PROTECTION_FAULT = 0x2,
4519 TC_NACK_DATA_ERROR = 0x3,
4520 } TC_NACKS;
4521 typedef enum TCC_PERF_SEL {
4522 TCC_PERF_SEL_NONE = 0x0,
4523 TCC_PERF_SEL_CYCLE = 0x1,
4524 TCC_PERF_SEL_BUSY = 0x2,
4525 TCC_PERF_SEL_REQ = 0x3,
4526 TCC_PERF_SEL_STREAMING_REQ = 0x4,
4527 TCC_PERF_SEL_EXE_REQ = 0x5,
4528 TCC_PERF_SEL_COMPRESSED_REQ = 0x6,
4529 TCC_PERF_SEL_COMPRESSED_0_REQ = 0x7,
4530 TCC_PERF_SEL_METADATA_REQ = 0x8,
4531 TCC_PERF_SEL_NC_VIRTUAL_REQ = 0x9,
4532 TCC_PERF_SEL_NC_PHYSICAL_REQ = 0xa,
4533 TCC_PERF_SEL_UC_VIRTUAL_REQ = 0xb,
4534 TCC_PERF_SEL_UC_PHYSICAL_REQ = 0xc,
4535 TCC_PERF_SEL_CC_PHYSICAL_REQ = 0xd,
4536 TCC_PERF_SEL_PROBE = 0xe,
4537 TCC_PERF_SEL_READ = 0xf,
4538 TCC_PERF_SEL_WRITE = 0x10,
4539 TCC_PERF_SEL_ATOMIC = 0x11,
4540 TCC_PERF_SEL_HIT = 0x12,
4541 TCC_PERF_SEL_MISS = 0x13,
4542 TCC_PERF_SEL_DEWRITE_ALLOCATE_HIT = 0x14,
4543 TCC_PERF_SEL_FULLY_WRITTEN_HIT = 0x15,
4544 TCC_PERF_SEL_WRITEBACK = 0x16,
4545 TCC_PERF_SEL_LATENCY_FIFO_FULL = 0x17,
4546 TCC_PERF_SEL_SRC_FIFO_FULL = 0x18,
4547 TCC_PERF_SEL_HOLE_FIFO_FULL = 0x19,
4548 TCC_PERF_SEL_MC_WRREQ = 0x1a,
4549 TCC_PERF_SEL_MC_WRREQ_UNCACHED = 0x1b,
4550 TCC_PERF_SEL_MC_WRREQ_STALL = 0x1c,
4551 TCC_PERF_SEL_MC_WRREQ_CREDIT_STALL = 0x1d,
4552 TCC_PERF_SEL_MC_WRREQ_MC_HALT_STALL = 0x1e,
4553 TCC_PERF_SEL_TOO_MANY_MC_WRREQS_STALL = 0x1f,
4554 TCC_PERF_SEL_MC_WRREQ_LEVEL = 0x20,
4555 TCC_PERF_SEL_MC_ATOMIC = 0x21,
4556 TCC_PERF_SEL_MC_ATOMIC_LEVEL = 0x22,
4557 TCC_PERF_SEL_MC_RDREQ = 0x23,
4558 TCC_PERF_SEL_MC_RDREQ_UNCACHED = 0x24,
4559 TCC_PERF_SEL_MC_RDREQ_MDC = 0x25,
4560 TCC_PERF_SEL_MC_RDREQ_COMPRESSED = 0x26,
4561 TCC_PERF_SEL_MC_RDREQ_CREDIT_STALL = 0x27,
4562 TCC_PERF_SEL_MC_RDREQ_MC_HALT_STALL = 0x28,
4563 TCC_PERF_SEL_MC_RDREQ_LEVEL = 0x29,
4564 TCC_PERF_SEL_TAG_STALL = 0x2a,
4565 TCC_PERF_SEL_TAG_WRITEBACK_FIFO_FULL_STALL = 0x2b,
4566 TCC_PERF_SEL_TAG_MISS_NOTHING_REPLACEABLE_STALL = 0x2c,
4567 TCC_PERF_SEL_TAG_UNCACHED_WRITE_ATOMIC_FIFO_FULL_STALL= 0x2d,
4568 TCC_PERF_SEL_TAG_NO_UNCACHED_WRITE_ATOMIC_ENTRIES_STALL= 0x2e,
4569 TCC_PERF_SEL_TAG_PROBE_STALL = 0x2f,
4570 TCC_PERF_SEL_TAG_PROBE_FILTER_STALL = 0x30,
4571 TCC_PERF_SEL_READ_RETURN_TIMEOUT = 0x31,
4572 TCC_PERF_SEL_WRITEBACK_READ_TIMEOUT = 0x32,
4573 TCC_PERF_SEL_READ_RETURN_FULL_BUBBLE = 0x33,
4574 TCC_PERF_SEL_BUBBLE = 0x34,
4575 TCC_PERF_SEL_RETURN_ACK = 0x35,
4576 TCC_PERF_SEL_RETURN_DATA = 0x36,
4577 TCC_PERF_SEL_RETURN_HOLE = 0x37,
4578 TCC_PERF_SEL_RETURN_ACK_HOLE = 0x38,
4579 TCC_PERF_SEL_IB_REQ = 0x39,
4580 TCC_PERF_SEL_IB_STALL = 0x3a,
4581 TCC_PERF_SEL_IB_TAG_STALL = 0x3b,
4582 TCC_PERF_SEL_IB_MDC_STALL = 0x3c,
4583 TCC_PERF_SEL_TCA_LEVEL = 0x3d,
4584 TCC_PERF_SEL_HOLE_LEVEL = 0x3e,
4585 TCC_PERF_SEL_MC_RDRET_NACK = 0x3f,
4586 TCC_PERF_SEL_MC_WRRET_NACK = 0x40,
4587 TCC_PERF_SEL_NORMAL_WRITEBACK = 0x41,
4588 TCC_PERF_SEL_TC_OP_WBL2_NC_WRITEBACK = 0x42,
4589 TCC_PERF_SEL_TC_OP_WBINVL2_WRITEBACK = 0x43,
4590 TCC_PERF_SEL_TC_OP_WBINVL2_NC_WRITEBACK = 0x44,
4591 TCC_PERF_SEL_TC_OP_WBINVL2_SD_WRITEBACK = 0x45,
4592 TCC_PERF_SEL_ALL_TC_OP_WB_WRITEBACK = 0x46,
4593 TCC_PERF_SEL_NORMAL_EVICT = 0x47,
4594 TCC_PERF_SEL_TC_OP_WBL2_NC_EVICT = 0x48,
4595 TCC_PERF_SEL_TC_OP_INVL2_NC_EVICT = 0x49,
4596 TCC_PERF_SEL_TC_OP_WBINVL2_EVICT = 0x4a,
4597 TCC_PERF_SEL_TC_OP_WBINVL2_NC_EVICT = 0x4b,
4598 TCC_PERF_SEL_TC_OP_WBINVL2_SD_EVICT = 0x4c,
4599 TCC_PERF_SEL_ALL_TC_OP_INV_EVICT = 0x4d,
4600 TCC_PERF_SEL_PROBE_EVICT = 0x4e,
4601 TCC_PERF_SEL_TC_OP_WBL2_NC_CYCLE = 0x4f,
4602 TCC_PERF_SEL_TC_OP_INVL2_NC_CYCLE = 0x50,
4603 TCC_PERF_SEL_TC_OP_WBINVL2_CYCLE = 0x51,
4604 TCC_PERF_SEL_TC_OP_WBINVL2_NC_CYCLE = 0x52,
4605 TCC_PERF_SEL_TC_OP_WBINVL2_SD_CYCLE = 0x53,
4606 TCC_PERF_SEL_ALL_TC_OP_WB_OR_INV_CYCLE = 0x54,
4607 TCC_PERF_SEL_TC_OP_WBL2_NC_START = 0x55,
4608 TCC_PERF_SEL_TC_OP_INVL2_NC_START = 0x56,
4609 TCC_PERF_SEL_TC_OP_WBINVL2_START = 0x57,
4610 TCC_PERF_SEL_TC_OP_WBINVL2_NC_START = 0x58,
4611 TCC_PERF_SEL_TC_OP_WBINVL2_SD_START = 0x59,
4612 TCC_PERF_SEL_ALL_TC_OP_WB_OR_INV_START = 0x5a,
4613 TCC_PERF_SEL_TC_OP_WBL2_NC_FINISH = 0x5b,
4614 TCC_PERF_SEL_TC_OP_INVL2_NC_FINISH = 0x5c,
4615 TCC_PERF_SEL_TC_OP_WBINVL2_FINISH = 0x5d,
4616 TCC_PERF_SEL_TC_OP_WBINVL2_NC_FINISH = 0x5e,
4617 TCC_PERF_SEL_TC_OP_WBINVL2_SD_FINISH = 0x5f,
4618 TCC_PERF_SEL_ALL_TC_OP_WB_OR_INV_FINISH = 0x60,
4619 TCC_PERF_SEL_MDC_REQ = 0x61,
4620 TCC_PERF_SEL_MDC_LEVEL = 0x62,
4621 TCC_PERF_SEL_MDC_TAG_HIT = 0x63,
4622 TCC_PERF_SEL_MDC_SECTOR_HIT = 0x64,
4623 TCC_PERF_SEL_MDC_SECTOR_MISS = 0x65,
4624 TCC_PERF_SEL_MDC_TAG_STALL = 0x66,
4625 TCC_PERF_SEL_MDC_TAG_REPLACEMENT_LINE_IN_USE_STALL= 0x67,
4626 TCC_PERF_SEL_MDC_TAG_DESECTORIZATION_FIFO_FULL_STALL= 0x68,
4627 TCC_PERF_SEL_MDC_TAG_WAITING_FOR_INVALIDATE_COMPLETION_STALL= 0x69,
4628 TCC_PERF_SEL_PROBE_FILTER_DISABLE_TRANSITION = 0x6a,
4629 TCC_PERF_SEL_PROBE_FILTER_DISABLED = 0x6b,
4630 TCC_PERF_SEL_CLIENT0_REQ = 0x80,
4631 TCC_PERF_SEL_CLIENT1_REQ = 0x81,
4632 TCC_PERF_SEL_CLIENT2_REQ = 0x82,
4633 TCC_PERF_SEL_CLIENT3_REQ = 0x83,
4634 TCC_PERF_SEL_CLIENT4_REQ = 0x84,
4635 TCC_PERF_SEL_CLIENT5_REQ = 0x85,
4636 TCC_PERF_SEL_CLIENT6_REQ = 0x86,
4637 TCC_PERF_SEL_CLIENT7_REQ = 0x87,
4638 TCC_PERF_SEL_CLIENT8_REQ = 0x88,
4639 TCC_PERF_SEL_CLIENT9_REQ = 0x89,
4640 TCC_PERF_SEL_CLIENT10_REQ = 0x8a,
4641 TCC_PERF_SEL_CLIENT11_REQ = 0x8b,
4642 TCC_PERF_SEL_CLIENT12_REQ = 0x8c,
4643 TCC_PERF_SEL_CLIENT13_REQ = 0x8d,
4644 TCC_PERF_SEL_CLIENT14_REQ = 0x8e,
4645 TCC_PERF_SEL_CLIENT15_REQ = 0x8f,
4646 TCC_PERF_SEL_CLIENT16_REQ = 0x90,
4647 TCC_PERF_SEL_CLIENT17_REQ = 0x91,
4648 TCC_PERF_SEL_CLIENT18_REQ = 0x92,
4649 TCC_PERF_SEL_CLIENT19_REQ = 0x93,
4650 TCC_PERF_SEL_CLIENT20_REQ = 0x94,
4651 TCC_PERF_SEL_CLIENT21_REQ = 0x95,
4652 TCC_PERF_SEL_CLIENT22_REQ = 0x96,
4653 TCC_PERF_SEL_CLIENT23_REQ = 0x97,
4654 TCC_PERF_SEL_CLIENT24_REQ = 0x98,
4655 TCC_PERF_SEL_CLIENT25_REQ = 0x99,
4656 TCC_PERF_SEL_CLIENT26_REQ = 0x9a,
4657 TCC_PERF_SEL_CLIENT27_REQ = 0x9b,
4658 TCC_PERF_SEL_CLIENT28_REQ = 0x9c,
4659 TCC_PERF_SEL_CLIENT29_REQ = 0x9d,
4660 TCC_PERF_SEL_CLIENT30_REQ = 0x9e,
4661 TCC_PERF_SEL_CLIENT31_REQ = 0x9f,
4662 TCC_PERF_SEL_CLIENT32_REQ = 0xa0,
4663 TCC_PERF_SEL_CLIENT33_REQ = 0xa1,
4664 TCC_PERF_SEL_CLIENT34_REQ = 0xa2,
4665 TCC_PERF_SEL_CLIENT35_REQ = 0xa3,
4666 TCC_PERF_SEL_CLIENT36_REQ = 0xa4,
4667 TCC_PERF_SEL_CLIENT37_REQ = 0xa5,
4668 TCC_PERF_SEL_CLIENT38_REQ = 0xa6,
4669 TCC_PERF_SEL_CLIENT39_REQ = 0xa7,
4670 TCC_PERF_SEL_CLIENT40_REQ = 0xa8,
4671 TCC_PERF_SEL_CLIENT41_REQ = 0xa9,
4672 TCC_PERF_SEL_CLIENT42_REQ = 0xaa,
4673 TCC_PERF_SEL_CLIENT43_REQ = 0xab,
4674 TCC_PERF_SEL_CLIENT44_REQ = 0xac,
4675 TCC_PERF_SEL_CLIENT45_REQ = 0xad,
4676 TCC_PERF_SEL_CLIENT46_REQ = 0xae,
4677 TCC_PERF_SEL_CLIENT47_REQ = 0xaf,
4678 TCC_PERF_SEL_CLIENT48_REQ = 0xb0,
4679 TCC_PERF_SEL_CLIENT49_REQ = 0xb1,
4680 TCC_PERF_SEL_CLIENT50_REQ = 0xb2,
4681 TCC_PERF_SEL_CLIENT51_REQ = 0xb3,
4682 TCC_PERF_SEL_CLIENT52_REQ = 0xb4,
4683 TCC_PERF_SEL_CLIENT53_REQ = 0xb5,
4684 TCC_PERF_SEL_CLIENT54_REQ = 0xb6,
4685 TCC_PERF_SEL_CLIENT55_REQ = 0xb7,
4686 TCC_PERF_SEL_CLIENT56_REQ = 0xb8,
4687 TCC_PERF_SEL_CLIENT57_REQ = 0xb9,
4688 TCC_PERF_SEL_CLIENT58_REQ = 0xba,
4689 TCC_PERF_SEL_CLIENT59_REQ = 0xbb,
4690 TCC_PERF_SEL_CLIENT60_REQ = 0xbc,
4691 TCC_PERF_SEL_CLIENT61_REQ = 0xbd,
4692 TCC_PERF_SEL_CLIENT62_REQ = 0xbe,
4693 TCC_PERF_SEL_CLIENT63_REQ = 0xbf,
4694 TCC_PERF_SEL_CLIENT64_REQ = 0xc0,
4695 TCC_PERF_SEL_CLIENT65_REQ = 0xc1,
4696 TCC_PERF_SEL_CLIENT66_REQ = 0xc2,
4697 TCC_PERF_SEL_CLIENT67_REQ = 0xc3,
4698 TCC_PERF_SEL_CLIENT68_REQ = 0xc4,
4699 TCC_PERF_SEL_CLIENT69_REQ = 0xc5,
4700 TCC_PERF_SEL_CLIENT70_REQ = 0xc6,
4701 TCC_PERF_SEL_CLIENT71_REQ = 0xc7,
4702 TCC_PERF_SEL_CLIENT72_REQ = 0xc8,
4703 TCC_PERF_SEL_CLIENT73_REQ = 0xc9,
4704 TCC_PERF_SEL_CLIENT74_REQ = 0xca,
4705 TCC_PERF_SEL_CLIENT75_REQ = 0xcb,
4706 TCC_PERF_SEL_CLIENT76_REQ = 0xcc,
4707 TCC_PERF_SEL_CLIENT77_REQ = 0xcd,
4708 TCC_PERF_SEL_CLIENT78_REQ = 0xce,
4709 TCC_PERF_SEL_CLIENT79_REQ = 0xcf,
4710 TCC_PERF_SEL_CLIENT80_REQ = 0xd0,
4711 TCC_PERF_SEL_CLIENT81_REQ = 0xd1,
4712 TCC_PERF_SEL_CLIENT82_REQ = 0xd2,
4713 TCC_PERF_SEL_CLIENT83_REQ = 0xd3,
4714 TCC_PERF_SEL_CLIENT84_REQ = 0xd4,
4715 TCC_PERF_SEL_CLIENT85_REQ = 0xd5,
4716 TCC_PERF_SEL_CLIENT86_REQ = 0xd6,
4717 TCC_PERF_SEL_CLIENT87_REQ = 0xd7,
4718 TCC_PERF_SEL_CLIENT88_REQ = 0xd8,
4719 TCC_PERF_SEL_CLIENT89_REQ = 0xd9,
4720 TCC_PERF_SEL_CLIENT90_REQ = 0xda,
4721 TCC_PERF_SEL_CLIENT91_REQ = 0xdb,
4722 TCC_PERF_SEL_CLIENT92_REQ = 0xdc,
4723 TCC_PERF_SEL_CLIENT93_REQ = 0xdd,
4724 TCC_PERF_SEL_CLIENT94_REQ = 0xde,
4725 TCC_PERF_SEL_CLIENT95_REQ = 0xdf,
4726 TCC_PERF_SEL_CLIENT96_REQ = 0xe0,
4727 TCC_PERF_SEL_CLIENT97_REQ = 0xe1,
4728 TCC_PERF_SEL_CLIENT98_REQ = 0xe2,
4729 TCC_PERF_SEL_CLIENT99_REQ = 0xe3,
4730 TCC_PERF_SEL_CLIENT100_REQ = 0xe4,
4731 TCC_PERF_SEL_CLIENT101_REQ = 0xe5,
4732 TCC_PERF_SEL_CLIENT102_REQ = 0xe6,
4733 TCC_PERF_SEL_CLIENT103_REQ = 0xe7,
4734 TCC_PERF_SEL_CLIENT104_REQ = 0xe8,
4735 TCC_PERF_SEL_CLIENT105_REQ = 0xe9,
4736 TCC_PERF_SEL_CLIENT106_REQ = 0xea,
4737 TCC_PERF_SEL_CLIENT107_REQ = 0xeb,
4738 TCC_PERF_SEL_CLIENT108_REQ = 0xec,
4739 TCC_PERF_SEL_CLIENT109_REQ = 0xed,
4740 TCC_PERF_SEL_CLIENT110_REQ = 0xee,
4741 TCC_PERF_SEL_CLIENT111_REQ = 0xef,
4742 TCC_PERF_SEL_CLIENT112_REQ = 0xf0,
4743 TCC_PERF_SEL_CLIENT113_REQ = 0xf1,
4744 TCC_PERF_SEL_CLIENT114_REQ = 0xf2,
4745 TCC_PERF_SEL_CLIENT115_REQ = 0xf3,
4746 TCC_PERF_SEL_CLIENT116_REQ = 0xf4,
4747 TCC_PERF_SEL_CLIENT117_REQ = 0xf5,
4748 TCC_PERF_SEL_CLIENT118_REQ = 0xf6,
4749 TCC_PERF_SEL_CLIENT119_REQ = 0xf7,
4750 TCC_PERF_SEL_CLIENT120_REQ = 0xf8,
4751 TCC_PERF_SEL_CLIENT121_REQ = 0xf9,
4752 TCC_PERF_SEL_CLIENT122_REQ = 0xfa,
4753 TCC_PERF_SEL_CLIENT123_REQ = 0xfb,
4754 TCC_PERF_SEL_CLIENT124_REQ = 0xfc,
4755 TCC_PERF_SEL_CLIENT125_REQ = 0xfd,
4756 TCC_PERF_SEL_CLIENT126_REQ = 0xfe,
4757 TCC_PERF_SEL_CLIENT127_REQ = 0xff,
4758 } TCC_PERF_SEL;
4759 typedef enum TCA_PERF_SEL {
4760 TCA_PERF_SEL_NONE = 0x0,
4761 TCA_PERF_SEL_CYCLE = 0x1,
4762 TCA_PERF_SEL_BUSY = 0x2,
4763 TCA_PERF_SEL_FORCED_HOLE_TCC0 = 0x3,
4764 TCA_PERF_SEL_FORCED_HOLE_TCC1 = 0x4,
4765 TCA_PERF_SEL_FORCED_HOLE_TCC2 = 0x5,
4766 TCA_PERF_SEL_FORCED_HOLE_TCC3 = 0x6,
4767 TCA_PERF_SEL_FORCED_HOLE_TCC4 = 0x7,
4768 TCA_PERF_SEL_FORCED_HOLE_TCC5 = 0x8,
4769 TCA_PERF_SEL_FORCED_HOLE_TCC6 = 0x9,
4770 TCA_PERF_SEL_FORCED_HOLE_TCC7 = 0xa,
4771 TCA_PERF_SEL_REQ_TCC0 = 0xb,
4772 TCA_PERF_SEL_REQ_TCC1 = 0xc,
4773 TCA_PERF_SEL_REQ_TCC2 = 0xd,
4774 TCA_PERF_SEL_REQ_TCC3 = 0xe,
4775 TCA_PERF_SEL_REQ_TCC4 = 0xf,
4776 TCA_PERF_SEL_REQ_TCC5 = 0x10,
4777 TCA_PERF_SEL_REQ_TCC6 = 0x11,
4778 TCA_PERF_SEL_REQ_TCC7 = 0x12,
4779 TCA_PERF_SEL_CROSSBAR_DOUBLE_ARB_TCC0 = 0x13,
4780 TCA_PERF_SEL_CROSSBAR_DOUBLE_ARB_TCC1 = 0x14,
4781 TCA_PERF_SEL_CROSSBAR_DOUBLE_ARB_TCC2 = 0x15,
4782 TCA_PERF_SEL_CROSSBAR_DOUBLE_ARB_TCC3 = 0x16,
4783 TCA_PERF_SEL_CROSSBAR_DOUBLE_ARB_TCC4 = 0x17,
4784 TCA_PERF_SEL_CROSSBAR_DOUBLE_ARB_TCC5 = 0x18,
4785 TCA_PERF_SEL_CROSSBAR_DOUBLE_ARB_TCC6 = 0x19,
4786 TCA_PERF_SEL_CROSSBAR_DOUBLE_ARB_TCC7 = 0x1a,
4787 TCA_PERF_SEL_CROSSBAR_STALL_TCC0 = 0x1b,
4788 TCA_PERF_SEL_CROSSBAR_STALL_TCC1 = 0x1c,
4789 TCA_PERF_SEL_CROSSBAR_STALL_TCC2 = 0x1d,
4790 TCA_PERF_SEL_CROSSBAR_STALL_TCC3 = 0x1e,
4791 TCA_PERF_SEL_CROSSBAR_STALL_TCC4 = 0x1f,
4792 TCA_PERF_SEL_CROSSBAR_STALL_TCC5 = 0x20,
4793 TCA_PERF_SEL_CROSSBAR_STALL_TCC6 = 0x21,
4794 TCA_PERF_SEL_CROSSBAR_STALL_TCC7 = 0x22,
4795 } TCA_PERF_SEL;
4796 typedef enum TA_TC_ADDR_MODES {
4797 TA_TC_ADDR_MODE_DEFAULT = 0x0,
4798 TA_TC_ADDR_MODE_COMP0 = 0x1,
4799 TA_TC_ADDR_MODE_COMP1 = 0x2,
4800 TA_TC_ADDR_MODE_COMP2 = 0x3,
4801 TA_TC_ADDR_MODE_COMP3 = 0x4,
4802 TA_TC_ADDR_MODE_UNALIGNED = 0x5,
4803 TA_TC_ADDR_MODE_BORDER_COLOR = 0x6,
4804 } TA_TC_ADDR_MODES;
4805 typedef enum TA_PERFCOUNT_SEL {
4806 TA_PERF_SEL_NULL = 0x0,
4807 TA_PERF_SEL_sh_fifo_busy = 0x1,
4808 TA_PERF_SEL_sh_fifo_cmd_busy = 0x2,
4809 TA_PERF_SEL_sh_fifo_addr_busy = 0x3,
4810 TA_PERF_SEL_sh_fifo_data_busy = 0x4,
4811 TA_PERF_SEL_sh_fifo_data_sfifo_busy = 0x5,
4812 TA_PERF_SEL_sh_fifo_data_tfifo_busy = 0x6,
4813 TA_PERF_SEL_gradient_busy = 0x7,
4814 TA_PERF_SEL_gradient_fifo_busy = 0x8,
4815 TA_PERF_SEL_lod_busy = 0x9,
4816 TA_PERF_SEL_lod_fifo_busy = 0xa,
4817 TA_PERF_SEL_addresser_busy = 0xb,
4818 TA_PERF_SEL_addresser_fifo_busy = 0xc,
4819 TA_PERF_SEL_aligner_busy = 0xd,
4820 TA_PERF_SEL_write_path_busy = 0xe,
4821 TA_PERF_SEL_ta_busy = 0xf,
4822 TA_PERF_SEL_sq_ta_cmd_cycles = 0x10,
4823 TA_PERF_SEL_sp_ta_addr_cycles = 0x11,
4824 TA_PERF_SEL_sp_ta_data_cycles = 0x12,
4825 TA_PERF_SEL_ta_fa_data_state_cycles = 0x13,
4826 TA_PERF_SEL_sh_fifo_addr_waiting_on_cmd_cycles = 0x14,
4827 TA_PERF_SEL_sh_fifo_cmd_waiting_on_addr_cycles = 0x15,
4828 TA_PERF_SEL_sh_fifo_addr_starved_while_busy_cycles= 0x16,
4829 TA_PERF_SEL_sh_fifo_cmd_starved_while_busy_cycles= 0x17,
4830 TA_PERF_SEL_sh_fifo_data_waiting_on_data_state_cycles= 0x18,
4831 TA_PERF_SEL_sh_fifo_data_state_waiting_on_data_cycles= 0x19,
4832 TA_PERF_SEL_sh_fifo_data_starved_while_busy_cycles= 0x1a,
4833 TA_PERF_SEL_sh_fifo_data_state_starved_while_busy_cycles= 0x1b,
4834 TA_PERF_SEL_RESERVED_28 = 0x1c,
4835 TA_PERF_SEL_RESERVED_29 = 0x1d,
4836 TA_PERF_SEL_sh_fifo_addr_cycles = 0x1e,
4837 TA_PERF_SEL_sh_fifo_data_cycles = 0x1f,
4838 TA_PERF_SEL_total_wavefronts = 0x20,
4839 TA_PERF_SEL_gradient_cycles = 0x21,
4840 TA_PERF_SEL_walker_cycles = 0x22,
4841 TA_PERF_SEL_aligner_cycles = 0x23,
4842 TA_PERF_SEL_image_wavefronts = 0x24,
4843 TA_PERF_SEL_image_read_wavefronts = 0x25,
4844 TA_PERF_SEL_image_write_wavefronts = 0x26,
4845 TA_PERF_SEL_image_atomic_wavefronts = 0x27,
4846 TA_PERF_SEL_image_total_cycles = 0x28,
4847 TA_PERF_SEL_RESERVED_41 = 0x29,
4848 TA_PERF_SEL_RESERVED_42 = 0x2a,
4849 TA_PERF_SEL_RESERVED_43 = 0x2b,
4850 TA_PERF_SEL_buffer_wavefronts = 0x2c,
4851 TA_PERF_SEL_buffer_read_wavefronts = 0x2d,
4852 TA_PERF_SEL_buffer_write_wavefronts = 0x2e,
4853 TA_PERF_SEL_buffer_atomic_wavefronts = 0x2f,
4854 TA_PERF_SEL_buffer_coalescable_wavefronts = 0x30,
4855 TA_PERF_SEL_buffer_total_cycles = 0x31,
4856 TA_PERF_SEL_buffer_coalescable_addr_multicycled_cycles= 0x32,
4857 TA_PERF_SEL_buffer_coalescable_clamp_16kdword_multicycled_cycles= 0x33,
4858 TA_PERF_SEL_buffer_coalesced_read_cycles = 0x34,
4859 TA_PERF_SEL_buffer_coalesced_write_cycles = 0x35,
4860 TA_PERF_SEL_addr_stalled_by_tc_cycles = 0x36,
4861 TA_PERF_SEL_addr_stalled_by_td_cycles = 0x37,
4862 TA_PERF_SEL_data_stalled_by_tc_cycles = 0x38,
4863 TA_PERF_SEL_addresser_stalled_by_aligner_only_cycles= 0x39,
4864 TA_PERF_SEL_addresser_stalled_cycles = 0x3a,
4865 TA_PERF_SEL_aniso_stalled_by_addresser_only_cycles= 0x3b,
4866 TA_PERF_SEL_aniso_stalled_cycles = 0x3c,
4867 TA_PERF_SEL_deriv_stalled_by_aniso_only_cycles = 0x3d,
4868 TA_PERF_SEL_deriv_stalled_cycles = 0x3e,
4869 TA_PERF_SEL_aniso_gt1_cycle_quads = 0x3f,
4870 TA_PERF_SEL_color_1_cycle_pixels = 0x40,
4871 TA_PERF_SEL_color_2_cycle_pixels = 0x41,
4872 TA_PERF_SEL_color_3_cycle_pixels = 0x42,
4873 TA_PERF_SEL_color_4_cycle_pixels = 0x43,
4874 TA_PERF_SEL_mip_1_cycle_pixels = 0x44,
4875 TA_PERF_SEL_mip_2_cycle_pixels = 0x45,
4876 TA_PERF_SEL_vol_1_cycle_pixels = 0x46,
4877 TA_PERF_SEL_vol_2_cycle_pixels = 0x47,
4878 TA_PERF_SEL_bilin_point_1_cycle_pixels = 0x48,
4879 TA_PERF_SEL_mipmap_lod_0_samples = 0x49,
4880 TA_PERF_SEL_mipmap_lod_1_samples = 0x4a,
4881 TA_PERF_SEL_mipmap_lod_2_samples = 0x4b,
4882 TA_PERF_SEL_mipmap_lod_3_samples = 0x4c,
4883 TA_PERF_SEL_mipmap_lod_4_samples = 0x4d,
4884 TA_PERF_SEL_mipmap_lod_5_samples = 0x4e,
4885 TA_PERF_SEL_mipmap_lod_6_samples = 0x4f,
4886 TA_PERF_SEL_mipmap_lod_7_samples = 0x50,
4887 TA_PERF_SEL_mipmap_lod_8_samples = 0x51,
4888 TA_PERF_SEL_mipmap_lod_9_samples = 0x52,
4889 TA_PERF_SEL_mipmap_lod_10_samples = 0x53,
4890 TA_PERF_SEL_mipmap_lod_11_samples = 0x54,
4891 TA_PERF_SEL_mipmap_lod_12_samples = 0x55,
4892 TA_PERF_SEL_mipmap_lod_13_samples = 0x56,
4893 TA_PERF_SEL_mipmap_lod_14_samples = 0x57,
4894 TA_PERF_SEL_mipmap_invalid_samples = 0x58,
4895 TA_PERF_SEL_aniso_1_cycle_quads = 0x59,
4896 TA_PERF_SEL_aniso_2_cycle_quads = 0x5a,
4897 TA_PERF_SEL_aniso_4_cycle_quads = 0x5b,
4898 TA_PERF_SEL_aniso_6_cycle_quads = 0x5c,
4899 TA_PERF_SEL_aniso_8_cycle_quads = 0x5d,
4900 TA_PERF_SEL_aniso_10_cycle_quads = 0x5e,
4901 TA_PERF_SEL_aniso_12_cycle_quads = 0x5f,
4902 TA_PERF_SEL_aniso_14_cycle_quads = 0x60,
4903 TA_PERF_SEL_aniso_16_cycle_quads = 0x61,
4904 TA_PERF_SEL_write_path_input_cycles = 0x62,
4905 TA_PERF_SEL_write_path_output_cycles = 0x63,
4906 TA_PERF_SEL_flat_wavefronts = 0x64,
4907 TA_PERF_SEL_flat_read_wavefronts = 0x65,
4908 TA_PERF_SEL_flat_write_wavefronts = 0x66,
4909 TA_PERF_SEL_flat_atomic_wavefronts = 0x67,
4910 TA_PERF_SEL_flat_coalesceable_wavefronts = 0x68,
4911 TA_PERF_SEL_reg_sclk_vld = 0x69,
4912 TA_PERF_SEL_local_cg_dyn_sclk_grp0_en = 0x6a,
4913 TA_PERF_SEL_local_cg_dyn_sclk_grp1_en = 0x6b,
4914 TA_PERF_SEL_local_cg_dyn_sclk_grp1_mems_en = 0x6c,
4915 TA_PERF_SEL_local_cg_dyn_sclk_grp4_en = 0x6d,
4916 TA_PERF_SEL_local_cg_dyn_sclk_grp5_en = 0x6e,
4917 TA_PERF_SEL_xnack_on_phase0 = 0x6f,
4918 TA_PERF_SEL_xnack_on_phase1 = 0x70,
4919 TA_PERF_SEL_xnack_on_phase2 = 0x71,
4920 TA_PERF_SEL_xnack_on_phase3 = 0x72,
4921 TA_PERF_SEL_first_xnack_on_phase0 = 0x73,
4922 TA_PERF_SEL_first_xnack_on_phase1 = 0x74,
4923 TA_PERF_SEL_first_xnack_on_phase2 = 0x75,
4924 TA_PERF_SEL_first_xnack_on_phase3 = 0x76,
4925 } TA_PERFCOUNT_SEL;
4926 typedef enum TD_PERFCOUNT_SEL {
4927 TD_PERF_SEL_none = 0x0,
4928 TD_PERF_SEL_td_busy = 0x1,
4929 TD_PERF_SEL_input_busy = 0x2,
4930 TD_PERF_SEL_output_busy = 0x3,
4931 TD_PERF_SEL_lerp_busy = 0x4,
4932 TD_PERF_SEL_reg_sclk_vld = 0x5,
4933 TD_PERF_SEL_local_cg_dyn_sclk_grp0_en = 0x6,
4934 TD_PERF_SEL_local_cg_dyn_sclk_grp1_en = 0x7,
4935 TD_PERF_SEL_local_cg_dyn_sclk_grp4_en = 0x8,
4936 TD_PERF_SEL_local_cg_dyn_sclk_grp5_en = 0x9,
4937 TD_PERF_SEL_tc_td_fifo_full = 0xa,
4938 TD_PERF_SEL_constant_state_full = 0xb,
4939 TD_PERF_SEL_sample_state_full = 0xc,
4940 TD_PERF_SEL_output_fifo_full = 0xd,
4941 TD_PERF_SEL_RESERVED_14 = 0xe,
4942 TD_PERF_SEL_tc_stall = 0xf,
4943 TD_PERF_SEL_pc_stall = 0x10,
4944 TD_PERF_SEL_gds_stall = 0x11,
4945 TD_PERF_SEL_RESERVED_18 = 0x12,
4946 TD_PERF_SEL_RESERVED_19 = 0x13,
4947 TD_PERF_SEL_gather4_wavefront = 0x14,
4948 TD_PERF_SEL_sample_c_wavefront = 0x15,
4949 TD_PERF_SEL_load_wavefront = 0x16,
4950 TD_PERF_SEL_atomic_wavefront = 0x17,
4951 TD_PERF_SEL_store_wavefront = 0x18,
4952 TD_PERF_SEL_ldfptr_wavefront = 0x19,
4953 TD_PERF_SEL_RESERVED_26 = 0x1a,
4954 TD_PERF_SEL_RESERVED_27 = 0x1b,
4955 TD_PERF_SEL_d16_en_wavefront = 0x1c,
4956 TD_PERF_SEL_bicubic_filter_wavefront = 0x1d,
4957 TD_PERF_SEL_bypass_filter_wavefront = 0x1e,
4958 TD_PERF_SEL_min_max_filter_wavefront = 0x1f,
4959 TD_PERF_SEL_coalescable_wavefront = 0x20,
4960 TD_PERF_SEL_coalesced_phase = 0x21,
4961 TD_PERF_SEL_four_phase_wavefront = 0x22,
4962 TD_PERF_SEL_eight_phase_wavefront = 0x23,
4963 TD_PERF_SEL_sixteen_phase_wavefront = 0x24,
4964 TD_PERF_SEL_four_phase_forward_wavefront = 0x25,
4965 TD_PERF_SEL_write_ack_wavefront = 0x26,
4966 TD_PERF_SEL_RESERVED_39 = 0x27,
4967 TD_PERF_SEL_user_defined_border = 0x28,
4968 TD_PERF_SEL_white_border = 0x29,
4969 TD_PERF_SEL_opaque_black_border = 0x2a,
4970 TD_PERF_SEL_RESERVED_43 = 0x2b,
4971 TD_PERF_SEL_RESERVED_44 = 0x2c,
4972 TD_PERF_SEL_nack = 0x2d,
4973 TD_PERF_SEL_td_sp_traffic = 0x2e,
4974 TD_PERF_SEL_consume_gds_traffic = 0x2f,
4975 TD_PERF_SEL_addresscmd_poison = 0x30,
4976 TD_PERF_SEL_data_poison = 0x31,
4977 TD_PERF_SEL_start_cycle_0 = 0x32,
4978 TD_PERF_SEL_start_cycle_1 = 0x33,
4979 TD_PERF_SEL_start_cycle_2 = 0x34,
4980 TD_PERF_SEL_start_cycle_3 = 0x35,
4981 TD_PERF_SEL_null_cycle_output = 0x36,
4982 } TD_PERFCOUNT_SEL;
4983 typedef enum TCP_PERFCOUNT_SELECT {
4984 TCP_PERF_SEL_TA_TCP_ADDR_STARVE_CYCLES = 0x0,
4985 TCP_PERF_SEL_TA_TCP_DATA_STARVE_CYCLES = 0x1,
4986 TCP_PERF_SEL_TCP_TA_ADDR_STALL_CYCLES = 0x2,
4987 TCP_PERF_SEL_TCP_TA_DATA_STALL_CYCLES = 0x3,
4988 TCP_PERF_SEL_TD_TCP_STALL_CYCLES = 0x4,
4989 TCP_PERF_SEL_TCR_TCP_STALL_CYCLES = 0x5,
4990 TCP_PERF_SEL_LOD_STALL_CYCLES = 0x6,
4991 TCP_PERF_SEL_READ_TAGCONFLICT_STALL_CYCLES = 0x7,
4992 TCP_PERF_SEL_WRITE_TAGCONFLICT_STALL_CYCLES = 0x8,
4993 TCP_PERF_SEL_ATOMIC_TAGCONFLICT_STALL_CYCLES = 0x9,
4994 TCP_PERF_SEL_ALLOC_STALL_CYCLES = 0xa,
4995 TCP_PERF_SEL_LFIFO_STALL_CYCLES = 0xb,
4996 TCP_PERF_SEL_RFIFO_STALL_CYCLES = 0xc,
4997 TCP_PERF_SEL_TCR_RDRET_STALL = 0xd,
4998 TCP_PERF_SEL_WRITE_CONFLICT_STALL = 0xe,
4999 TCP_PERF_SEL_HOLE_READ_STALL = 0xf,
5000 TCP_PERF_SEL_READCONFLICT_STALL_CYCLES = 0x10,
5001 TCP_PERF_SEL_PENDING_STALL_CYCLES = 0x11,
5002 TCP_PERF_SEL_READFIFO_STALL_CYCLES = 0x12,
5003 TCP_PERF_SEL_TCP_LATENCY = 0x13,
5004 TCP_PERF_SEL_TCC_READ_REQ_LATENCY = 0x14,
5005 TCP_PERF_SEL_TCC_WRITE_REQ_LATENCY = 0x15,
5006 TCP_PERF_SEL_TCC_WRITE_REQ_HOLE_LATENCY = 0x16,
5007 TCP_PERF_SEL_TCC_READ_REQ = 0x17,
5008 TCP_PERF_SEL_TCC_WRITE_REQ = 0x18,
5009 TCP_PERF_SEL_TCC_ATOMIC_WITH_RET_REQ = 0x19,
5010 TCP_PERF_SEL_TCC_ATOMIC_WITHOUT_RET_REQ = 0x1a,
5011 TCP_PERF_SEL_TOTAL_LOCAL_READ = 0x1b,
5012 TCP_PERF_SEL_TOTAL_GLOBAL_READ = 0x1c,
5013 TCP_PERF_SEL_TOTAL_LOCAL_WRITE = 0x1d,
5014 TCP_PERF_SEL_TOTAL_GLOBAL_WRITE = 0x1e,
5015 TCP_PERF_SEL_TOTAL_ATOMIC_WITH_RET = 0x1f,
5016 TCP_PERF_SEL_TOTAL_ATOMIC_WITHOUT_RET = 0x20,
5017 TCP_PERF_SEL_TOTAL_WBINVL1 = 0x21,
5018 TCP_PERF_SEL_IMG_READ_FMT_1 = 0x22,
5019 TCP_PERF_SEL_IMG_READ_FMT_8 = 0x23,
5020 TCP_PERF_SEL_IMG_READ_FMT_16 = 0x24,
5021 TCP_PERF_SEL_IMG_READ_FMT_32 = 0x25,
5022 TCP_PERF_SEL_IMG_READ_FMT_32_AS_8 = 0x26,
5023 TCP_PERF_SEL_IMG_READ_FMT_32_AS_16 = 0x27,
5024 TCP_PERF_SEL_IMG_READ_FMT_32_AS_128 = 0x28,
5025 TCP_PERF_SEL_IMG_READ_FMT_64_2_CYCLE = 0x29,
5026 TCP_PERF_SEL_IMG_READ_FMT_64_1_CYCLE = 0x2a,
5027 TCP_PERF_SEL_IMG_READ_FMT_96 = 0x2b,
5028 TCP_PERF_SEL_IMG_READ_FMT_128_4_CYCLE = 0x2c,
5029 TCP_PERF_SEL_IMG_READ_FMT_128_1_CYCLE = 0x2d,
5030 TCP_PERF_SEL_IMG_READ_FMT_BC1 = 0x2e,
5031 TCP_PERF_SEL_IMG_READ_FMT_BC2 = 0x2f,
5032 TCP_PERF_SEL_IMG_READ_FMT_BC3 = 0x30,
5033 TCP_PERF_SEL_IMG_READ_FMT_BC4 = 0x31,
5034 TCP_PERF_SEL_IMG_READ_FMT_BC5 = 0x32,
5035 TCP_PERF_SEL_IMG_READ_FMT_BC6 = 0x33,
5036 TCP_PERF_SEL_IMG_READ_FMT_BC7 = 0x34,
5037 TCP_PERF_SEL_IMG_READ_FMT_I8 = 0x35,
5038 TCP_PERF_SEL_IMG_READ_FMT_I16 = 0x36,
5039 TCP_PERF_SEL_IMG_READ_FMT_I32 = 0x37,
5040 TCP_PERF_SEL_IMG_READ_FMT_I32_AS_8 = 0x38,
5041 TCP_PERF_SEL_IMG_READ_FMT_I32_AS_16 = 0x39,
5042 TCP_PERF_SEL_IMG_READ_FMT_D8 = 0x3a,
5043 TCP_PERF_SEL_IMG_READ_FMT_D16 = 0x3b,
5044 TCP_PERF_SEL_IMG_READ_FMT_D32 = 0x3c,
5045 TCP_PERF_SEL_IMG_WRITE_FMT_8 = 0x3d,
5046 TCP_PERF_SEL_IMG_WRITE_FMT_16 = 0x3e,
5047 TCP_PERF_SEL_IMG_WRITE_FMT_32 = 0x3f,
5048 TCP_PERF_SEL_IMG_WRITE_FMT_64 = 0x40,
5049 TCP_PERF_SEL_IMG_WRITE_FMT_128 = 0x41,
5050 TCP_PERF_SEL_IMG_WRITE_FMT_D8 = 0x42,
5051 TCP_PERF_SEL_IMG_WRITE_FMT_D16 = 0x43,
5052 TCP_PERF_SEL_IMG_WRITE_FMT_D32 = 0x44,
5053 TCP_PERF_SEL_IMG_ATOMIC_WITH_RET_FMT_32 = 0x45,
5054 TCP_PERF_SEL_IMG_ATOMIC_WITHOUT_RET_FMT_32 = 0x46,
5055 TCP_PERF_SEL_IMG_ATOMIC_WITH_RET_FMT_64 = 0x47,
5056 TCP_PERF_SEL_IMG_ATOMIC_WITHOUT_RET_FMT_64 = 0x48,
5057 TCP_PERF_SEL_BUF_READ_FMT_8 = 0x49,
5058 TCP_PERF_SEL_BUF_READ_FMT_16 = 0x4a,
5059 TCP_PERF_SEL_BUF_READ_FMT_32 = 0x4b,
5060 TCP_PERF_SEL_BUF_WRITE_FMT_8 = 0x4c,
5061 TCP_PERF_SEL_BUF_WRITE_FMT_16 = 0x4d,
5062 TCP_PERF_SEL_BUF_WRITE_FMT_32 = 0x4e,
5063 TCP_PERF_SEL_BUF_ATOMIC_WITH_RET_FMT_32 = 0x4f,
5064 TCP_PERF_SEL_BUF_ATOMIC_WITHOUT_RET_FMT_32 = 0x50,
5065 TCP_PERF_SEL_BUF_ATOMIC_WITH_RET_FMT_64 = 0x51,
5066 TCP_PERF_SEL_BUF_ATOMIC_WITHOUT_RET_FMT_64 = 0x52,
5067 TCP_PERF_SEL_ARR_LINEAR_GENERAL = 0x53,
5068 TCP_PERF_SEL_ARR_LINEAR_ALIGNED = 0x54,
5069 TCP_PERF_SEL_ARR_1D_THIN1 = 0x55,
5070 TCP_PERF_SEL_ARR_1D_THICK = 0x56,
5071 TCP_PERF_SEL_ARR_2D_THIN1 = 0x57,
5072 TCP_PERF_SEL_ARR_2D_THICK = 0x58,
5073 TCP_PERF_SEL_ARR_2D_XTHICK = 0x59,
5074 TCP_PERF_SEL_ARR_3D_THIN1 = 0x5a,
5075 TCP_PERF_SEL_ARR_3D_THICK = 0x5b,
5076 TCP_PERF_SEL_ARR_3D_XTHICK = 0x5c,
5077 TCP_PERF_SEL_DIM_1D = 0x5d,
5078 TCP_PERF_SEL_DIM_2D = 0x5e,
5079 TCP_PERF_SEL_DIM_3D = 0x5f,
5080 TCP_PERF_SEL_DIM_1D_ARRAY = 0x60,
5081 TCP_PERF_SEL_DIM_2D_ARRAY = 0x61,
5082 TCP_PERF_SEL_DIM_2D_MSAA = 0x62,
5083 TCP_PERF_SEL_DIM_2D_ARRAY_MSAA = 0x63,
5084 TCP_PERF_SEL_DIM_CUBE_ARRAY = 0x64,
5085 TCP_PERF_SEL_CP_TCP_INVALIDATE = 0x65,
5086 TCP_PERF_SEL_TA_TCP_STATE_READ = 0x66,
5087 TCP_PERF_SEL_TAGRAM0_REQ = 0x67,
5088 TCP_PERF_SEL_TAGRAM1_REQ = 0x68,
5089 TCP_PERF_SEL_TAGRAM2_REQ = 0x69,
5090 TCP_PERF_SEL_TAGRAM3_REQ = 0x6a,
5091 TCP_PERF_SEL_GATE_EN1 = 0x6b,
5092 TCP_PERF_SEL_GATE_EN2 = 0x6c,
5093 TCP_PERF_SEL_CORE_REG_SCLK_VLD = 0x6d,
5094 TCP_PERF_SEL_TCC_REQ = 0x6e,
5095 TCP_PERF_SEL_TCC_NON_READ_REQ = 0x6f,
5096 TCP_PERF_SEL_TCC_BYPASS_READ_REQ = 0x70,
5097 TCP_PERF_SEL_TCC_MISS_EVICT_READ_REQ = 0x71,
5098 TCP_PERF_SEL_TCC_VOLATILE_READ_REQ = 0x72,
5099 TCP_PERF_SEL_TCC_VOLATILE_BYPASS_READ_REQ = 0x73,
5100 TCP_PERF_SEL_TCC_VOLATILE_MISS_EVICT_READ_REQ = 0x74,
5101 TCP_PERF_SEL_TCC_BYPASS_WRITE_REQ = 0x75,
5102 TCP_PERF_SEL_TCC_MISS_EVICT_WRITE_REQ = 0x76,
5103 TCP_PERF_SEL_TCC_VOLATILE_BYPASS_WRITE_REQ = 0x77,
5104 TCP_PERF_SEL_TCC_VOLATILE_WRITE_REQ = 0x78,
5105 TCP_PERF_SEL_TCC_VOLATILE_MISS_EVICT_WRITE_REQ = 0x79,
5106 TCP_PERF_SEL_TCC_BYPASS_ATOMIC_REQ = 0x7a,
5107 TCP_PERF_SEL_TCC_ATOMIC_REQ = 0x7b,
5108 TCP_PERF_SEL_TCC_VOLATILE_ATOMIC_REQ = 0x7c,
5109 TCP_PERF_SEL_TCC_DATA_BUS_BUSY = 0x7d,
5110 TCP_PERF_SEL_TOTAL_ACCESSES = 0x7e,
5111 TCP_PERF_SEL_TOTAL_READ = 0x7f,
5112 TCP_PERF_SEL_TOTAL_HIT_LRU_READ = 0x80,
5113 TCP_PERF_SEL_TOTAL_HIT_EVICT_READ = 0x81,
5114 TCP_PERF_SEL_TOTAL_MISS_LRU_READ = 0x82,
5115 TCP_PERF_SEL_TOTAL_MISS_EVICT_READ = 0x83,
5116 TCP_PERF_SEL_TOTAL_NON_READ = 0x84,
5117 TCP_PERF_SEL_TOTAL_WRITE = 0x85,
5118 TCP_PERF_SEL_TOTAL_MISS_LRU_WRITE = 0x86,
5119 TCP_PERF_SEL_TOTAL_MISS_EVICT_WRITE = 0x87,
5120 TCP_PERF_SEL_TOTAL_WBINVL1_VOL = 0x88,
5121 TCP_PERF_SEL_TOTAL_WRITEBACK_INVALIDATES = 0x89,
5122 TCP_PERF_SEL_DISPLAY_MICROTILING = 0x8a,
5123 TCP_PERF_SEL_THIN_MICROTILING = 0x8b,
5124 TCP_PERF_SEL_DEPTH_MICROTILING = 0x8c,
5125 TCP_PERF_SEL_ARR_PRT_THIN1 = 0x8d,
5126 TCP_PERF_SEL_ARR_PRT_2D_THIN1 = 0x8e,
5127 TCP_PERF_SEL_ARR_PRT_3D_THIN1 = 0x8f,
5128 TCP_PERF_SEL_ARR_PRT_THICK = 0x90,
5129 TCP_PERF_SEL_ARR_PRT_2D_THICK = 0x91,
5130 TCP_PERF_SEL_ARR_PRT_3D_THICK = 0x92,
5131 TCP_PERF_SEL_CP_TCP_INVALIDATE_VOL = 0x93,
5132 TCP_PERF_SEL_SQ_TCP_INVALIDATE_VOL = 0x94,
5133 TCP_PERF_SEL_UNALIGNED = 0x95,
5134 TCP_PERF_SEL_ROTATED_MICROTILING = 0x96,
5135 TCP_PERF_SEL_THICK_MICROTILING = 0x97,
5136 TCP_PERF_SEL_ATC = 0x98,
5137 TCP_PERF_SEL_POWER_STALL = 0x99,
5138 TCP_PERF_SEL_RESERVED_154 = 0x9a,
5139 TCP_PERF_SEL_TCC_LRU_REQ = 0x9b,
5140 TCP_PERF_SEL_TCC_STREAM_REQ = 0x9c,
5141 TCP_PERF_SEL_TCC_NC_READ_REQ = 0x9d,
5142 TCP_PERF_SEL_TCC_NC_WRITE_REQ = 0x9e,
5143 TCP_PERF_SEL_TCC_NC_ATOMIC_REQ = 0x9f,
5144 TCP_PERF_SEL_TCC_UC_READ_REQ = 0xa0,
5145 TCP_PERF_SEL_TCC_UC_WRITE_REQ = 0xa1,
5146 TCP_PERF_SEL_TCC_UC_ATOMIC_REQ = 0xa2,
5147 TCP_PERF_SEL_TCC_CC_READ_REQ = 0xa3,
5148 TCP_PERF_SEL_TCC_CC_WRITE_REQ = 0xa4,
5149 TCP_PERF_SEL_TCC_CC_ATOMIC_REQ = 0xa5,
5150 TCP_PERF_SEL_TCC_DCC_REQ = 0xa6,
5151 TCP_PERF_SEL_TCC_PHYSICAL_REQ = 0xa7,
5152 TCP_PERF_SEL_UNORDERED_MTYPE_STALL = 0xa8,
5153 TCP_PERF_SEL_VOLATILE = 0xa9,
5154 TCP_PERF_SEL_TC_TA_XNACK_STALL = 0xaa,
5155 TCP_PERF_SEL_ATCL1_SERIALIZATION_STALL = 0xab,
5156 TCP_PERF_SEL_SHOOTDOWN = 0xac,
5157 TCP_PERF_SEL_GATCL1_TRANSLATION_MISS = 0xad,
5158 TCP_PERF_SEL_GATCL1_PERMISSION_MISS = 0xae,
5159 TCP_PERF_SEL_GATCL1_REQUEST = 0xaf,
5160 TCP_PERF_SEL_GATCL1_STALL_INFLIGHT_MAX = 0xb0,
5161 TCP_PERF_SEL_GATCL1_STALL_LRU_INFLIGHT = 0xb1,
5162 TCP_PERF_SEL_GATCL1_LFIFO_FULL = 0xb2,
5163 TCP_PERF_SEL_GATCL1_STALL_LFIFO_NOT_RES = 0xb3,
5164 TCP_PERF_SEL_GATCL1_STALL_ATCL2_REQ_OUT_OF_CREDITS= 0xb4,
5165 TCP_PERF_SEL_GATCL1_ATCL2_INFLIGHT = 0xb5,
5166 TCP_PERF_SEL_GATCL1_STALL_MISSFIFO_FULL = 0xb6,
5167 } TCP_PERFCOUNT_SELECT;
5168 typedef enum TCP_CACHE_POLICIES {
5169 TCP_CACHE_POLICY_MISS_LRU = 0x0,
5170 TCP_CACHE_POLICY_MISS_EVICT = 0x1,
5171 TCP_CACHE_POLICY_HIT_LRU = 0x2,
5172 TCP_CACHE_POLICY_HIT_EVICT = 0x3,
5173 } TCP_CACHE_POLICIES;
5174 typedef enum TCP_CACHE_STORE_POLICIES {
5175 TCP_CACHE_STORE_POLICY_WT_LRU = 0x0,
5176 TCP_CACHE_STORE_POLICY_WT_EVICT = 0x1,
5177 } TCP_CACHE_STORE_POLICIES;
5178 typedef enum TCP_WATCH_MODES {
5179 TCP_WATCH_MODE_READ = 0x0,
5180 TCP_WATCH_MODE_NONREAD = 0x1,
5181 TCP_WATCH_MODE_ATOMIC = 0x2,
5182 TCP_WATCH_MODE_ALL = 0x3,
5183 } TCP_WATCH_MODES;
5184 typedef enum TCP_DSM_DATA_SEL {
5185 TCP_DSM_DISABLE = 0x0,
5186 TCP_DSM_SEL0 = 0x1,
5187 TCP_DSM_SEL1 = 0x2,
5188 TCP_DSM_SEL_BOTH = 0x3,
5189 } TCP_DSM_DATA_SEL;
5190 typedef enum TCP_DSM_SINGLE_WRITE {
5191 TCP_DSM_SINGLE_WRITE_EN = 0x1,
5192 } TCP_DSM_SINGLE_WRITE;
5193 typedef enum VGT_OUT_PRIM_TYPE {
5194 VGT_OUT_POINT = 0x0,
5195 VGT_OUT_LINE = 0x1,
5196 VGT_OUT_TRI = 0x2,
5197 VGT_OUT_RECT_V0 = 0x3,
5198 VGT_OUT_RECT_V1 = 0x4,
5199 VGT_OUT_RECT_V2 = 0x5,
5200 VGT_OUT_RECT_V3 = 0x6,
5201 VGT_OUT_RESERVED = 0x7,
5202 VGT_TE_QUAD = 0x8,
5203 VGT_TE_PRIM_INDEX_LINE = 0x9,
5204 VGT_TE_PRIM_INDEX_TRI = 0xa,
5205 VGT_TE_PRIM_INDEX_QUAD = 0xb,
5206 VGT_OUT_LINE_ADJ = 0xc,
5207 VGT_OUT_TRI_ADJ = 0xd,
5208 VGT_OUT_PATCH = 0xe,
5209 } VGT_OUT_PRIM_TYPE;
5210 typedef enum VGT_DI_PRIM_TYPE {
5211 DI_PT_NONE = 0x0,
5212 DI_PT_POINTLIST = 0x1,
5213 DI_PT_LINELIST = 0x2,
5214 DI_PT_LINESTRIP = 0x3,
5215 DI_PT_TRILIST = 0x4,
5216 DI_PT_TRIFAN = 0x5,
5217 DI_PT_TRISTRIP = 0x6,
5218 DI_PT_UNUSED_0 = 0x7,
5219 DI_PT_UNUSED_1 = 0x8,
5220 DI_PT_PATCH = 0x9,
5221 DI_PT_LINELIST_ADJ = 0xa,
5222 DI_PT_LINESTRIP_ADJ = 0xb,
5223 DI_PT_TRILIST_ADJ = 0xc,
5224 DI_PT_TRISTRIP_ADJ = 0xd,
5225 DI_PT_UNUSED_3 = 0xe,
5226 DI_PT_UNUSED_4 = 0xf,
5227 DI_PT_TRI_WITH_WFLAGS = 0x10,
5228 DI_PT_RECTLIST = 0x11,
5229 DI_PT_LINELOOP = 0x12,
5230 DI_PT_QUADLIST = 0x13,
5231 DI_PT_QUADSTRIP = 0x14,
5232 DI_PT_POLYGON = 0x15,
5233 DI_PT_2D_COPY_RECT_LIST_V0 = 0x16,
5234 DI_PT_2D_COPY_RECT_LIST_V1 = 0x17,
5235 DI_PT_2D_COPY_RECT_LIST_V2 = 0x18,
5236 DI_PT_2D_COPY_RECT_LIST_V3 = 0x19,
5237 DI_PT_2D_FILL_RECT_LIST = 0x1a,
5238 DI_PT_2D_LINE_STRIP = 0x1b,
5239 DI_PT_2D_TRI_STRIP = 0x1c,
5240 } VGT_DI_PRIM_TYPE;
5241 typedef enum VGT_DI_SOURCE_SELECT {
5242 DI_SRC_SEL_DMA = 0x0,
5243 DI_SRC_SEL_IMMEDIATE = 0x1,
5244 DI_SRC_SEL_AUTO_INDEX = 0x2,
5245 DI_SRC_SEL_RESERVED = 0x3,
5246 } VGT_DI_SOURCE_SELECT;
5247 typedef enum VGT_DI_MAJOR_MODE_SELECT {
5248 DI_MAJOR_MODE_0 = 0x0,
5249 DI_MAJOR_MODE_1 = 0x1,
5250 } VGT_DI_MAJOR_MODE_SELECT;
5251 typedef enum VGT_DI_INDEX_SIZE {
5252 DI_INDEX_SIZE_16_BIT = 0x0,
5253 DI_INDEX_SIZE_32_BIT = 0x1,
5254 DI_INDEX_SIZE_8_BIT = 0x2,
5255 } VGT_DI_INDEX_SIZE;
5256 typedef enum VGT_EVENT_TYPE {
5257 Reserved_0x00 = 0x0,
5258 SAMPLE_STREAMOUTSTATS1 = 0x1,
5259 SAMPLE_STREAMOUTSTATS2 = 0x2,
5260 SAMPLE_STREAMOUTSTATS3 = 0x3,
5261 CACHE_FLUSH_TS = 0x4,
5262 CONTEXT_DONE = 0x5,
5263 CACHE_FLUSH = 0x6,
5264 CS_PARTIAL_FLUSH = 0x7,
5265 VGT_STREAMOUT_SYNC = 0x8,
5266 Reserved_0x09 = 0x9,
5267 VGT_STREAMOUT_RESET = 0xa,
5268 END_OF_PIPE_INCR_DE = 0xb,
5269 END_OF_PIPE_IB_END = 0xc,
5270 RST_PIX_CNT = 0xd,
5271 Reserved_0x0E = 0xe,
5272 VS_PARTIAL_FLUSH = 0xf,
5273 PS_PARTIAL_FLUSH = 0x10,
5274 FLUSH_HS_OUTPUT = 0x11,
5275 FLUSH_LS_OUTPUT = 0x12,
5276 Reserved_0x13 = 0x13,
5277 CACHE_FLUSH_AND_INV_TS_EVENT = 0x14,
5278 ZPASS_DONE = 0x15,
5279 CACHE_FLUSH_AND_INV_EVENT = 0x16,
5280 PERFCOUNTER_START = 0x17,
5281 PERFCOUNTER_STOP = 0x18,
5282 PIPELINESTAT_START = 0x19,
5283 PIPELINESTAT_STOP = 0x1a,
5284 PERFCOUNTER_SAMPLE = 0x1b,
5285 FLUSH_ES_OUTPUT = 0x1c,
5286 FLUSH_GS_OUTPUT = 0x1d,
5287 SAMPLE_PIPELINESTAT = 0x1e,
5288 SO_VGTSTREAMOUT_FLUSH = 0x1f,
5289 SAMPLE_STREAMOUTSTATS = 0x20,
5290 RESET_VTX_CNT = 0x21,
5291 BLOCK_CONTEXT_DONE = 0x22,
5292 CS_CONTEXT_DONE = 0x23,
5293 VGT_FLUSH = 0x24,
5294 TGID_ROLLOVER = 0x25,
5295 SQ_NON_EVENT = 0x26,
5296 SC_SEND_DB_VPZ = 0x27,
5297 BOTTOM_OF_PIPE_TS = 0x28,
5298 FLUSH_SX_TS = 0x29,
5299 DB_CACHE_FLUSH_AND_INV = 0x2a,
5300 FLUSH_AND_INV_DB_DATA_TS = 0x2b,
5301 FLUSH_AND_INV_DB_META = 0x2c,
5302 FLUSH_AND_INV_CB_DATA_TS = 0x2d,
5303 FLUSH_AND_INV_CB_META = 0x2e,
5304 CS_DONE = 0x2f,
5305 PS_DONE = 0x30,
5306 FLUSH_AND_INV_CB_PIXEL_DATA = 0x31,
5307 SX_CB_RAT_ACK_REQUEST = 0x32,
5308 THREAD_TRACE_START = 0x33,
5309 THREAD_TRACE_STOP = 0x34,
5310 THREAD_TRACE_MARKER = 0x35,
5311 THREAD_TRACE_FLUSH = 0x36,
5312 THREAD_TRACE_FINISH = 0x37,
5313 PIXEL_PIPE_STAT_CONTROL = 0x38,
5314 PIXEL_PIPE_STAT_DUMP = 0x39,
5315 PIXEL_PIPE_STAT_RESET = 0x3a,
5316 CONTEXT_SUSPEND = 0x3b,
5317 OFFCHIP_HS_DEALLOC = 0x3c,
5318 } VGT_EVENT_TYPE;
5319 typedef enum VGT_DMA_SWAP_MODE {
5320 VGT_DMA_SWAP_NONE = 0x0,
5321 VGT_DMA_SWAP_16_BIT = 0x1,
5322 VGT_DMA_SWAP_32_BIT = 0x2,
5323 VGT_DMA_SWAP_WORD = 0x3,
5324 } VGT_DMA_SWAP_MODE;
5325 typedef enum VGT_INDEX_TYPE_MODE {
5326 VGT_INDEX_16 = 0x0,
5327 VGT_INDEX_32 = 0x1,
5328 VGT_INDEX_8 = 0x2,
5329 } VGT_INDEX_TYPE_MODE;
5330 typedef enum VGT_DMA_BUF_TYPE {
5331 VGT_DMA_BUF_MEM = 0x0,
5332 VGT_DMA_BUF_RING = 0x1,
5333 VGT_DMA_BUF_SETUP = 0x2,
5334 VGT_DMA_PTR_UPDATE = 0x3,
5335 } VGT_DMA_BUF_TYPE;
5336 typedef enum VGT_OUTPATH_SELECT {
5337 VGT_OUTPATH_VTX_REUSE = 0x0,
5338 VGT_OUTPATH_TESS_EN = 0x1,
5339 VGT_OUTPATH_PASSTHRU = 0x2,
5340 VGT_OUTPATH_GS_BLOCK = 0x3,
5341 VGT_OUTPATH_HS_BLOCK = 0x4,
5342 } VGT_OUTPATH_SELECT;
5343 typedef enum VGT_GRP_PRIM_TYPE {
5344 VGT_GRP_3D_POINT = 0x0,
5345 VGT_GRP_3D_LINE = 0x1,
5346 VGT_GRP_3D_TRI = 0x2,
5347 VGT_GRP_3D_RECT = 0x3,
5348 VGT_GRP_3D_QUAD = 0x4,
5349 VGT_GRP_2D_COPY_RECT_V0 = 0x5,
5350 VGT_GRP_2D_COPY_RECT_V1 = 0x6,
5351 VGT_GRP_2D_COPY_RECT_V2 = 0x7,
5352 VGT_GRP_2D_COPY_RECT_V3 = 0x8,
5353 VGT_GRP_2D_FILL_RECT = 0x9,
5354 VGT_GRP_2D_LINE = 0xa,
5355 VGT_GRP_2D_TRI = 0xb,
5356 VGT_GRP_PRIM_INDEX_LINE = 0xc,
5357 VGT_GRP_PRIM_INDEX_TRI = 0xd,
5358 VGT_GRP_PRIM_INDEX_QUAD = 0xe,
5359 VGT_GRP_3D_LINE_ADJ = 0xf,
5360 VGT_GRP_3D_TRI_ADJ = 0x10,
5361 VGT_GRP_3D_PATCH = 0x11,
5362 } VGT_GRP_PRIM_TYPE;
5363 typedef enum VGT_GRP_PRIM_ORDER {
5364 VGT_GRP_LIST = 0x0,
5365 VGT_GRP_STRIP = 0x1,
5366 VGT_GRP_FAN = 0x2,
5367 VGT_GRP_LOOP = 0x3,
5368 VGT_GRP_POLYGON = 0x4,
5369 } VGT_GRP_PRIM_ORDER;
5370 typedef enum VGT_GROUP_CONV_SEL {
5371 VGT_GRP_INDEX_16 = 0x0,
5372 VGT_GRP_INDEX_32 = 0x1,
5373 VGT_GRP_UINT_16 = 0x2,
5374 VGT_GRP_UINT_32 = 0x3,
5375 VGT_GRP_SINT_16 = 0x4,
5376 VGT_GRP_SINT_32 = 0x5,
5377 VGT_GRP_FLOAT_32 = 0x6,
5378 VGT_GRP_AUTO_PRIM = 0x7,
5379 VGT_GRP_FIX_1_23_TO_FLOAT = 0x8,
5380 } VGT_GROUP_CONV_SEL;
5381 typedef enum VGT_GS_MODE_TYPE {
5382 GS_OFF = 0x0,
5383 GS_SCENARIO_A = 0x1,
5384 GS_SCENARIO_B = 0x2,
5385 GS_SCENARIO_G = 0x3,
5386 GS_SCENARIO_C = 0x4,
5387 SPRITE_EN = 0x5,
5388 } VGT_GS_MODE_TYPE;
5389 typedef enum VGT_GS_CUT_MODE {
5390 GS_CUT_1024 = 0x0,
5391 GS_CUT_512 = 0x1,
5392 GS_CUT_256 = 0x2,
5393 GS_CUT_128 = 0x3,
5394 } VGT_GS_CUT_MODE;
5395 typedef enum VGT_GS_OUTPRIM_TYPE {
5396 POINTLIST = 0x0,
5397 LINESTRIP = 0x1,
5398 TRISTRIP = 0x2,
5399 } VGT_GS_OUTPRIM_TYPE;
5400 typedef enum VGT_CACHE_INVALID_MODE {
5401 VC_ONLY = 0x0,
5402 TC_ONLY = 0x1,
5403 VC_AND_TC = 0x2,
5404 } VGT_CACHE_INVALID_MODE;
5405 typedef enum VGT_TESS_TYPE {
5406 TESS_ISOLINE = 0x0,
5407 TESS_TRIANGLE = 0x1,
5408 TESS_QUAD = 0x2,
5409 } VGT_TESS_TYPE;
5410 typedef enum VGT_TESS_PARTITION {
5411 PART_INTEGER = 0x0,
5412 PART_POW2 = 0x1,
5413 PART_FRAC_ODD = 0x2,
5414 PART_FRAC_EVEN = 0x3,
5415 } VGT_TESS_PARTITION;
5416 typedef enum VGT_TESS_TOPOLOGY {
5417 OUTPUT_POINT = 0x0,
5418 OUTPUT_LINE = 0x1,
5419 OUTPUT_TRIANGLE_CW = 0x2,
5420 OUTPUT_TRIANGLE_CCW = 0x3,
5421 } VGT_TESS_TOPOLOGY;
5422 typedef enum VGT_RDREQ_POLICY {
5423 VGT_POLICY_LRU = 0x0,
5424 VGT_POLICY_STREAM = 0x1,
5425 } VGT_RDREQ_POLICY;
5426 typedef enum VGT_DIST_MODE {
5427 NO_DIST = 0x0,
5428 PATCHES = 0x1,
5429 DONUTS = 0x2,
5430 } VGT_DIST_MODE;
5431 typedef enum VGT_STAGES_LS_EN {
5432 LS_STAGE_OFF = 0x0,
5433 LS_STAGE_ON = 0x1,
5434 CS_STAGE_ON = 0x2,
5435 RESERVED_LS = 0x3,
5436 } VGT_STAGES_LS_EN;
5437 typedef enum VGT_STAGES_HS_EN {
5438 HS_STAGE_OFF = 0x0,
5439 HS_STAGE_ON = 0x1,
5440 } VGT_STAGES_HS_EN;
5441 typedef enum VGT_STAGES_ES_EN {
5442 ES_STAGE_OFF = 0x0,
5443 ES_STAGE_DS = 0x1,
5444 ES_STAGE_REAL = 0x2,
5445 RESERVED_ES = 0x3,
5446 } VGT_STAGES_ES_EN;
5447 typedef enum VGT_STAGES_GS_EN {
5448 GS_STAGE_OFF = 0x0,
5449 GS_STAGE_ON = 0x1,
5450 } VGT_STAGES_GS_EN;
5451 typedef enum VGT_STAGES_VS_EN {
5452 VS_STAGE_REAL = 0x0,
5453 VS_STAGE_DS = 0x1,
5454 VS_STAGE_COPY_SHADER = 0x2,
5455 RESERVED_VS = 0x3,
5456 } VGT_STAGES_VS_EN;
5457 typedef enum VGT_PERFCOUNT_SELECT {
5458 vgt_perf_VGT_SPI_ESTHREAD_EVENT_WINDOW_ACTIVE = 0x0,
5459 vgt_perf_VGT_SPI_ESVERT_VALID = 0x1,
5460 vgt_perf_VGT_SPI_ESVERT_EOV = 0x2,
5461 vgt_perf_VGT_SPI_ESVERT_STALLED = 0x3,
5462 vgt_perf_VGT_SPI_ESVERT_STARVED_BUSY = 0x4,
5463 vgt_perf_VGT_SPI_ESVERT_STARVED_IDLE = 0x5,
5464 vgt_perf_VGT_SPI_ESVERT_STATIC = 0x6,
5465 vgt_perf_VGT_SPI_ESTHREAD_IS_EVENT = 0x7,
5466 vgt_perf_VGT_SPI_ESTHREAD_SEND = 0x8,
5467 vgt_perf_VGT_SPI_GSPRIM_VALID = 0x9,
5468 vgt_perf_VGT_SPI_GSPRIM_EOV = 0xa,
5469 vgt_perf_VGT_SPI_GSPRIM_CONT = 0xb,
5470 vgt_perf_VGT_SPI_GSPRIM_STALLED = 0xc,
5471 vgt_perf_VGT_SPI_GSPRIM_STARVED_BUSY = 0xd,
5472 vgt_perf_VGT_SPI_GSPRIM_STARVED_IDLE = 0xe,
5473 vgt_perf_VGT_SPI_GSPRIM_STATIC = 0xf,
5474 vgt_perf_VGT_SPI_GSTHREAD_EVENT_WINDOW_ACTIVE = 0x10,
5475 vgt_perf_VGT_SPI_GSTHREAD_IS_EVENT = 0x11,
5476 vgt_perf_VGT_SPI_GSTHREAD_SEND = 0x12,
5477 vgt_perf_VGT_SPI_VSTHREAD_EVENT_WINDOW_ACTIVE = 0x13,
5478 vgt_perf_VGT_SPI_VSVERT_SEND = 0x14,
5479 vgt_perf_VGT_SPI_VSVERT_EOV = 0x15,
5480 vgt_perf_VGT_SPI_VSVERT_STALLED = 0x16,
5481 vgt_perf_VGT_SPI_VSVERT_STARVED_BUSY = 0x17,
5482 vgt_perf_VGT_SPI_VSVERT_STARVED_IDLE = 0x18,
5483 vgt_perf_VGT_SPI_VSVERT_STATIC = 0x19,
5484 vgt_perf_VGT_SPI_VSTHREAD_IS_EVENT = 0x1a,
5485 vgt_perf_VGT_SPI_VSTHREAD_SEND = 0x1b,
5486 vgt_perf_VGT_PA_EVENT_WINDOW_ACTIVE = 0x1c,
5487 vgt_perf_VGT_PA_CLIPV_SEND = 0x1d,
5488 vgt_perf_VGT_PA_CLIPV_FIRSTVERT = 0x1e,
5489 vgt_perf_VGT_PA_CLIPV_STALLED = 0x1f,
5490 vgt_perf_VGT_PA_CLIPV_STARVED_BUSY = 0x20,
5491 vgt_perf_VGT_PA_CLIPV_STARVED_IDLE = 0x21,
5492 vgt_perf_VGT_PA_CLIPV_STATIC = 0x22,
5493 vgt_perf_VGT_PA_CLIPP_SEND = 0x23,
5494 vgt_perf_VGT_PA_CLIPP_EOP = 0x24,
5495 vgt_perf_VGT_PA_CLIPP_IS_EVENT = 0x25,
5496 vgt_perf_VGT_PA_CLIPP_NULL_PRIM = 0x26,
5497 vgt_perf_VGT_PA_CLIPP_NEW_VTX_VECT = 0x27,
5498 vgt_perf_VGT_PA_CLIPP_STALLED = 0x28,
5499 vgt_perf_VGT_PA_CLIPP_STARVED_BUSY = 0x29,
5500 vgt_perf_VGT_PA_CLIPP_STARVED_IDLE = 0x2a,
5501 vgt_perf_VGT_PA_CLIPP_STATIC = 0x2b,
5502 vgt_perf_VGT_PA_CLIPS_SEND = 0x2c,
5503 vgt_perf_VGT_PA_CLIPS_STALLED = 0x2d,
5504 vgt_perf_VGT_PA_CLIPS_STARVED_BUSY = 0x2e,
5505 vgt_perf_VGT_PA_CLIPS_STARVED_IDLE = 0x2f,
5506 vgt_perf_VGT_PA_CLIPS_STATIC = 0x30,
5507 vgt_perf_vsvert_ds_send = 0x31,
5508 vgt_perf_vsvert_api_send = 0x32,
5509 vgt_perf_hs_tif_stall = 0x33,
5510 vgt_perf_hs_input_stall = 0x34,
5511 vgt_perf_hs_interface_stall = 0x35,
5512 vgt_perf_hs_tfm_stall = 0x36,
5513 vgt_perf_te11_starved = 0x37,
5514 vgt_perf_gs_event_stall = 0x38,
5515 vgt_perf_vgt_pa_clipp_send_not_event = 0x39,
5516 vgt_perf_vgt_pa_clipp_valid_prim = 0x3a,
5517 vgt_perf_reused_es_indices = 0x3b,
5518 vgt_perf_vs_cache_hits = 0x3c,
5519 vgt_perf_gs_cache_hits = 0x3d,
5520 vgt_perf_ds_cache_hits = 0x3e,
5521 vgt_perf_total_cache_hits = 0x3f,
5522 vgt_perf_vgt_busy = 0x40,
5523 vgt_perf_vgt_gs_busy = 0x41,
5524 vgt_perf_esvert_stalled_es_tbl = 0x42,
5525 vgt_perf_esvert_stalled_gs_tbl = 0x43,
5526 vgt_perf_esvert_stalled_gs_event = 0x44,
5527 vgt_perf_esvert_stalled_gsprim = 0x45,
5528 vgt_perf_gsprim_stalled_es_tbl = 0x46,
5529 vgt_perf_gsprim_stalled_gs_tbl = 0x47,
5530 vgt_perf_gsprim_stalled_gs_event = 0x48,
5531 vgt_perf_gsprim_stalled_esvert = 0x49,
5532 vgt_perf_esthread_stalled_es_rb_full = 0x4a,
5533 vgt_perf_esthread_stalled_spi_bp = 0x4b,
5534 vgt_perf_counters_avail_stalled = 0x4c,
5535 vgt_perf_gs_rb_space_avail_stalled = 0x4d,
5536 vgt_perf_gs_issue_rtr_stalled = 0x4e,
5537 vgt_perf_gsthread_stalled = 0x4f,
5538 vgt_perf_strmout_stalled = 0x50,
5539 vgt_perf_wait_for_es_done_stalled = 0x51,
5540 vgt_perf_cm_stalled_by_gog = 0x52,
5541 vgt_perf_cm_reading_stalled = 0x53,
5542 vgt_perf_cm_stalled_by_gsfetch_done = 0x54,
5543 vgt_perf_gog_vs_tbl_stalled = 0x55,
5544 vgt_perf_gog_out_indx_stalled = 0x56,
5545 vgt_perf_gog_out_prim_stalled = 0x57,
5546 vgt_perf_waveid_stalled = 0x58,
5547 vgt_perf_gog_busy = 0x59,
5548 vgt_perf_reused_vs_indices = 0x5a,
5549 vgt_perf_sclk_reg_vld_event = 0x5b,
5550 vgt_perf_vs_conflicting_indices = 0x5c,
5551 vgt_perf_sclk_core_vld_event = 0x5d,
5552 vgt_perf_hswave_stalled = 0x5e,
5553 vgt_perf_sclk_gs_vld_event = 0x5f,
5554 vgt_perf_VGT_SPI_LSVERT_VALID = 0x60,
5555 vgt_perf_VGT_SPI_LSVERT_EOV = 0x61,
5556 vgt_perf_VGT_SPI_LSVERT_STALLED = 0x62,
5557 vgt_perf_VGT_SPI_LSVERT_STARVED_BUSY = 0x63,
5558 vgt_perf_VGT_SPI_LSVERT_STARVED_IDLE = 0x64,
5559 vgt_perf_VGT_SPI_LSVERT_STATIC = 0x65,
5560 vgt_perf_VGT_SPI_LSWAVE_EVENT_WINDOW_ACTIVE = 0x66,
5561 vgt_perf_VGT_SPI_LSWAVE_IS_EVENT = 0x67,
5562 vgt_perf_VGT_SPI_LSWAVE_SEND = 0x68,
5563 vgt_perf_VGT_SPI_HSVERT_VALID = 0x69,
5564 vgt_perf_VGT_SPI_HSVERT_EOV = 0x6a,
5565 vgt_perf_VGT_SPI_HSVERT_STALLED = 0x6b,
5566 vgt_perf_VGT_SPI_HSVERT_STARVED_BUSY = 0x6c,
5567 vgt_perf_VGT_SPI_HSVERT_STARVED_IDLE = 0x6d,
5568 vgt_perf_VGT_SPI_HSVERT_STATIC = 0x6e,
5569 vgt_perf_VGT_SPI_HSWAVE_EVENT_WINDOW_ACTIVE = 0x6f,
5570 vgt_perf_VGT_SPI_HSWAVE_IS_EVENT = 0x70,
5571 vgt_perf_VGT_SPI_HSWAVE_SEND = 0x71,
5572 vgt_perf_ds_prims = 0x72,
5573 vgt_perf_ls_thread_groups = 0x73,
5574 vgt_perf_hs_thread_groups = 0x74,
5575 vgt_perf_es_thread_groups = 0x75,
5576 vgt_perf_vs_thread_groups = 0x76,
5577 vgt_perf_ls_done_latency = 0x77,
5578 vgt_perf_hs_done_latency = 0x78,
5579 vgt_perf_es_done_latency = 0x79,
5580 vgt_perf_gs_done_latency = 0x7a,
5581 vgt_perf_vgt_hs_busy = 0x7b,
5582 vgt_perf_vgt_te11_busy = 0x7c,
5583 vgt_perf_ls_flush = 0x7d,
5584 vgt_perf_hs_flush = 0x7e,
5585 vgt_perf_es_flush = 0x7f,
5586 vgt_perf_vgt_pa_clipp_eopg = 0x80,
5587 vgt_perf_ls_done = 0x81,
5588 vgt_perf_hs_done = 0x82,
5589 vgt_perf_es_done = 0x83,
5590 vgt_perf_gs_done = 0x84,
5591 vgt_perf_vsfetch_done = 0x85,
5592 vgt_perf_gs_done_received = 0x86,
5593 vgt_perf_es_ring_high_water_mark = 0x87,
5594 vgt_perf_gs_ring_high_water_mark = 0x88,
5595 vgt_perf_vs_table_high_water_mark = 0x89,
5596 vgt_perf_hs_tgs_active_high_water_mark = 0x8a,
5597 vgt_perf_pa_clipp_dealloc = 0x8b,
5598 vgt_perf_cut_mem_flush_stalled = 0x8c,
5599 vgt_perf_vsvert_work_received = 0x8d,
5600 vgt_perf_vgt_pa_clipp_starved_after_work = 0x8e,
5601 vgt_perf_te11_con_starved_after_work = 0x8f,
5602 vgt_perf_hs_waiting_on_ls_done_stall = 0x90,
5603 vgt_spi_vsvert_valid = 0x91,
5604 } VGT_PERFCOUNT_SELECT;
5605 typedef enum IA_PERFCOUNT_SELECT {
5606 ia_perf_GRP_INPUT_EVENT_WINDOW_ACTIVE = 0x0,
5607 ia_perf_dma_data_fifo_full = 0x1,
5608 ia_perf_RESERVED1 = 0x2,
5609 ia_perf_RESERVED2 = 0x3,
5610 ia_perf_RESERVED3 = 0x4,
5611 ia_perf_RESERVED4 = 0x5,
5612 ia_perf_RESERVED5 = 0x6,
5613 ia_perf_MC_LAT_BIN_0 = 0x7,
5614 ia_perf_MC_LAT_BIN_1 = 0x8,
5615 ia_perf_MC_LAT_BIN_2 = 0x9,
5616 ia_perf_MC_LAT_BIN_3 = 0xa,
5617 ia_perf_MC_LAT_BIN_4 = 0xb,
5618 ia_perf_MC_LAT_BIN_5 = 0xc,
5619 ia_perf_MC_LAT_BIN_6 = 0xd,
5620 ia_perf_MC_LAT_BIN_7 = 0xe,
5621 ia_perf_ia_busy = 0xf,
5622 ia_perf_ia_sclk_reg_vld_event = 0x10,
5623 ia_perf_RESERVED6 = 0x11,
5624 ia_perf_ia_sclk_core_vld_event = 0x12,
5625 ia_perf_RESERVED7 = 0x13,
5626 ia_perf_ia_dma_return = 0x14,
5627 ia_perf_ia_stalled = 0x15,
5628 ia_perf_shift_starved_pipe0_event = 0x16,
5629 ia_perf_shift_starved_pipe1_event = 0x17,
5630 } IA_PERFCOUNT_SELECT;
5631 typedef enum WD_PERFCOUNT_SELECT {
5632 wd_perf_RBIU_FIFOS_EVENT_WINDOW_ACTIVE = 0x0,
5633 wd_perf_RBIU_DR_FIFO_STARVED = 0x1,
5634 wd_perf_RBIU_DR_FIFO_STALLED = 0x2,
5635 wd_perf_RBIU_DI_FIFO_STARVED = 0x3,
5636 wd_perf_RBIU_DI_FIFO_STALLED = 0x4,
5637 wd_perf_wd_busy = 0x5,
5638 wd_perf_wd_sclk_reg_vld_event = 0x6,
5639 wd_perf_wd_sclk_input_vld_event = 0x7,
5640 wd_perf_wd_sclk_core_vld_event = 0x8,
5641 wd_perf_wd_stalled = 0x9,
5642 wd_perf_inside_tf_bin_0 = 0xa,
5643 wd_perf_inside_tf_bin_1 = 0xb,
5644 wd_perf_inside_tf_bin_2 = 0xc,
5645 wd_perf_inside_tf_bin_3 = 0xd,
5646 wd_perf_inside_tf_bin_4 = 0xe,
5647 wd_perf_inside_tf_bin_5 = 0xf,
5648 wd_perf_inside_tf_bin_6 = 0x10,
5649 wd_perf_inside_tf_bin_7 = 0x11,
5650 wd_perf_inside_tf_bin_8 = 0x12,
5651 wd_perf_tfreq_lat_bin_0 = 0x13,
5652 wd_perf_tfreq_lat_bin_1 = 0x14,
5653 wd_perf_tfreq_lat_bin_2 = 0x15,
5654 wd_perf_tfreq_lat_bin_3 = 0x16,
5655 wd_perf_tfreq_lat_bin_4 = 0x17,
5656 wd_perf_tfreq_lat_bin_5 = 0x18,
5657 wd_perf_tfreq_lat_bin_6 = 0x19,
5658 wd_perf_tfreq_lat_bin_7 = 0x1a,
5659 wd_starved_on_hs_done = 0x1b,
5660 wd_perf_se0_hs_done_latency = 0x1c,
5661 wd_perf_se1_hs_done_latency = 0x1d,
5662 wd_perf_se2_hs_done_latency = 0x1e,
5663 wd_perf_se3_hs_done_latency = 0x1f,
5664 wd_perf_hs_done_se0 = 0x20,
5665 wd_perf_hs_done_se1 = 0x21,
5666 wd_perf_hs_done_se2 = 0x22,
5667 wd_perf_hs_done_se3 = 0x23,
5668 wd_perf_null_patches = 0x24,
5669 } WD_PERFCOUNT_SELECT;
5670 typedef enum WD_IA_DRAW_TYPE {
5671 WD_IA_DRAW_TYPE_DI_MM0 = 0x0,
5672 WD_IA_DRAW_TYPE_DI_MM1 = 0x1,
5673 WD_IA_DRAW_TYPE_EVENT_INIT = 0x2,
5674 WD_IA_DRAW_TYPE_EVENT_ADDR = 0x3,
5675 WD_IA_DRAW_TYPE_MIN_INDX = 0x4,
5676 WD_IA_DRAW_TYPE_MAX_INDX = 0x5,
5677 WD_IA_DRAW_TYPE_INDX_OFF = 0x6,
5678 WD_IA_DRAW_TYPE_IMM_DATA = 0x7,
5679 } WD_IA_DRAW_TYPE;
5680 typedef enum WD_IA_DRAW_SOURCE {
5681 WD_IA_DRAW_SOURCE_DMA = 0x0,
5682 WD_IA_DRAW_SOURCE_IMMD = 0x1,
5683 WD_IA_DRAW_SOURCE_AUTO = 0x2,
5684 WD_IA_DRAW_SOURCE_OPAQ = 0x3,
5685 } WD_IA_DRAW_SOURCE;
5686 #define GSTHREADID_SIZE 0x2
5687 typedef enum SurfaceEndian {
5688 ENDIAN_NONE = 0x0,
5689 ENDIAN_8IN16 = 0x1,
5690 ENDIAN_8IN32 = 0x2,
5691 ENDIAN_8IN64 = 0x3,
5692 } SurfaceEndian;
5693 typedef enum ArrayMode {
5694 ARRAY_LINEAR_GENERAL = 0x0,
5695 ARRAY_LINEAR_ALIGNED = 0x1,
5696 ARRAY_1D_TILED_THIN1 = 0x2,
5697 ARRAY_1D_TILED_THICK = 0x3,
5698 ARRAY_2D_TILED_THIN1 = 0x4,
5699 ARRAY_PRT_TILED_THIN1 = 0x5,
5700 ARRAY_PRT_2D_TILED_THIN1 = 0x6,
5701 ARRAY_2D_TILED_THICK = 0x7,
5702 ARRAY_2D_TILED_XTHICK = 0x8,
5703 ARRAY_PRT_TILED_THICK = 0x9,
5704 ARRAY_PRT_2D_TILED_THICK = 0xa,
5705 ARRAY_PRT_3D_TILED_THIN1 = 0xb,
5706 ARRAY_3D_TILED_THIN1 = 0xc,
5707 ARRAY_3D_TILED_THICK = 0xd,
5708 ARRAY_3D_TILED_XTHICK = 0xe,
5709 ARRAY_PRT_3D_TILED_THICK = 0xf,
5710 } ArrayMode;
5711 typedef enum PipeTiling {
5712 CONFIG_1_PIPE = 0x0,
5713 CONFIG_2_PIPE = 0x1,
5714 CONFIG_4_PIPE = 0x2,
5715 CONFIG_8_PIPE = 0x3,
5716 } PipeTiling;
5717 typedef enum BankTiling {
5718 CONFIG_4_BANK = 0x0,
5719 CONFIG_8_BANK = 0x1,
5720 } BankTiling;
5721 typedef enum GroupInterleave {
5722 CONFIG_256B_GROUP = 0x0,
5723 CONFIG_512B_GROUP = 0x1,
5724 } GroupInterleave;
5725 typedef enum RowTiling {
5726 CONFIG_1KB_ROW = 0x0,
5727 CONFIG_2KB_ROW = 0x1,
5728 CONFIG_4KB_ROW = 0x2,
5729 CONFIG_8KB_ROW = 0x3,
5730 CONFIG_1KB_ROW_OPT = 0x4,
5731 CONFIG_2KB_ROW_OPT = 0x5,
5732 CONFIG_4KB_ROW_OPT = 0x6,
5733 CONFIG_8KB_ROW_OPT = 0x7,
5734 } RowTiling;
5735 typedef enum BankSwapBytes {
5736 CONFIG_128B_SWAPS = 0x0,
5737 CONFIG_256B_SWAPS = 0x1,
5738 CONFIG_512B_SWAPS = 0x2,
5739 CONFIG_1KB_SWAPS = 0x3,
5740 } BankSwapBytes;
5741 typedef enum SampleSplitBytes {
5742 CONFIG_1KB_SPLIT = 0x0,
5743 CONFIG_2KB_SPLIT = 0x1,
5744 CONFIG_4KB_SPLIT = 0x2,
5745 CONFIG_8KB_SPLIT = 0x3,
5746 } SampleSplitBytes;
5747 typedef enum NumPipes {
5748 ADDR_CONFIG_1_PIPE = 0x0,
5749 ADDR_CONFIG_2_PIPE = 0x1,
5750 ADDR_CONFIG_4_PIPE = 0x2,
5751 ADDR_CONFIG_8_PIPE = 0x3,
5752 } NumPipes;
5753 typedef enum PipeInterleaveSize {
5754 ADDR_CONFIG_PIPE_INTERLEAVE_256B = 0x0,
5755 ADDR_CONFIG_PIPE_INTERLEAVE_512B = 0x1,
5756 } PipeInterleaveSize;
5757 typedef enum BankInterleaveSize {
5758 ADDR_CONFIG_BANK_INTERLEAVE_1 = 0x0,
5759 ADDR_CONFIG_BANK_INTERLEAVE_2 = 0x1,
5760 ADDR_CONFIG_BANK_INTERLEAVE_4 = 0x2,
5761 ADDR_CONFIG_BANK_INTERLEAVE_8 = 0x3,
5762 } BankInterleaveSize;
5763 typedef enum NumShaderEngines {
5764 ADDR_CONFIG_1_SHADER_ENGINE = 0x0,
5765 ADDR_CONFIG_2_SHADER_ENGINE = 0x1,
5766 } NumShaderEngines;
5767 typedef enum ShaderEngineTileSize {
5768 ADDR_CONFIG_SE_TILE_16 = 0x0,
5769 ADDR_CONFIG_SE_TILE_32 = 0x1,
5770 } ShaderEngineTileSize;
5771 typedef enum NumGPUs {
5772 ADDR_CONFIG_1_GPU = 0x0,
5773 ADDR_CONFIG_2_GPU = 0x1,
5774 ADDR_CONFIG_4_GPU = 0x2,
5775 } NumGPUs;
5776 typedef enum MultiGPUTileSize {
5777 ADDR_CONFIG_GPU_TILE_16 = 0x0,
5778 ADDR_CONFIG_GPU_TILE_32 = 0x1,
5779 ADDR_CONFIG_GPU_TILE_64 = 0x2,
5780 ADDR_CONFIG_GPU_TILE_128 = 0x3,
5781 } MultiGPUTileSize;
5782 typedef enum RowSize {
5783 ADDR_CONFIG_1KB_ROW = 0x0,
5784 ADDR_CONFIG_2KB_ROW = 0x1,
5785 ADDR_CONFIG_4KB_ROW = 0x2,
5786 } RowSize;
5787 typedef enum NumLowerPipes {
5788 ADDR_CONFIG_1_LOWER_PIPES = 0x0,
5789 ADDR_CONFIG_2_LOWER_PIPES = 0x1,
5790 } NumLowerPipes;
5791 typedef enum DebugBlockId {
5792 DBG_CLIENT_BLKID_RESERVED = 0x0,
5793 DBG_CLIENT_BLKID_dbg = 0x1,
5794 DBG_CLIENT_BLKID_scf2 = 0x2,
5795 DBG_CLIENT_BLKID_mcd5 = 0x3,
5796 DBG_CLIENT_BLKID_vmc = 0x4,
5797 DBG_CLIENT_BLKID_sx30 = 0x5,
5798 DBG_CLIENT_BLKID_mcd2 = 0x6,
5799 DBG_CLIENT_BLKID_bci1 = 0x7,
5800 DBG_CLIENT_BLKID_xdma_dbg_client_wrapper = 0x8,
5801 DBG_CLIENT_BLKID_mcc0 = 0x9,
5802 DBG_CLIENT_BLKID_uvdf_0 = 0xa,
5803 DBG_CLIENT_BLKID_uvdf_1 = 0xb,
5804 DBG_CLIENT_BLKID_uvdf_2 = 0xc,
5805 DBG_CLIENT_BLKID_uvdi_0 = 0xd,
5806 DBG_CLIENT_BLKID_bci0 = 0xe,
5807 DBG_CLIENT_BLKID_vcec0_0 = 0xf,
5808 DBG_CLIENT_BLKID_cb100 = 0x10,
5809 DBG_CLIENT_BLKID_cb001 = 0x11,
5810 DBG_CLIENT_BLKID_mcd4 = 0x12,
5811 DBG_CLIENT_BLKID_tmonw00 = 0x13,
5812 DBG_CLIENT_BLKID_cb101 = 0x14,
5813 DBG_CLIENT_BLKID_sx10 = 0x15,
5814 DBG_CLIENT_BLKID_cb301 = 0x16,
5815 DBG_CLIENT_BLKID_tmonw01 = 0x17,
5816 DBG_CLIENT_BLKID_vcea0_0 = 0x18,
5817 DBG_CLIENT_BLKID_vcea0_1 = 0x19,
5818 DBG_CLIENT_BLKID_vcea0_2 = 0x1a,
5819 DBG_CLIENT_BLKID_vcea0_3 = 0x1b,
5820 DBG_CLIENT_BLKID_scf1 = 0x1c,
5821 DBG_CLIENT_BLKID_sx20 = 0x1d,
5822 DBG_CLIENT_BLKID_spim1 = 0x1e,
5823 DBG_CLIENT_BLKID_pa10 = 0x1f,
5824 DBG_CLIENT_BLKID_pa00 = 0x20,
5825 DBG_CLIENT_BLKID_gmcon = 0x21,
5826 DBG_CLIENT_BLKID_mcb = 0x22,
5827 DBG_CLIENT_BLKID_vgt0 = 0x23,
5828 DBG_CLIENT_BLKID_pc0 = 0x24,
5829 DBG_CLIENT_BLKID_bci2 = 0x25,
5830 DBG_CLIENT_BLKID_uvdb_0 = 0x26,
5831 DBG_CLIENT_BLKID_spim3 = 0x27,
5832 DBG_CLIENT_BLKID_cpc_0 = 0x28,
5833 DBG_CLIENT_BLKID_cpc_1 = 0x29,
5834 DBG_CLIENT_BLKID_uvdm_0 = 0x2a,
5835 DBG_CLIENT_BLKID_uvdm_1 = 0x2b,
5836 DBG_CLIENT_BLKID_uvdm_2 = 0x2c,
5837 DBG_CLIENT_BLKID_uvdm_3 = 0x2d,
5838 DBG_CLIENT_BLKID_cb000 = 0x2e,
5839 DBG_CLIENT_BLKID_spim0 = 0x2f,
5840 DBG_CLIENT_BLKID_mcc2 = 0x30,
5841 DBG_CLIENT_BLKID_ds0 = 0x31,
5842 DBG_CLIENT_BLKID_srbm = 0x32,
5843 DBG_CLIENT_BLKID_ih = 0x33,
5844 DBG_CLIENT_BLKID_sem = 0x34,
5845 DBG_CLIENT_BLKID_sdma_0 = 0x35,
5846 DBG_CLIENT_BLKID_sdma_1 = 0x36,
5847 DBG_CLIENT_BLKID_hdp = 0x37,
5848 DBG_CLIENT_BLKID_acp_0 = 0x38,
5849 DBG_CLIENT_BLKID_acp_1 = 0x39,
5850 DBG_CLIENT_BLKID_cb200 = 0x3a,
5851 DBG_CLIENT_BLKID_scf3 = 0x3b,
5852 DBG_CLIENT_BLKID_vceb1_0 = 0x3c,
5853 DBG_CLIENT_BLKID_vcea1_0 = 0x3d,
5854 DBG_CLIENT_BLKID_vcea1_1 = 0x3e,
5855 DBG_CLIENT_BLKID_vcea1_2 = 0x3f,
5856 DBG_CLIENT_BLKID_vcea1_3 = 0x40,
5857 DBG_CLIENT_BLKID_bci3 = 0x41,
5858 DBG_CLIENT_BLKID_mcd0 = 0x42,
5859 DBG_CLIENT_BLKID_pa11 = 0x43,
5860 DBG_CLIENT_BLKID_pa01 = 0x44,
5861 DBG_CLIENT_BLKID_cb201 = 0x45,
5862 DBG_CLIENT_BLKID_spim2 = 0x46,
5863 DBG_CLIENT_BLKID_vgt2 = 0x47,
5864 DBG_CLIENT_BLKID_pc2 = 0x48,
5865 DBG_CLIENT_BLKID_smu_0 = 0x49,
5866 DBG_CLIENT_BLKID_smu_1 = 0x4a,
5867 DBG_CLIENT_BLKID_smu_2 = 0x4b,
5868 DBG_CLIENT_BLKID_cb1 = 0x4c,
5869 DBG_CLIENT_BLKID_ia0 = 0x4d,
5870 DBG_CLIENT_BLKID_wd = 0x4e,
5871 DBG_CLIENT_BLKID_ia1 = 0x4f,
5872 DBG_CLIENT_BLKID_vcec1_0 = 0x50,
5873 DBG_CLIENT_BLKID_scf0 = 0x51,
5874 DBG_CLIENT_BLKID_vgt1 = 0x52,
5875 DBG_CLIENT_BLKID_pc1 = 0x53,
5876 DBG_CLIENT_BLKID_cb0 = 0x54,
5877 DBG_CLIENT_BLKID_gdc_one_0 = 0x55,
5878 DBG_CLIENT_BLKID_gdc_one_1 = 0x56,
5879 DBG_CLIENT_BLKID_gdc_one_2 = 0x57,
5880 DBG_CLIENT_BLKID_gdc_one_3 = 0x58,
5881 DBG_CLIENT_BLKID_gdc_one_4 = 0x59,
5882 DBG_CLIENT_BLKID_gdc_one_5 = 0x5a,
5883 DBG_CLIENT_BLKID_gdc_one_6 = 0x5b,
5884 DBG_CLIENT_BLKID_gdc_one_7 = 0x5c,
5885 DBG_CLIENT_BLKID_gdc_one_8 = 0x5d,
5886 DBG_CLIENT_BLKID_gdc_one_9 = 0x5e,
5887 DBG_CLIENT_BLKID_gdc_one_10 = 0x5f,
5888 DBG_CLIENT_BLKID_gdc_one_11 = 0x60,
5889 DBG_CLIENT_BLKID_gdc_one_12 = 0x61,
5890 DBG_CLIENT_BLKID_gdc_one_13 = 0x62,
5891 DBG_CLIENT_BLKID_gdc_one_14 = 0x63,
5892 DBG_CLIENT_BLKID_gdc_one_15 = 0x64,
5893 DBG_CLIENT_BLKID_gdc_one_16 = 0x65,
5894 DBG_CLIENT_BLKID_gdc_one_17 = 0x66,
5895 DBG_CLIENT_BLKID_gdc_one_18 = 0x67,
5896 DBG_CLIENT_BLKID_gdc_one_19 = 0x68,
5897 DBG_CLIENT_BLKID_gdc_one_20 = 0x69,
5898 DBG_CLIENT_BLKID_gdc_one_21 = 0x6a,
5899 DBG_CLIENT_BLKID_gdc_one_22 = 0x6b,
5900 DBG_CLIENT_BLKID_gdc_one_23 = 0x6c,
5901 DBG_CLIENT_BLKID_gdc_one_24 = 0x6d,
5902 DBG_CLIENT_BLKID_gdc_one_25 = 0x6e,
5903 DBG_CLIENT_BLKID_gdc_one_26 = 0x6f,
5904 DBG_CLIENT_BLKID_gdc_one_27 = 0x70,
5905 DBG_CLIENT_BLKID_gdc_one_28 = 0x71,
5906 DBG_CLIENT_BLKID_gdc_one_29 = 0x72,
5907 DBG_CLIENT_BLKID_gdc_one_30 = 0x73,
5908 DBG_CLIENT_BLKID_gdc_one_31 = 0x74,
5909 DBG_CLIENT_BLKID_gdc_one_32 = 0x75,
5910 DBG_CLIENT_BLKID_gdc_one_33 = 0x76,
5911 DBG_CLIENT_BLKID_gdc_one_34 = 0x77,
5912 DBG_CLIENT_BLKID_gdc_one_35 = 0x78,
5913 DBG_CLIENT_BLKID_vceb0_0 = 0x79,
5914 DBG_CLIENT_BLKID_vgt3 = 0x7a,
5915 DBG_CLIENT_BLKID_pc3 = 0x7b,
5916 DBG_CLIENT_BLKID_mcd3 = 0x7c,
5917 DBG_CLIENT_BLKID_uvdu_0 = 0x7d,
5918 DBG_CLIENT_BLKID_uvdu_1 = 0x7e,
5919 DBG_CLIENT_BLKID_uvdu_2 = 0x7f,
5920 DBG_CLIENT_BLKID_uvdu_3 = 0x80,
5921 DBG_CLIENT_BLKID_uvdu_4 = 0x81,
5922 DBG_CLIENT_BLKID_uvdu_5 = 0x82,
5923 DBG_CLIENT_BLKID_uvdu_6 = 0x83,
5924 DBG_CLIENT_BLKID_cb300 = 0x84,
5925 DBG_CLIENT_BLKID_mcd1 = 0x85,
5926 DBG_CLIENT_BLKID_sx00 = 0x86,
5927 DBG_CLIENT_BLKID_uvdc_0 = 0x87,
5928 DBG_CLIENT_BLKID_uvdc_1 = 0x88,
5929 DBG_CLIENT_BLKID_mcc3 = 0x89,
5930 DBG_CLIENT_BLKID_cpg_0 = 0x8a,
5931 DBG_CLIENT_BLKID_cpg_1 = 0x8b,
5932 DBG_CLIENT_BLKID_gck = 0x8c,
5933 DBG_CLIENT_BLKID_mcc1 = 0x8d,
5934 DBG_CLIENT_BLKID_cpf_0 = 0x8e,
5935 DBG_CLIENT_BLKID_cpf_1 = 0x8f,
5936 DBG_CLIENT_BLKID_rlc = 0x90,
5937 DBG_CLIENT_BLKID_grbm = 0x91,
5938 DBG_CLIENT_BLKID_sammsp = 0x92,
5939 DBG_CLIENT_BLKID_dci_pg = 0x93,
5940 DBG_CLIENT_BLKID_dci_0 = 0x94,
5941 DBG_CLIENT_BLKID_dccg0_0 = 0x95,
5942 DBG_CLIENT_BLKID_dccg0_1 = 0x96,
5943 DBG_CLIENT_BLKID_dcfe01_0 = 0x97,
5944 DBG_CLIENT_BLKID_dcfe02_0 = 0x98,
5945 DBG_CLIENT_BLKID_dcfe03_0 = 0x99,
5946 DBG_CLIENT_BLKID_dcfe04_0 = 0x9a,
5947 DBG_CLIENT_BLKID_dcfe05_0 = 0x9b,
5948 DBG_CLIENT_BLKID_dcfe06_0 = 0x9c,
5949 DBG_CLIENT_BLKID_RESERVED_LAST = 0x9d,
5950 } DebugBlockId;
5951 typedef enum DebugBlockId_OLD {
5952 DBG_BLOCK_ID_RESERVED = 0x0,
5953 DBG_BLOCK_ID_DBG = 0x1,
5954 DBG_BLOCK_ID_VMC = 0x2,
5955 DBG_BLOCK_ID_PDMA = 0x3,
5956 DBG_BLOCK_ID_CG = 0x4,
5957 DBG_BLOCK_ID_SRBM = 0x5,
5958 DBG_BLOCK_ID_GRBM = 0x6,
5959 DBG_BLOCK_ID_RLC = 0x7,
5960 DBG_BLOCK_ID_CSC = 0x8,
5961 DBG_BLOCK_ID_SEM = 0x9,
5962 DBG_BLOCK_ID_IH = 0xa,
5963 DBG_BLOCK_ID_SC = 0xb,
5964 DBG_BLOCK_ID_SQ = 0xc,
5965 DBG_BLOCK_ID_AVP = 0xd,
5966 DBG_BLOCK_ID_GMCON = 0xe,
5967 DBG_BLOCK_ID_SMU = 0xf,
5968 DBG_BLOCK_ID_DMA0 = 0x10,
5969 DBG_BLOCK_ID_DMA1 = 0x11,
5970 DBG_BLOCK_ID_SPIM = 0x12,
5971 DBG_BLOCK_ID_GDS = 0x13,
5972 DBG_BLOCK_ID_SPIS = 0x14,
5973 DBG_BLOCK_ID_UNUSED0 = 0x15,
5974 DBG_BLOCK_ID_PA0 = 0x16,
5975 DBG_BLOCK_ID_PA1 = 0x17,
5976 DBG_BLOCK_ID_CP0 = 0x18,
5977 DBG_BLOCK_ID_CP1 = 0x19,
5978 DBG_BLOCK_ID_CP2 = 0x1a,
5979 DBG_BLOCK_ID_UNUSED1 = 0x1b,
5980 DBG_BLOCK_ID_UVDU = 0x1c,
5981 DBG_BLOCK_ID_UVDM = 0x1d,
5982 DBG_BLOCK_ID_VCE = 0x1e,
5983 DBG_BLOCK_ID_UNUSED2 = 0x1f,
5984 DBG_BLOCK_ID_VGT0 = 0x20,
5985 DBG_BLOCK_ID_VGT1 = 0x21,
5986 DBG_BLOCK_ID_IA = 0x22,
5987 DBG_BLOCK_ID_UNUSED3 = 0x23,
5988 DBG_BLOCK_ID_SCT0 = 0x24,
5989 DBG_BLOCK_ID_SCT1 = 0x25,
5990 DBG_BLOCK_ID_SPM0 = 0x26,
5991 DBG_BLOCK_ID_SPM1 = 0x27,
5992 DBG_BLOCK_ID_TCAA = 0x28,
5993 DBG_BLOCK_ID_TCAB = 0x29,
5994 DBG_BLOCK_ID_TCCA = 0x2a,
5995 DBG_BLOCK_ID_TCCB = 0x2b,
5996 DBG_BLOCK_ID_MCC0 = 0x2c,
5997 DBG_BLOCK_ID_MCC1 = 0x2d,
5998 DBG_BLOCK_ID_MCC2 = 0x2e,
5999 DBG_BLOCK_ID_MCC3 = 0x2f,
6000 DBG_BLOCK_ID_SX0 = 0x30,
6001 DBG_BLOCK_ID_SX1 = 0x31,
6002 DBG_BLOCK_ID_SX2 = 0x32,
6003 DBG_BLOCK_ID_SX3 = 0x33,
6004 DBG_BLOCK_ID_UNUSED4 = 0x34,
6005 DBG_BLOCK_ID_UNUSED5 = 0x35,
6006 DBG_BLOCK_ID_UNUSED6 = 0x36,
6007 DBG_BLOCK_ID_UNUSED7 = 0x37,
6008 DBG_BLOCK_ID_PC0 = 0x38,
6009 DBG_BLOCK_ID_PC1 = 0x39,
6010 DBG_BLOCK_ID_UNUSED8 = 0x3a,
6011 DBG_BLOCK_ID_UNUSED9 = 0x3b,
6012 DBG_BLOCK_ID_UNUSED10 = 0x3c,
6013 DBG_BLOCK_ID_UNUSED11 = 0x3d,
6014 DBG_BLOCK_ID_MCB = 0x3e,
6015 DBG_BLOCK_ID_UNUSED12 = 0x3f,
6016 DBG_BLOCK_ID_SCB0 = 0x40,
6017 DBG_BLOCK_ID_SCB1 = 0x41,
6018 DBG_BLOCK_ID_UNUSED13 = 0x42,
6019 DBG_BLOCK_ID_UNUSED14 = 0x43,
6020 DBG_BLOCK_ID_SCF0 = 0x44,
6021 DBG_BLOCK_ID_SCF1 = 0x45,
6022 DBG_BLOCK_ID_UNUSED15 = 0x46,
6023 DBG_BLOCK_ID_UNUSED16 = 0x47,
6024 DBG_BLOCK_ID_BCI0 = 0x48,
6025 DBG_BLOCK_ID_BCI1 = 0x49,
6026 DBG_BLOCK_ID_BCI2 = 0x4a,
6027 DBG_BLOCK_ID_BCI3 = 0x4b,
6028 DBG_BLOCK_ID_UNUSED17 = 0x4c,
6029 DBG_BLOCK_ID_UNUSED18 = 0x4d,
6030 DBG_BLOCK_ID_UNUSED19 = 0x4e,
6031 DBG_BLOCK_ID_UNUSED20 = 0x4f,
6032 DBG_BLOCK_ID_CB00 = 0x50,
6033 DBG_BLOCK_ID_CB01 = 0x51,
6034 DBG_BLOCK_ID_CB02 = 0x52,
6035 DBG_BLOCK_ID_CB03 = 0x53,
6036 DBG_BLOCK_ID_CB04 = 0x54,
6037 DBG_BLOCK_ID_UNUSED21 = 0x55,
6038 DBG_BLOCK_ID_UNUSED22 = 0x56,
6039 DBG_BLOCK_ID_UNUSED23 = 0x57,
6040 DBG_BLOCK_ID_CB10 = 0x58,
6041 DBG_BLOCK_ID_CB11 = 0x59,
6042 DBG_BLOCK_ID_CB12 = 0x5a,
6043 DBG_BLOCK_ID_CB13 = 0x5b,
6044 DBG_BLOCK_ID_CB14 = 0x5c,
6045 DBG_BLOCK_ID_UNUSED24 = 0x5d,
6046 DBG_BLOCK_ID_UNUSED25 = 0x5e,
6047 DBG_BLOCK_ID_UNUSED26 = 0x5f,
6048 DBG_BLOCK_ID_TCP0 = 0x60,
6049 DBG_BLOCK_ID_TCP1 = 0x61,
6050 DBG_BLOCK_ID_TCP2 = 0x62,
6051 DBG_BLOCK_ID_TCP3 = 0x63,
6052 DBG_BLOCK_ID_TCP4 = 0x64,
6053 DBG_BLOCK_ID_TCP5 = 0x65,
6054 DBG_BLOCK_ID_TCP6 = 0x66,
6055 DBG_BLOCK_ID_TCP7 = 0x67,
6056 DBG_BLOCK_ID_TCP8 = 0x68,
6057 DBG_BLOCK_ID_TCP9 = 0x69,
6058 DBG_BLOCK_ID_TCP10 = 0x6a,
6059 DBG_BLOCK_ID_TCP11 = 0x6b,
6060 DBG_BLOCK_ID_TCP12 = 0x6c,
6061 DBG_BLOCK_ID_TCP13 = 0x6d,
6062 DBG_BLOCK_ID_TCP14 = 0x6e,
6063 DBG_BLOCK_ID_TCP15 = 0x6f,
6064 DBG_BLOCK_ID_TCP16 = 0x70,
6065 DBG_BLOCK_ID_TCP17 = 0x71,
6066 DBG_BLOCK_ID_TCP18 = 0x72,
6067 DBG_BLOCK_ID_TCP19 = 0x73,
6068 DBG_BLOCK_ID_TCP20 = 0x74,
6069 DBG_BLOCK_ID_TCP21 = 0x75,
6070 DBG_BLOCK_ID_TCP22 = 0x76,
6071 DBG_BLOCK_ID_TCP23 = 0x77,
6072 DBG_BLOCK_ID_TCP_RESERVED0 = 0x78,
6073 DBG_BLOCK_ID_TCP_RESERVED1 = 0x79,
6074 DBG_BLOCK_ID_TCP_RESERVED2 = 0x7a,
6075 DBG_BLOCK_ID_TCP_RESERVED3 = 0x7b,
6076 DBG_BLOCK_ID_TCP_RESERVED4 = 0x7c,
6077 DBG_BLOCK_ID_TCP_RESERVED5 = 0x7d,
6078 DBG_BLOCK_ID_TCP_RESERVED6 = 0x7e,
6079 DBG_BLOCK_ID_TCP_RESERVED7 = 0x7f,
6080 DBG_BLOCK_ID_DB00 = 0x80,
6081 DBG_BLOCK_ID_DB01 = 0x81,
6082 DBG_BLOCK_ID_DB02 = 0x82,
6083 DBG_BLOCK_ID_DB03 = 0x83,
6084 DBG_BLOCK_ID_DB04 = 0x84,
6085 DBG_BLOCK_ID_UNUSED27 = 0x85,
6086 DBG_BLOCK_ID_UNUSED28 = 0x86,
6087 DBG_BLOCK_ID_UNUSED29 = 0x87,
6088 DBG_BLOCK_ID_DB10 = 0x88,
6089 DBG_BLOCK_ID_DB11 = 0x89,
6090 DBG_BLOCK_ID_DB12 = 0x8a,
6091 DBG_BLOCK_ID_DB13 = 0x8b,
6092 DBG_BLOCK_ID_DB14 = 0x8c,
6093 DBG_BLOCK_ID_UNUSED30 = 0x8d,
6094 DBG_BLOCK_ID_UNUSED31 = 0x8e,
6095 DBG_BLOCK_ID_UNUSED32 = 0x8f,
6096 DBG_BLOCK_ID_TCC0 = 0x90,
6097 DBG_BLOCK_ID_TCC1 = 0x91,
6098 DBG_BLOCK_ID_TCC2 = 0x92,
6099 DBG_BLOCK_ID_TCC3 = 0x93,
6100 DBG_BLOCK_ID_TCC4 = 0x94,
6101 DBG_BLOCK_ID_TCC5 = 0x95,
6102 DBG_BLOCK_ID_TCC6 = 0x96,
6103 DBG_BLOCK_ID_TCC7 = 0x97,
6104 DBG_BLOCK_ID_SPS00 = 0x98,
6105 DBG_BLOCK_ID_SPS01 = 0x99,
6106 DBG_BLOCK_ID_SPS02 = 0x9a,
6107 DBG_BLOCK_ID_SPS10 = 0x9b,
6108 DBG_BLOCK_ID_SPS11 = 0x9c,
6109 DBG_BLOCK_ID_SPS12 = 0x9d,
6110 DBG_BLOCK_ID_UNUSED33 = 0x9e,
6111 DBG_BLOCK_ID_UNUSED34 = 0x9f,
6112 DBG_BLOCK_ID_TA00 = 0xa0,
6113 DBG_BLOCK_ID_TA01 = 0xa1,
6114 DBG_BLOCK_ID_TA02 = 0xa2,
6115 DBG_BLOCK_ID_TA03 = 0xa3,
6116 DBG_BLOCK_ID_TA04 = 0xa4,
6117 DBG_BLOCK_ID_TA05 = 0xa5,
6118 DBG_BLOCK_ID_TA06 = 0xa6,
6119 DBG_BLOCK_ID_TA07 = 0xa7,
6120 DBG_BLOCK_ID_TA08 = 0xa8,
6121 DBG_BLOCK_ID_TA09 = 0xa9,
6122 DBG_BLOCK_ID_TA0A = 0xaa,
6123 DBG_BLOCK_ID_TA0B = 0xab,
6124 DBG_BLOCK_ID_UNUSED35 = 0xac,
6125 DBG_BLOCK_ID_UNUSED36 = 0xad,
6126 DBG_BLOCK_ID_UNUSED37 = 0xae,
6127 DBG_BLOCK_ID_UNUSED38 = 0xaf,
6128 DBG_BLOCK_ID_TA10 = 0xb0,
6129 DBG_BLOCK_ID_TA11 = 0xb1,
6130 DBG_BLOCK_ID_TA12 = 0xb2,
6131 DBG_BLOCK_ID_TA13 = 0xb3,
6132 DBG_BLOCK_ID_TA14 = 0xb4,
6133 DBG_BLOCK_ID_TA15 = 0xb5,
6134 DBG_BLOCK_ID_TA16 = 0xb6,
6135 DBG_BLOCK_ID_TA17 = 0xb7,
6136 DBG_BLOCK_ID_TA18 = 0xb8,
6137 DBG_BLOCK_ID_TA19 = 0xb9,
6138 DBG_BLOCK_ID_TA1A = 0xba,
6139 DBG_BLOCK_ID_TA1B = 0xbb,
6140 DBG_BLOCK_ID_UNUSED39 = 0xbc,
6141 DBG_BLOCK_ID_UNUSED40 = 0xbd,
6142 DBG_BLOCK_ID_UNUSED41 = 0xbe,
6143 DBG_BLOCK_ID_UNUSED42 = 0xbf,
6144 DBG_BLOCK_ID_TD00 = 0xc0,
6145 DBG_BLOCK_ID_TD01 = 0xc1,
6146 DBG_BLOCK_ID_TD02 = 0xc2,
6147 DBG_BLOCK_ID_TD03 = 0xc3,
6148 DBG_BLOCK_ID_TD04 = 0xc4,
6149 DBG_BLOCK_ID_TD05 = 0xc5,
6150 DBG_BLOCK_ID_TD06 = 0xc6,
6151 DBG_BLOCK_ID_TD07 = 0xc7,
6152 DBG_BLOCK_ID_TD08 = 0xc8,
6153 DBG_BLOCK_ID_TD09 = 0xc9,
6154 DBG_BLOCK_ID_TD0A = 0xca,
6155 DBG_BLOCK_ID_TD0B = 0xcb,
6156 DBG_BLOCK_ID_UNUSED43 = 0xcc,
6157 DBG_BLOCK_ID_UNUSED44 = 0xcd,
6158 DBG_BLOCK_ID_UNUSED45 = 0xce,
6159 DBG_BLOCK_ID_UNUSED46 = 0xcf,
6160 DBG_BLOCK_ID_TD10 = 0xd0,
6161 DBG_BLOCK_ID_TD11 = 0xd1,
6162 DBG_BLOCK_ID_TD12 = 0xd2,
6163 DBG_BLOCK_ID_TD13 = 0xd3,
6164 DBG_BLOCK_ID_TD14 = 0xd4,
6165 DBG_BLOCK_ID_TD15 = 0xd5,
6166 DBG_BLOCK_ID_TD16 = 0xd6,
6167 DBG_BLOCK_ID_TD17 = 0xd7,
6168 DBG_BLOCK_ID_TD18 = 0xd8,
6169 DBG_BLOCK_ID_TD19 = 0xd9,
6170 DBG_BLOCK_ID_TD1A = 0xda,
6171 DBG_BLOCK_ID_TD1B = 0xdb,
6172 DBG_BLOCK_ID_UNUSED47 = 0xdc,
6173 DBG_BLOCK_ID_UNUSED48 = 0xdd,
6174 DBG_BLOCK_ID_UNUSED49 = 0xde,
6175 DBG_BLOCK_ID_UNUSED50 = 0xdf,
6176 DBG_BLOCK_ID_MCD0 = 0xe0,
6177 DBG_BLOCK_ID_MCD1 = 0xe1,
6178 DBG_BLOCK_ID_MCD2 = 0xe2,
6179 DBG_BLOCK_ID_MCD3 = 0xe3,
6180 DBG_BLOCK_ID_MCD4 = 0xe4,
6181 DBG_BLOCK_ID_MCD5 = 0xe5,
6182 DBG_BLOCK_ID_UNUSED51 = 0xe6,
6183 DBG_BLOCK_ID_UNUSED52 = 0xe7,
6184 } DebugBlockId_OLD;
6185 typedef enum DebugBlockId_BY2 {
6186 DBG_BLOCK_ID_RESERVED_BY2 = 0x0,
6187 DBG_BLOCK_ID_VMC_BY2 = 0x1,
6188 DBG_BLOCK_ID_CG_BY2 = 0x2,
6189 DBG_BLOCK_ID_GRBM_BY2 = 0x3,
6190 DBG_BLOCK_ID_CSC_BY2 = 0x4,
6191 DBG_BLOCK_ID_IH_BY2 = 0x5,
6192 DBG_BLOCK_ID_SQ_BY2 = 0x6,
6193 DBG_BLOCK_ID_GMCON_BY2 = 0x7,
6194 DBG_BLOCK_ID_DMA0_BY2 = 0x8,
6195 DBG_BLOCK_ID_SPIM_BY2 = 0x9,
6196 DBG_BLOCK_ID_SPIS_BY2 = 0xa,
6197 DBG_BLOCK_ID_PA0_BY2 = 0xb,
6198 DBG_BLOCK_ID_CP0_BY2 = 0xc,
6199 DBG_BLOCK_ID_CP2_BY2 = 0xd,
6200 DBG_BLOCK_ID_UVDU_BY2 = 0xe,
6201 DBG_BLOCK_ID_VCE_BY2 = 0xf,
6202 DBG_BLOCK_ID_VGT0_BY2 = 0x10,
6203 DBG_BLOCK_ID_IA_BY2 = 0x11,
6204 DBG_BLOCK_ID_SCT0_BY2 = 0x12,
6205 DBG_BLOCK_ID_SPM0_BY2 = 0x13,
6206 DBG_BLOCK_ID_TCAA_BY2 = 0x14,
6207 DBG_BLOCK_ID_TCCA_BY2 = 0x15,
6208 DBG_BLOCK_ID_MCC0_BY2 = 0x16,
6209 DBG_BLOCK_ID_MCC2_BY2 = 0x17,
6210 DBG_BLOCK_ID_SX0_BY2 = 0x18,
6211 DBG_BLOCK_ID_SX2_BY2 = 0x19,
6212 DBG_BLOCK_ID_UNUSED4_BY2 = 0x1a,
6213 DBG_BLOCK_ID_UNUSED6_BY2 = 0x1b,
6214 DBG_BLOCK_ID_PC0_BY2 = 0x1c,
6215 DBG_BLOCK_ID_UNUSED8_BY2 = 0x1d,
6216 DBG_BLOCK_ID_UNUSED10_BY2 = 0x1e,
6217 DBG_BLOCK_ID_MCB_BY2 = 0x1f,
6218 DBG_BLOCK_ID_SCB0_BY2 = 0x20,
6219 DBG_BLOCK_ID_UNUSED13_BY2 = 0x21,
6220 DBG_BLOCK_ID_SCF0_BY2 = 0x22,
6221 DBG_BLOCK_ID_UNUSED15_BY2 = 0x23,
6222 DBG_BLOCK_ID_BCI0_BY2 = 0x24,
6223 DBG_BLOCK_ID_BCI2_BY2 = 0x25,
6224 DBG_BLOCK_ID_UNUSED17_BY2 = 0x26,
6225 DBG_BLOCK_ID_UNUSED19_BY2 = 0x27,
6226 DBG_BLOCK_ID_CB00_BY2 = 0x28,
6227 DBG_BLOCK_ID_CB02_BY2 = 0x29,
6228 DBG_BLOCK_ID_CB04_BY2 = 0x2a,
6229 DBG_BLOCK_ID_UNUSED22_BY2 = 0x2b,
6230 DBG_BLOCK_ID_CB10_BY2 = 0x2c,
6231 DBG_BLOCK_ID_CB12_BY2 = 0x2d,
6232 DBG_BLOCK_ID_CB14_BY2 = 0x2e,
6233 DBG_BLOCK_ID_UNUSED25_BY2 = 0x2f,
6234 DBG_BLOCK_ID_TCP0_BY2 = 0x30,
6235 DBG_BLOCK_ID_TCP2_BY2 = 0x31,
6236 DBG_BLOCK_ID_TCP4_BY2 = 0x32,
6237 DBG_BLOCK_ID_TCP6_BY2 = 0x33,
6238 DBG_BLOCK_ID_TCP8_BY2 = 0x34,
6239 DBG_BLOCK_ID_TCP10_BY2 = 0x35,
6240 DBG_BLOCK_ID_TCP12_BY2 = 0x36,
6241 DBG_BLOCK_ID_TCP14_BY2 = 0x37,
6242 DBG_BLOCK_ID_TCP16_BY2 = 0x38,
6243 DBG_BLOCK_ID_TCP18_BY2 = 0x39,
6244 DBG_BLOCK_ID_TCP20_BY2 = 0x3a,
6245 DBG_BLOCK_ID_TCP22_BY2 = 0x3b,
6246 DBG_BLOCK_ID_TCP_RESERVED0_BY2 = 0x3c,
6247 DBG_BLOCK_ID_TCP_RESERVED2_BY2 = 0x3d,
6248 DBG_BLOCK_ID_TCP_RESERVED4_BY2 = 0x3e,
6249 DBG_BLOCK_ID_TCP_RESERVED6_BY2 = 0x3f,
6250 DBG_BLOCK_ID_DB00_BY2 = 0x40,
6251 DBG_BLOCK_ID_DB02_BY2 = 0x41,
6252 DBG_BLOCK_ID_DB04_BY2 = 0x42,
6253 DBG_BLOCK_ID_UNUSED28_BY2 = 0x43,
6254 DBG_BLOCK_ID_DB10_BY2 = 0x44,
6255 DBG_BLOCK_ID_DB12_BY2 = 0x45,
6256 DBG_BLOCK_ID_DB14_BY2 = 0x46,
6257 DBG_BLOCK_ID_UNUSED31_BY2 = 0x47,
6258 DBG_BLOCK_ID_TCC0_BY2 = 0x48,
6259 DBG_BLOCK_ID_TCC2_BY2 = 0x49,
6260 DBG_BLOCK_ID_TCC4_BY2 = 0x4a,
6261 DBG_BLOCK_ID_TCC6_BY2 = 0x4b,
6262 DBG_BLOCK_ID_SPS00_BY2 = 0x4c,
6263 DBG_BLOCK_ID_SPS02_BY2 = 0x4d,
6264 DBG_BLOCK_ID_SPS11_BY2 = 0x4e,
6265 DBG_BLOCK_ID_UNUSED33_BY2 = 0x4f,
6266 DBG_BLOCK_ID_TA00_BY2 = 0x50,
6267 DBG_BLOCK_ID_TA02_BY2 = 0x51,
6268 DBG_BLOCK_ID_TA04_BY2 = 0x52,
6269 DBG_BLOCK_ID_TA06_BY2 = 0x53,
6270 DBG_BLOCK_ID_TA08_BY2 = 0x54,
6271 DBG_BLOCK_ID_TA0A_BY2 = 0x55,
6272 DBG_BLOCK_ID_UNUSED35_BY2 = 0x56,
6273 DBG_BLOCK_ID_UNUSED37_BY2 = 0x57,
6274 DBG_BLOCK_ID_TA10_BY2 = 0x58,
6275 DBG_BLOCK_ID_TA12_BY2 = 0x59,
6276 DBG_BLOCK_ID_TA14_BY2 = 0x5a,
6277 DBG_BLOCK_ID_TA16_BY2 = 0x5b,
6278 DBG_BLOCK_ID_TA18_BY2 = 0x5c,
6279 DBG_BLOCK_ID_TA1A_BY2 = 0x5d,
6280 DBG_BLOCK_ID_UNUSED39_BY2 = 0x5e,
6281 DBG_BLOCK_ID_UNUSED41_BY2 = 0x5f,
6282 DBG_BLOCK_ID_TD00_BY2 = 0x60,
6283 DBG_BLOCK_ID_TD02_BY2 = 0x61,
6284 DBG_BLOCK_ID_TD04_BY2 = 0x62,
6285 DBG_BLOCK_ID_TD06_BY2 = 0x63,
6286 DBG_BLOCK_ID_TD08_BY2 = 0x64,
6287 DBG_BLOCK_ID_TD0A_BY2 = 0x65,
6288 DBG_BLOCK_ID_UNUSED43_BY2 = 0x66,
6289 DBG_BLOCK_ID_UNUSED45_BY2 = 0x67,
6290 DBG_BLOCK_ID_TD10_BY2 = 0x68,
6291 DBG_BLOCK_ID_TD12_BY2 = 0x69,
6292 DBG_BLOCK_ID_TD14_BY2 = 0x6a,
6293 DBG_BLOCK_ID_TD16_BY2 = 0x6b,
6294 DBG_BLOCK_ID_TD18_BY2 = 0x6c,
6295 DBG_BLOCK_ID_TD1A_BY2 = 0x6d,
6296 DBG_BLOCK_ID_UNUSED47_BY2 = 0x6e,
6297 DBG_BLOCK_ID_UNUSED49_BY2 = 0x6f,
6298 DBG_BLOCK_ID_MCD0_BY2 = 0x70,
6299 DBG_BLOCK_ID_MCD2_BY2 = 0x71,
6300 DBG_BLOCK_ID_MCD4_BY2 = 0x72,
6301 DBG_BLOCK_ID_UNUSED51_BY2 = 0x73,
6302 } DebugBlockId_BY2;
6303 typedef enum DebugBlockId_BY4 {
6304 DBG_BLOCK_ID_RESERVED_BY4 = 0x0,
6305 DBG_BLOCK_ID_CG_BY4 = 0x1,
6306 DBG_BLOCK_ID_CSC_BY4 = 0x2,
6307 DBG_BLOCK_ID_SQ_BY4 = 0x3,
6308 DBG_BLOCK_ID_DMA0_BY4 = 0x4,
6309 DBG_BLOCK_ID_SPIS_BY4 = 0x5,
6310 DBG_BLOCK_ID_CP0_BY4 = 0x6,
6311 DBG_BLOCK_ID_UVDU_BY4 = 0x7,
6312 DBG_BLOCK_ID_VGT0_BY4 = 0x8,
6313 DBG_BLOCK_ID_SCT0_BY4 = 0x9,
6314 DBG_BLOCK_ID_TCAA_BY4 = 0xa,
6315 DBG_BLOCK_ID_MCC0_BY4 = 0xb,
6316 DBG_BLOCK_ID_SX0_BY4 = 0xc,
6317 DBG_BLOCK_ID_UNUSED4_BY4 = 0xd,
6318 DBG_BLOCK_ID_PC0_BY4 = 0xe,
6319 DBG_BLOCK_ID_UNUSED10_BY4 = 0xf,
6320 DBG_BLOCK_ID_SCB0_BY4 = 0x10,
6321 DBG_BLOCK_ID_SCF0_BY4 = 0x11,
6322 DBG_BLOCK_ID_BCI0_BY4 = 0x12,
6323 DBG_BLOCK_ID_UNUSED17_BY4 = 0x13,
6324 DBG_BLOCK_ID_CB00_BY4 = 0x14,
6325 DBG_BLOCK_ID_CB04_BY4 = 0x15,
6326 DBG_BLOCK_ID_CB10_BY4 = 0x16,
6327 DBG_BLOCK_ID_CB14_BY4 = 0x17,
6328 DBG_BLOCK_ID_TCP0_BY4 = 0x18,
6329 DBG_BLOCK_ID_TCP4_BY4 = 0x19,
6330 DBG_BLOCK_ID_TCP8_BY4 = 0x1a,
6331 DBG_BLOCK_ID_TCP12_BY4 = 0x1b,
6332 DBG_BLOCK_ID_TCP16_BY4 = 0x1c,
6333 DBG_BLOCK_ID_TCP20_BY4 = 0x1d,
6334 DBG_BLOCK_ID_TCP_RESERVED0_BY4 = 0x1e,
6335 DBG_BLOCK_ID_TCP_RESERVED4_BY4 = 0x1f,
6336 DBG_BLOCK_ID_DB_BY4 = 0x20,
6337 DBG_BLOCK_ID_DB04_BY4 = 0x21,
6338 DBG_BLOCK_ID_DB10_BY4 = 0x22,
6339 DBG_BLOCK_ID_DB14_BY4 = 0x23,
6340 DBG_BLOCK_ID_TCC0_BY4 = 0x24,
6341 DBG_BLOCK_ID_TCC4_BY4 = 0x25,
6342 DBG_BLOCK_ID_SPS00_BY4 = 0x26,
6343 DBG_BLOCK_ID_SPS11_BY4 = 0x27,
6344 DBG_BLOCK_ID_TA00_BY4 = 0x28,
6345 DBG_BLOCK_ID_TA04_BY4 = 0x29,
6346 DBG_BLOCK_ID_TA08_BY4 = 0x2a,
6347 DBG_BLOCK_ID_UNUSED35_BY4 = 0x2b,
6348 DBG_BLOCK_ID_TA10_BY4 = 0x2c,
6349 DBG_BLOCK_ID_TA14_BY4 = 0x2d,
6350 DBG_BLOCK_ID_TA18_BY4 = 0x2e,
6351 DBG_BLOCK_ID_UNUSED39_BY4 = 0x2f,
6352 DBG_BLOCK_ID_TD00_BY4 = 0x30,
6353 DBG_BLOCK_ID_TD04_BY4 = 0x31,
6354 DBG_BLOCK_ID_TD08_BY4 = 0x32,
6355 DBG_BLOCK_ID_UNUSED43_BY4 = 0x33,
6356 DBG_BLOCK_ID_TD10_BY4 = 0x34,
6357 DBG_BLOCK_ID_TD14_BY4 = 0x35,
6358 DBG_BLOCK_ID_TD18_BY4 = 0x36,
6359 DBG_BLOCK_ID_UNUSED47_BY4 = 0x37,
6360 DBG_BLOCK_ID_MCD0_BY4 = 0x38,
6361 DBG_BLOCK_ID_MCD4_BY4 = 0x39,
6362 } DebugBlockId_BY4;
6363 typedef enum DebugBlockId_BY8 {
6364 DBG_BLOCK_ID_RESERVED_BY8 = 0x0,
6365 DBG_BLOCK_ID_CSC_BY8 = 0x1,
6366 DBG_BLOCK_ID_DMA0_BY8 = 0x2,
6367 DBG_BLOCK_ID_CP0_BY8 = 0x3,
6368 DBG_BLOCK_ID_VGT0_BY8 = 0x4,
6369 DBG_BLOCK_ID_TCAA_BY8 = 0x5,
6370 DBG_BLOCK_ID_SX0_BY8 = 0x6,
6371 DBG_BLOCK_ID_PC0_BY8 = 0x7,
6372 DBG_BLOCK_ID_SCB0_BY8 = 0x8,
6373 DBG_BLOCK_ID_BCI0_BY8 = 0x9,
6374 DBG_BLOCK_ID_CB00_BY8 = 0xa,
6375 DBG_BLOCK_ID_CB10_BY8 = 0xb,
6376 DBG_BLOCK_ID_TCP0_BY8 = 0xc,
6377 DBG_BLOCK_ID_TCP8_BY8 = 0xd,
6378 DBG_BLOCK_ID_TCP16_BY8 = 0xe,
6379 DBG_BLOCK_ID_TCP_RESERVED0_BY8 = 0xf,
6380 DBG_BLOCK_ID_DB00_BY8 = 0x10,
6381 DBG_BLOCK_ID_DB10_BY8 = 0x11,
6382 DBG_BLOCK_ID_TCC0_BY8 = 0x12,
6383 DBG_BLOCK_ID_SPS00_BY8 = 0x13,
6384 DBG_BLOCK_ID_TA00_BY8 = 0x14,
6385 DBG_BLOCK_ID_TA08_BY8 = 0x15,
6386 DBG_BLOCK_ID_TA10_BY8 = 0x16,
6387 DBG_BLOCK_ID_TA18_BY8 = 0x17,
6388 DBG_BLOCK_ID_TD00_BY8 = 0x18,
6389 DBG_BLOCK_ID_TD08_BY8 = 0x19,
6390 DBG_BLOCK_ID_TD10_BY8 = 0x1a,
6391 DBG_BLOCK_ID_TD18_BY8 = 0x1b,
6392 DBG_BLOCK_ID_MCD0_BY8 = 0x1c,
6393 } DebugBlockId_BY8;
6394 typedef enum DebugBlockId_BY16 {
6395 DBG_BLOCK_ID_RESERVED_BY16 = 0x0,
6396 DBG_BLOCK_ID_DMA0_BY16 = 0x1,
6397 DBG_BLOCK_ID_VGT0_BY16 = 0x2,
6398 DBG_BLOCK_ID_SX0_BY16 = 0x3,
6399 DBG_BLOCK_ID_SCB0_BY16 = 0x4,
6400 DBG_BLOCK_ID_CB00_BY16 = 0x5,
6401 DBG_BLOCK_ID_TCP0_BY16 = 0x6,
6402 DBG_BLOCK_ID_TCP16_BY16 = 0x7,
6403 DBG_BLOCK_ID_DB00_BY16 = 0x8,
6404 DBG_BLOCK_ID_TCC0_BY16 = 0x9,
6405 DBG_BLOCK_ID_TA00_BY16 = 0xa,
6406 DBG_BLOCK_ID_TA10_BY16 = 0xb,
6407 DBG_BLOCK_ID_TD00_BY16 = 0xc,
6408 DBG_BLOCK_ID_TD10_BY16 = 0xd,
6409 DBG_BLOCK_ID_MCD0_BY16 = 0xe,
6410 } DebugBlockId_BY16;
6411 typedef enum ColorTransform {
6412 DCC_CT_AUTO = 0x0,
6413 DCC_CT_NONE = 0x1,
6414 ABGR_TO_A_BG_G_RB = 0x2,
6415 BGRA_TO_BG_G_RB_A = 0x3,
6416 } ColorTransform;
6417 typedef enum CompareRef {
6418 REF_NEVER = 0x0,
6419 REF_LESS = 0x1,
6420 REF_EQUAL = 0x2,
6421 REF_LEQUAL = 0x3,
6422 REF_GREATER = 0x4,
6423 REF_NOTEQUAL = 0x5,
6424 REF_GEQUAL = 0x6,
6425 REF_ALWAYS = 0x7,
6426 } CompareRef;
6427 typedef enum ReadSize {
6428 READ_256_BITS = 0x0,
6429 READ_512_BITS = 0x1,
6430 } ReadSize;
6431 typedef enum DepthFormat {
6432 DEPTH_INVALID = 0x0,
6433 DEPTH_16 = 0x1,
6434 DEPTH_X8_24 = 0x2,
6435 DEPTH_8_24 = 0x3,
6436 DEPTH_X8_24_FLOAT = 0x4,
6437 DEPTH_8_24_FLOAT = 0x5,
6438 DEPTH_32_FLOAT = 0x6,
6439 DEPTH_X24_8_32_FLOAT = 0x7,
6440 } DepthFormat;
6441 typedef enum ZFormat {
6442 Z_INVALID = 0x0,
6443 Z_16 = 0x1,
6444 Z_24 = 0x2,
6445 Z_32_FLOAT = 0x3,
6446 } ZFormat;
6447 typedef enum StencilFormat {
6448 STENCIL_INVALID = 0x0,
6449 STENCIL_8 = 0x1,
6450 } StencilFormat;
6451 typedef enum CmaskMode {
6452 CMASK_CLEAR_NONE = 0x0,
6453 CMASK_CLEAR_ONE = 0x1,
6454 CMASK_CLEAR_ALL = 0x2,
6455 CMASK_ANY_EXPANDED = 0x3,
6456 CMASK_ALPHA0_FRAG1 = 0x4,
6457 CMASK_ALPHA0_FRAG2 = 0x5,
6458 CMASK_ALPHA0_FRAG4 = 0x6,
6459 CMASK_ALPHA0_FRAGS = 0x7,
6460 CMASK_ALPHA1_FRAG1 = 0x8,
6461 CMASK_ALPHA1_FRAG2 = 0x9,
6462 CMASK_ALPHA1_FRAG4 = 0xa,
6463 CMASK_ALPHA1_FRAGS = 0xb,
6464 CMASK_ALPHAX_FRAG1 = 0xc,
6465 CMASK_ALPHAX_FRAG2 = 0xd,
6466 CMASK_ALPHAX_FRAG4 = 0xe,
6467 CMASK_ALPHAX_FRAGS = 0xf,
6468 } CmaskMode;
6469 typedef enum QuadExportFormat {
6470 EXPORT_UNUSED = 0x0,
6471 EXPORT_32_R = 0x1,
6472 EXPORT_32_GR = 0x2,
6473 EXPORT_32_AR = 0x3,
6474 EXPORT_FP16_ABGR = 0x4,
6475 EXPORT_UNSIGNED16_ABGR = 0x5,
6476 EXPORT_SIGNED16_ABGR = 0x6,
6477 EXPORT_32_ABGR = 0x7,
6478 } QuadExportFormat;
6479 typedef enum QuadExportFormatOld {
6480 EXPORT_4P_32BPC_ABGR = 0x0,
6481 EXPORT_4P_16BPC_ABGR = 0x1,
6482 EXPORT_4P_32BPC_GR = 0x2,
6483 EXPORT_4P_32BPC_AR = 0x3,
6484 EXPORT_2P_32BPC_ABGR = 0x4,
6485 EXPORT_8P_32BPC_R = 0x5,
6486 } QuadExportFormatOld;
6487 typedef enum ColorFormat {
6488 COLOR_INVALID = 0x0,
6489 COLOR_8 = 0x1,
6490 COLOR_16 = 0x2,
6491 COLOR_8_8 = 0x3,
6492 COLOR_32 = 0x4,
6493 COLOR_16_16 = 0x5,
6494 COLOR_10_11_11 = 0x6,
6495 COLOR_11_11_10 = 0x7,
6496 COLOR_10_10_10_2 = 0x8,
6497 COLOR_2_10_10_10 = 0x9,
6498 COLOR_8_8_8_8 = 0xa,
6499 COLOR_32_32 = 0xb,
6500 COLOR_16_16_16_16 = 0xc,
6501 COLOR_RESERVED_13 = 0xd,
6502 COLOR_32_32_32_32 = 0xe,
6503 COLOR_RESERVED_15 = 0xf,
6504 COLOR_5_6_5 = 0x10,
6505 COLOR_1_5_5_5 = 0x11,
6506 COLOR_5_5_5_1 = 0x12,
6507 COLOR_4_4_4_4 = 0x13,
6508 COLOR_8_24 = 0x14,
6509 COLOR_24_8 = 0x15,
6510 COLOR_X24_8_32_FLOAT = 0x16,
6511 COLOR_RESERVED_23 = 0x17,
6512 } ColorFormat;
6513 typedef enum SurfaceFormat {
6514 FMT_INVALID = 0x0,
6515 FMT_8 = 0x1,
6516 FMT_16 = 0x2,
6517 FMT_8_8 = 0x3,
6518 FMT_32 = 0x4,
6519 FMT_16_16 = 0x5,
6520 FMT_10_11_11 = 0x6,
6521 FMT_11_11_10 = 0x7,
6522 FMT_10_10_10_2 = 0x8,
6523 FMT_2_10_10_10 = 0x9,
6524 FMT_8_8_8_8 = 0xa,
6525 FMT_32_32 = 0xb,
6526 FMT_16_16_16_16 = 0xc,
6527 FMT_32_32_32 = 0xd,
6528 FMT_32_32_32_32 = 0xe,
6529 FMT_RESERVED_4 = 0xf,
6530 FMT_5_6_5 = 0x10,
6531 FMT_1_5_5_5 = 0x11,
6532 FMT_5_5_5_1 = 0x12,
6533 FMT_4_4_4_4 = 0x13,
6534 FMT_8_24 = 0x14,
6535 FMT_24_8 = 0x15,
6536 FMT_X24_8_32_FLOAT = 0x16,
6537 FMT_RESERVED_33 = 0x17,
6538 FMT_11_11_10_FLOAT = 0x18,
6539 FMT_16_FLOAT = 0x19,
6540 FMT_32_FLOAT = 0x1a,
6541 FMT_16_16_FLOAT = 0x1b,
6542 FMT_8_24_FLOAT = 0x1c,
6543 FMT_24_8_FLOAT = 0x1d,
6544 FMT_32_32_FLOAT = 0x1e,
6545 FMT_10_11_11_FLOAT = 0x1f,
6546 FMT_16_16_16_16_FLOAT = 0x20,
6547 FMT_3_3_2 = 0x21,
6548 FMT_6_5_5 = 0x22,
6549 FMT_32_32_32_32_FLOAT = 0x23,
6550 FMT_RESERVED_36 = 0x24,
6551 FMT_1 = 0x25,
6552 FMT_1_REVERSED = 0x26,
6553 FMT_GB_GR = 0x27,
6554 FMT_BG_RG = 0x28,
6555 FMT_32_AS_8 = 0x29,
6556 FMT_32_AS_8_8 = 0x2a,
6557 FMT_5_9_9_9_SHAREDEXP = 0x2b,
6558 FMT_8_8_8 = 0x2c,
6559 FMT_16_16_16 = 0x2d,
6560 FMT_16_16_16_FLOAT = 0x2e,
6561 FMT_4_4 = 0x2f,
6562 FMT_32_32_32_FLOAT = 0x30,
6563 FMT_BC1 = 0x31,
6564 FMT_BC2 = 0x32,
6565 FMT_BC3 = 0x33,
6566 FMT_BC4 = 0x34,
6567 FMT_BC5 = 0x35,
6568 FMT_BC6 = 0x36,
6569 FMT_BC7 = 0x37,
6570 FMT_32_AS_32_32_32_32 = 0x38,
6571 FMT_APC3 = 0x39,
6572 FMT_APC4 = 0x3a,
6573 FMT_APC5 = 0x3b,
6574 FMT_APC6 = 0x3c,
6575 FMT_APC7 = 0x3d,
6576 FMT_CTX1 = 0x3e,
6577 FMT_RESERVED_63 = 0x3f,
6578 } SurfaceFormat;
6579 typedef enum BUF_DATA_FORMAT {
6580 BUF_DATA_FORMAT_INVALID = 0x0,
6581 BUF_DATA_FORMAT_8 = 0x1,
6582 BUF_DATA_FORMAT_16 = 0x2,
6583 BUF_DATA_FORMAT_8_8 = 0x3,
6584 BUF_DATA_FORMAT_32 = 0x4,
6585 BUF_DATA_FORMAT_16_16 = 0x5,
6586 BUF_DATA_FORMAT_10_11_11 = 0x6,
6587 BUF_DATA_FORMAT_11_11_10 = 0x7,
6588 BUF_DATA_FORMAT_10_10_10_2 = 0x8,
6589 BUF_DATA_FORMAT_2_10_10_10 = 0x9,
6590 BUF_DATA_FORMAT_8_8_8_8 = 0xa,
6591 BUF_DATA_FORMAT_32_32 = 0xb,
6592 BUF_DATA_FORMAT_16_16_16_16 = 0xc,
6593 BUF_DATA_FORMAT_32_32_32 = 0xd,
6594 BUF_DATA_FORMAT_32_32_32_32 = 0xe,
6595 BUF_DATA_FORMAT_RESERVED_15 = 0xf,
6596 } BUF_DATA_FORMAT;
6597 typedef enum IMG_DATA_FORMAT {
6598 IMG_DATA_FORMAT_INVALID = 0x0,
6599 IMG_DATA_FORMAT_8 = 0x1,
6600 IMG_DATA_FORMAT_16 = 0x2,
6601 IMG_DATA_FORMAT_8_8 = 0x3,
6602 IMG_DATA_FORMAT_32 = 0x4,
6603 IMG_DATA_FORMAT_16_16 = 0x5,
6604 IMG_DATA_FORMAT_10_11_11 = 0x6,
6605 IMG_DATA_FORMAT_11_11_10 = 0x7,
6606 IMG_DATA_FORMAT_10_10_10_2 = 0x8,
6607 IMG_DATA_FORMAT_2_10_10_10 = 0x9,
6608 IMG_DATA_FORMAT_8_8_8_8 = 0xa,
6609 IMG_DATA_FORMAT_32_32 = 0xb,
6610 IMG_DATA_FORMAT_16_16_16_16 = 0xc,
6611 IMG_DATA_FORMAT_32_32_32 = 0xd,
6612 IMG_DATA_FORMAT_32_32_32_32 = 0xe,
6613 IMG_DATA_FORMAT_RESERVED_15 = 0xf,
6614 IMG_DATA_FORMAT_5_6_5 = 0x10,
6615 IMG_DATA_FORMAT_1_5_5_5 = 0x11,
6616 IMG_DATA_FORMAT_5_5_5_1 = 0x12,
6617 IMG_DATA_FORMAT_4_4_4_4 = 0x13,
6618 IMG_DATA_FORMAT_8_24 = 0x14,
6619 IMG_DATA_FORMAT_24_8 = 0x15,
6620 IMG_DATA_FORMAT_X24_8_32 = 0x16,
6621 IMG_DATA_FORMAT_RESERVED_23 = 0x17,
6622 IMG_DATA_FORMAT_RESERVED_24 = 0x18,
6623 IMG_DATA_FORMAT_RESERVED_25 = 0x19,
6624 IMG_DATA_FORMAT_RESERVED_26 = 0x1a,
6625 IMG_DATA_FORMAT_RESERVED_27 = 0x1b,
6626 IMG_DATA_FORMAT_RESERVED_28 = 0x1c,
6627 IMG_DATA_FORMAT_RESERVED_29 = 0x1d,
6628 IMG_DATA_FORMAT_RESERVED_30 = 0x1e,
6629 IMG_DATA_FORMAT_RESERVED_31 = 0x1f,
6630 IMG_DATA_FORMAT_GB_GR = 0x20,
6631 IMG_DATA_FORMAT_BG_RG = 0x21,
6632 IMG_DATA_FORMAT_5_9_9_9 = 0x22,
6633 IMG_DATA_FORMAT_BC1 = 0x23,
6634 IMG_DATA_FORMAT_BC2 = 0x24,
6635 IMG_DATA_FORMAT_BC3 = 0x25,
6636 IMG_DATA_FORMAT_BC4 = 0x26,
6637 IMG_DATA_FORMAT_BC5 = 0x27,
6638 IMG_DATA_FORMAT_BC6 = 0x28,
6639 IMG_DATA_FORMAT_BC7 = 0x29,
6640 IMG_DATA_FORMAT_RESERVED_42 = 0x2a,
6641 IMG_DATA_FORMAT_RESERVED_43 = 0x2b,
6642 IMG_DATA_FORMAT_FMASK8_S2_F1 = 0x2c,
6643 IMG_DATA_FORMAT_FMASK8_S4_F1 = 0x2d,
6644 IMG_DATA_FORMAT_FMASK8_S8_F1 = 0x2e,
6645 IMG_DATA_FORMAT_FMASK8_S2_F2 = 0x2f,
6646 IMG_DATA_FORMAT_FMASK8_S4_F2 = 0x30,
6647 IMG_DATA_FORMAT_FMASK8_S4_F4 = 0x31,
6648 IMG_DATA_FORMAT_FMASK16_S16_F1 = 0x32,
6649 IMG_DATA_FORMAT_FMASK16_S8_F2 = 0x33,
6650 IMG_DATA_FORMAT_FMASK32_S16_F2 = 0x34,
6651 IMG_DATA_FORMAT_FMASK32_S8_F4 = 0x35,
6652 IMG_DATA_FORMAT_FMASK32_S8_F8 = 0x36,
6653 IMG_DATA_FORMAT_FMASK64_S16_F4 = 0x37,
6654 IMG_DATA_FORMAT_FMASK64_S16_F8 = 0x38,
6655 IMG_DATA_FORMAT_4_4 = 0x39,
6656 IMG_DATA_FORMAT_6_5_5 = 0x3a,
6657 IMG_DATA_FORMAT_1 = 0x3b,
6658 IMG_DATA_FORMAT_1_REVERSED = 0x3c,
6659 IMG_DATA_FORMAT_32_AS_8 = 0x3d,
6660 IMG_DATA_FORMAT_32_AS_8_8 = 0x3e,
6661 IMG_DATA_FORMAT_32_AS_32_32_32_32 = 0x3f,
6662 } IMG_DATA_FORMAT;
6663 typedef enum BUF_NUM_FORMAT {
6664 BUF_NUM_FORMAT_UNORM = 0x0,
6665 BUF_NUM_FORMAT_SNORM = 0x1,
6666 BUF_NUM_FORMAT_USCALED = 0x2,
6667 BUF_NUM_FORMAT_SSCALED = 0x3,
6668 BUF_NUM_FORMAT_UINT = 0x4,
6669 BUF_NUM_FORMAT_SINT = 0x5,
6670 BUF_NUM_FORMAT_RESERVED_6 = 0x6,
6671 BUF_NUM_FORMAT_FLOAT = 0x7,
6672 } BUF_NUM_FORMAT;
6673 typedef enum IMG_NUM_FORMAT {
6674 IMG_NUM_FORMAT_UNORM = 0x0,
6675 IMG_NUM_FORMAT_SNORM = 0x1,
6676 IMG_NUM_FORMAT_USCALED = 0x2,
6677 IMG_NUM_FORMAT_SSCALED = 0x3,
6678 IMG_NUM_FORMAT_UINT = 0x4,
6679 IMG_NUM_FORMAT_SINT = 0x5,
6680 IMG_NUM_FORMAT_RESERVED_6 = 0x6,
6681 IMG_NUM_FORMAT_FLOAT = 0x7,
6682 IMG_NUM_FORMAT_RESERVED_8 = 0x8,
6683 IMG_NUM_FORMAT_SRGB = 0x9,
6684 IMG_NUM_FORMAT_RESERVED_10 = 0xa,
6685 IMG_NUM_FORMAT_RESERVED_11 = 0xb,
6686 IMG_NUM_FORMAT_RESERVED_12 = 0xc,
6687 IMG_NUM_FORMAT_RESERVED_13 = 0xd,
6688 IMG_NUM_FORMAT_RESERVED_14 = 0xe,
6689 IMG_NUM_FORMAT_RESERVED_15 = 0xf,
6690 } IMG_NUM_FORMAT;
6691 typedef enum TileType {
6692 ARRAY_COLOR_TILE = 0x0,
6693 ARRAY_DEPTH_TILE = 0x1,
6694 } TileType;
6695 typedef enum NonDispTilingOrder {
6696 ADDR_SURF_MICRO_TILING_DISPLAY = 0x0,
6697 ADDR_SURF_MICRO_TILING_NON_DISPLAY = 0x1,
6698 } NonDispTilingOrder;
6699 typedef enum MicroTileMode {
6700 ADDR_SURF_DISPLAY_MICRO_TILING = 0x0,
6701 ADDR_SURF_THIN_MICRO_TILING = 0x1,
6702 ADDR_SURF_DEPTH_MICRO_TILING = 0x2,
6703 ADDR_SURF_ROTATED_MICRO_TILING = 0x3,
6704 ADDR_SURF_THICK_MICRO_TILING = 0x4,
6705 } MicroTileMode;
6706 typedef enum TileSplit {
6707 ADDR_SURF_TILE_SPLIT_64B = 0x0,
6708 ADDR_SURF_TILE_SPLIT_128B = 0x1,
6709 ADDR_SURF_TILE_SPLIT_256B = 0x2,
6710 ADDR_SURF_TILE_SPLIT_512B = 0x3,
6711 ADDR_SURF_TILE_SPLIT_1KB = 0x4,
6712 ADDR_SURF_TILE_SPLIT_2KB = 0x5,
6713 ADDR_SURF_TILE_SPLIT_4KB = 0x6,
6714 } TileSplit;
6715 typedef enum SampleSplit {
6716 ADDR_SURF_SAMPLE_SPLIT_1 = 0x0,
6717 ADDR_SURF_SAMPLE_SPLIT_2 = 0x1,
6718 ADDR_SURF_SAMPLE_SPLIT_4 = 0x2,
6719 ADDR_SURF_SAMPLE_SPLIT_8 = 0x3,
6720 } SampleSplit;
6721 typedef enum PipeConfig {
6722 ADDR_SURF_P2 = 0x0,
6723 ADDR_SURF_P2_RESERVED0 = 0x1,
6724 ADDR_SURF_P2_RESERVED1 = 0x2,
6725 ADDR_SURF_P2_RESERVED2 = 0x3,
6726 ADDR_SURF_P4_8x16 = 0x4,
6727 ADDR_SURF_P4_16x16 = 0x5,
6728 ADDR_SURF_P4_16x32 = 0x6,
6729 ADDR_SURF_P4_32x32 = 0x7,
6730 ADDR_SURF_P8_16x16_8x16 = 0x8,
6731 ADDR_SURF_P8_16x32_8x16 = 0x9,
6732 ADDR_SURF_P8_32x32_8x16 = 0xa,
6733 ADDR_SURF_P8_16x32_16x16 = 0xb,
6734 ADDR_SURF_P8_32x32_16x16 = 0xc,
6735 ADDR_SURF_P8_32x32_16x32 = 0xd,
6736 ADDR_SURF_P8_32x64_32x32 = 0xe,
6737 ADDR_SURF_P8_RESERVED0 = 0xf,
6738 ADDR_SURF_P16_32x32_8x16 = 0x10,
6739 ADDR_SURF_P16_32x32_16x16 = 0x11,
6740 } PipeConfig;
6741 typedef enum NumBanks {
6742 ADDR_SURF_2_BANK = 0x0,
6743 ADDR_SURF_4_BANK = 0x1,
6744 ADDR_SURF_8_BANK = 0x2,
6745 ADDR_SURF_16_BANK = 0x3,
6746 } NumBanks;
6747 typedef enum BankWidth {
6748 ADDR_SURF_BANK_WIDTH_1 = 0x0,
6749 ADDR_SURF_BANK_WIDTH_2 = 0x1,
6750 ADDR_SURF_BANK_WIDTH_4 = 0x2,
6751 ADDR_SURF_BANK_WIDTH_8 = 0x3,
6752 } BankWidth;
6753 typedef enum BankHeight {
6754 ADDR_SURF_BANK_HEIGHT_1 = 0x0,
6755 ADDR_SURF_BANK_HEIGHT_2 = 0x1,
6756 ADDR_SURF_BANK_HEIGHT_4 = 0x2,
6757 ADDR_SURF_BANK_HEIGHT_8 = 0x3,
6758 } BankHeight;
6759 typedef enum BankWidthHeight {
6760 ADDR_SURF_BANK_WH_1 = 0x0,
6761 ADDR_SURF_BANK_WH_2 = 0x1,
6762 ADDR_SURF_BANK_WH_4 = 0x2,
6763 ADDR_SURF_BANK_WH_8 = 0x3,
6764 } BankWidthHeight;
6765 typedef enum MacroTileAspect {
6766 ADDR_SURF_MACRO_ASPECT_1 = 0x0,
6767 ADDR_SURF_MACRO_ASPECT_2 = 0x1,
6768 ADDR_SURF_MACRO_ASPECT_4 = 0x2,
6769 ADDR_SURF_MACRO_ASPECT_8 = 0x3,
6770 } MacroTileAspect;
6771 typedef enum GATCL1RequestType {
6772 GATCL1_TYPE_NORMAL = 0x0,
6773 GATCL1_TYPE_SHOOTDOWN = 0x1,
6774 GATCL1_TYPE_BYPASS = 0x2,
6775 } GATCL1RequestType;
6776 typedef enum TCC_CACHE_POLICIES {
6777 TCC_CACHE_POLICY_LRU = 0x0,
6778 TCC_CACHE_POLICY_STREAM = 0x1,
6779 } TCC_CACHE_POLICIES;
6780 typedef enum MTYPE {
6781 MTYPE_NC_NV = 0x0,
6782 MTYPE_NC = 0x1,
6783 MTYPE_CC = 0x2,
6784 MTYPE_UC = 0x3,
6785 } MTYPE;
6786 typedef enum PERFMON_COUNTER_MODE {
6787 PERFMON_COUNTER_MODE_ACCUM = 0x0,
6788 PERFMON_COUNTER_MODE_ACTIVE_CYCLES = 0x1,
6789 PERFMON_COUNTER_MODE_MAX = 0x2,
6790 PERFMON_COUNTER_MODE_DIRTY = 0x3,
6791 PERFMON_COUNTER_MODE_SAMPLE = 0x4,
6792 PERFMON_COUNTER_MODE_CYCLES_SINCE_FIRST_EVENT = 0x5,
6793 PERFMON_COUNTER_MODE_CYCLES_SINCE_LAST_EVENT = 0x6,
6794 PERFMON_COUNTER_MODE_CYCLES_GE_HI = 0x7,
6795 PERFMON_COUNTER_MODE_CYCLES_EQ_HI = 0x8,
6796 PERFMON_COUNTER_MODE_INACTIVE_CYCLES = 0x9,
6797 PERFMON_COUNTER_MODE_RESERVED = 0xf,
6798 } PERFMON_COUNTER_MODE;
6799 typedef enum PERFMON_SPM_MODE {
6800 PERFMON_SPM_MODE_OFF = 0x0,
6801 PERFMON_SPM_MODE_16BIT_CLAMP = 0x1,
6802 PERFMON_SPM_MODE_16BIT_NO_CLAMP = 0x2,
6803 PERFMON_SPM_MODE_32BIT_CLAMP = 0x3,
6804 PERFMON_SPM_MODE_32BIT_NO_CLAMP = 0x4,
6805 PERFMON_SPM_MODE_RESERVED_5 = 0x5,
6806 PERFMON_SPM_MODE_RESERVED_6 = 0x6,
6807 PERFMON_SPM_MODE_RESERVED_7 = 0x7,
6808 PERFMON_SPM_MODE_TEST_MODE_0 = 0x8,
6809 PERFMON_SPM_MODE_TEST_MODE_1 = 0x9,
6810 PERFMON_SPM_MODE_TEST_MODE_2 = 0xa,
6811 } PERFMON_SPM_MODE;
6812 typedef enum SurfaceTiling {
6813 ARRAY_LINEAR = 0x0,
6814 ARRAY_TILED = 0x1,
6815 } SurfaceTiling;
6816 typedef enum SurfaceArray {
6817 ARRAY_1D = 0x0,
6818 ARRAY_2D = 0x1,
6819 ARRAY_3D = 0x2,
6820 ARRAY_3D_SLICE = 0x3,
6821 } SurfaceArray;
6822 typedef enum ColorArray {
6823 ARRAY_2D_ALT_COLOR = 0x0,
6824 ARRAY_2D_COLOR = 0x1,
6825 ARRAY_3D_SLICE_COLOR = 0x3,
6826 } ColorArray;
6827 typedef enum DepthArray {
6828 ARRAY_2D_ALT_DEPTH = 0x0,
6829 ARRAY_2D_DEPTH = 0x1,
6830 } DepthArray;
6831 typedef enum ENUM_NUM_SIMD_PER_CU {
6832 NUM_SIMD_PER_CU = 0x4,
6833 } ENUM_NUM_SIMD_PER_CU;
6834 typedef enum MEM_PWR_FORCE_CTRL {
6835 NO_FORCE_REQUEST = 0x0,
6836 FORCE_LIGHT_SLEEP_REQUEST = 0x1,
6837 FORCE_DEEP_SLEEP_REQUEST = 0x2,
6838 FORCE_SHUT_DOWN_REQUEST = 0x3,
6839 } MEM_PWR_FORCE_CTRL;
6840 typedef enum MEM_PWR_FORCE_CTRL2 {
6841 NO_FORCE_REQ = 0x0,
6842 FORCE_LIGHT_SLEEP_REQ = 0x1,
6843 } MEM_PWR_FORCE_CTRL2;
6844 typedef enum MEM_PWR_DIS_CTRL {
6845 ENABLE_MEM_PWR_CTRL = 0x0,
6846 DISABLE_MEM_PWR_CTRL = 0x1,
6847 } MEM_PWR_DIS_CTRL;
6848 typedef enum MEM_PWR_SEL_CTRL {
6849 DYNAMIC_SHUT_DOWN_ENABLE = 0x0,
6850 DYNAMIC_DEEP_SLEEP_ENABLE = 0x1,
6851 DYNAMIC_LIGHT_SLEEP_ENABLE = 0x2,
6852 } MEM_PWR_SEL_CTRL;
6853 typedef enum MEM_PWR_SEL_CTRL2 {
6854 DYNAMIC_DEEP_SLEEP_EN = 0x0,
6855 DYNAMIC_LIGHT_SLEEP_EN = 0x1,
6856 } MEM_PWR_SEL_CTRL2;
6857
6858 #endif