freedreno/a6xx: Define the register fields for polygon fill mode.
[mesa.git] / src / freedreno / registers / a4xx.xml
1 <?xml version="1.0" encoding="UTF-8"?>
2 <database xmlns="http://nouveau.freedesktop.org/"
3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4 xsi:schemaLocation="http://nouveau.freedesktop.org/ rules-ng.xsd">
5 <import file="freedreno_copyright.xml"/>
6 <import file="adreno/adreno_common.xml"/>
7 <import file="adreno/adreno_pm4.xml"/>
8
9 <enum name="a4xx_color_fmt">
10 <value name="RB4_A8_UNORM" value="0x01"/>
11 <value name="RB4_R8_UNORM" value="0x02"/>
12 <value name="RB4_R8_SNORM" value="0x03"/>
13 <value name="RB4_R8_UINT" value="0x04"/>
14 <value name="RB4_R8_SINT" value="0x05"/>
15
16 <value name="RB4_R4G4B4A4_UNORM" value="0x08"/>
17 <value name="RB4_R5G5B5A1_UNORM" value="0x0a"/>
18 <value name="RB4_R5G6B5_UNORM" value="0x0e"/>
19 <value name="RB4_R8G8_UNORM" value="0x0f"/>
20 <value name="RB4_R8G8_SNORM" value="0x10"/>
21 <value name="RB4_R8G8_UINT" value="0x11"/>
22 <value name="RB4_R8G8_SINT" value="0x12"/>
23 <value name="RB4_R16_UNORM" value="0x13"/>
24 <value name="RB4_R16_SNORM" value="0x14"/>
25 <value name="RB4_R16_FLOAT" value="0x15"/>
26 <value name="RB4_R16_UINT" value="0x16"/>
27 <value name="RB4_R16_SINT" value="0x17"/>
28
29 <value name="RB4_R8G8B8_UNORM" value="0x19"/>
30
31 <value name="RB4_R8G8B8A8_UNORM" value="0x1a"/>
32 <value name="RB4_R8G8B8A8_SNORM" value="0x1c"/>
33 <value name="RB4_R8G8B8A8_UINT" value="0x1d"/>
34 <value name="RB4_R8G8B8A8_SINT" value="0x1e"/>
35 <value name="RB4_R10G10B10A2_UNORM" value="0x1f"/>
36 <value name="RB4_R10G10B10A2_UINT" value="0x22"/>
37 <value name="RB4_R11G11B10_FLOAT" value="0x27"/>
38 <value name="RB4_R16G16_UNORM" value="0x28"/>
39 <value name="RB4_R16G16_SNORM" value="0x29"/>
40 <value name="RB4_R16G16_FLOAT" value="0x2a"/>
41 <value name="RB4_R16G16_UINT" value="0x2b"/>
42 <value name="RB4_R16G16_SINT" value="0x2c"/>
43 <value name="RB4_R32_FLOAT" value="0x2d"/>
44 <value name="RB4_R32_UINT" value="0x2e"/>
45 <value name="RB4_R32_SINT" value="0x2f"/>
46
47 <value name="RB4_R16G16B16A16_UNORM" value="0x34"/>
48 <value name="RB4_R16G16B16A16_SNORM" value="0x35"/>
49 <value name="RB4_R16G16B16A16_FLOAT" value="0x36"/>
50 <value name="RB4_R16G16B16A16_UINT" value="0x37"/>
51 <value name="RB4_R16G16B16A16_SINT" value="0x38"/>
52 <value name="RB4_R32G32_FLOAT" value="0x39"/>
53 <value name="RB4_R32G32_UINT" value="0x3a"/>
54 <value name="RB4_R32G32_SINT" value="0x3b"/>
55
56 <value name="RB4_R32G32B32A32_FLOAT" value="0x3c"/>
57 <value name="RB4_R32G32B32A32_UINT" value="0x3d"/>
58 <value name="RB4_R32G32B32A32_SINT" value="0x3e"/>
59
60 <value name="RB4_NONE" value="0xff"/>
61 </enum>
62
63 <enum name="a4xx_tile_mode">
64 <value name="TILE4_LINEAR" value="0"/>
65 <value name="TILE4_2" value="2"/>
66 <value name="TILE4_3" value="3"/>
67 </enum>
68
69 <enum name="a4xx_vtx_fmt" prefix="chipset">
70 <!-- hmm, shifted one compared to a3xx?!? -->
71 <value name="VFMT4_32_FLOAT" value="0x1"/>
72 <value name="VFMT4_32_32_FLOAT" value="0x2"/>
73 <value name="VFMT4_32_32_32_FLOAT" value="0x3"/>
74 <value name="VFMT4_32_32_32_32_FLOAT" value="0x4"/>
75
76 <value name="VFMT4_16_FLOAT" value="0x5"/>
77 <value name="VFMT4_16_16_FLOAT" value="0x6"/>
78 <value name="VFMT4_16_16_16_FLOAT" value="0x7"/>
79 <value name="VFMT4_16_16_16_16_FLOAT" value="0x8"/>
80
81 <value name="VFMT4_32_FIXED" value="0x9"/>
82 <value name="VFMT4_32_32_FIXED" value="0xa"/>
83 <value name="VFMT4_32_32_32_FIXED" value="0xb"/>
84 <value name="VFMT4_32_32_32_32_FIXED" value="0xc"/>
85
86 <value name="VFMT4_11_11_10_FLOAT" value="0xd"/>
87
88 <!-- beyond here it does not appear to be shifted -->
89 <value name="VFMT4_16_SINT" value="0x10"/>
90 <value name="VFMT4_16_16_SINT" value="0x11"/>
91 <value name="VFMT4_16_16_16_SINT" value="0x12"/>
92 <value name="VFMT4_16_16_16_16_SINT" value="0x13"/>
93 <value name="VFMT4_16_UINT" value="0x14"/>
94 <value name="VFMT4_16_16_UINT" value="0x15"/>
95 <value name="VFMT4_16_16_16_UINT" value="0x16"/>
96 <value name="VFMT4_16_16_16_16_UINT" value="0x17"/>
97 <value name="VFMT4_16_SNORM" value="0x18"/>
98 <value name="VFMT4_16_16_SNORM" value="0x19"/>
99 <value name="VFMT4_16_16_16_SNORM" value="0x1a"/>
100 <value name="VFMT4_16_16_16_16_SNORM" value="0x1b"/>
101 <value name="VFMT4_16_UNORM" value="0x1c"/>
102 <value name="VFMT4_16_16_UNORM" value="0x1d"/>
103 <value name="VFMT4_16_16_16_UNORM" value="0x1e"/>
104 <value name="VFMT4_16_16_16_16_UNORM" value="0x1f"/>
105
106 <value name="VFMT4_32_UINT" value="0x20"/>
107 <value name="VFMT4_32_32_UINT" value="0x21"/>
108 <value name="VFMT4_32_32_32_UINT" value="0x22"/>
109 <value name="VFMT4_32_32_32_32_UINT" value="0x23"/>
110 <value name="VFMT4_32_SINT" value="0x24"/>
111 <value name="VFMT4_32_32_SINT" value="0x25"/>
112 <value name="VFMT4_32_32_32_SINT" value="0x26"/>
113 <value name="VFMT4_32_32_32_32_SINT" value="0x27"/>
114
115 <value name="VFMT4_8_UINT" value="0x28"/>
116 <value name="VFMT4_8_8_UINT" value="0x29"/>
117 <value name="VFMT4_8_8_8_UINT" value="0x2a"/>
118 <value name="VFMT4_8_8_8_8_UINT" value="0x2b"/>
119 <value name="VFMT4_8_UNORM" value="0x2c"/>
120 <value name="VFMT4_8_8_UNORM" value="0x2d"/>
121 <value name="VFMT4_8_8_8_UNORM" value="0x2e"/>
122 <value name="VFMT4_8_8_8_8_UNORM" value="0x2f"/>
123 <value name="VFMT4_8_SINT" value="0x30"/>
124 <value name="VFMT4_8_8_SINT" value="0x31"/>
125 <value name="VFMT4_8_8_8_SINT" value="0x32"/>
126 <value name="VFMT4_8_8_8_8_SINT" value="0x33"/>
127 <value name="VFMT4_8_SNORM" value="0x34"/>
128 <value name="VFMT4_8_8_SNORM" value="0x35"/>
129 <value name="VFMT4_8_8_8_SNORM" value="0x36"/>
130 <value name="VFMT4_8_8_8_8_SNORM" value="0x37"/>
131
132 <value name="VFMT4_10_10_10_2_UINT" value="0x38"/>
133 <value name="VFMT4_10_10_10_2_UNORM" value="0x39"/>
134 <value name="VFMT4_10_10_10_2_SINT" value="0x3a"/>
135 <value name="VFMT4_10_10_10_2_SNORM" value="0x3b"/>
136 <value name="VFMT4_2_10_10_10_UINT" value="0x3c"/>
137 <value name="VFMT4_2_10_10_10_UNORM" value="0x3d"/>
138 <value name="VFMT4_2_10_10_10_SINT" value="0x3e"/>
139 <value name="VFMT4_2_10_10_10_SNORM" value="0x3f"/>
140
141 <value name="VFMT4_NONE" value="0xff"/>
142 </enum>
143
144 <enum name="a4xx_tex_fmt">
145 <!-- 0x00 .. 0x02 -->
146
147 <!-- 8-bit formats -->
148 <value name="TFMT4_A8_UNORM" value="0x03"/>
149 <value name="TFMT4_8_UNORM" value="0x04"/>
150 <value name="TFMT4_8_SNORM" value="0x05"/>
151 <value name="TFMT4_8_UINT" value="0x06"/>
152 <value name="TFMT4_8_SINT" value="0x07"/>
153
154 <!-- 16-bit formats -->
155 <value name="TFMT4_4_4_4_4_UNORM" value="0x08"/>
156 <value name="TFMT4_5_5_5_1_UNORM" value="0x09"/>
157 <!-- 0x0a -->
158 <value name="TFMT4_5_6_5_UNORM" value="0x0b"/>
159
160 <!-- 0x0c -->
161
162 <value name="TFMT4_L8_A8_UNORM" value="0x0d"/>
163 <value name="TFMT4_8_8_UNORM" value="0x0e"/>
164 <value name="TFMT4_8_8_SNORM" value="0x0f"/>
165 <value name="TFMT4_8_8_UINT" value="0x10"/>
166 <value name="TFMT4_8_8_SINT" value="0x11"/>
167
168 <value name="TFMT4_16_UNORM" value="0x12"/>
169 <value name="TFMT4_16_SNORM" value="0x13"/>
170 <value name="TFMT4_16_FLOAT" value="0x14"/>
171 <value name="TFMT4_16_UINT" value="0x15"/>
172 <value name="TFMT4_16_SINT" value="0x16"/>
173
174 <!-- 0x17 .. 0x1b -->
175
176 <!-- 32-bit formats -->
177 <value name="TFMT4_8_8_8_8_UNORM" value="0x1c"/>
178 <value name="TFMT4_8_8_8_8_SNORM" value="0x1d"/>
179 <value name="TFMT4_8_8_8_8_UINT" value="0x1e"/>
180 <value name="TFMT4_8_8_8_8_SINT" value="0x1f"/>
181
182 <value name="TFMT4_9_9_9_E5_FLOAT" value="0x20"/>
183 <value name="TFMT4_10_10_10_2_UNORM" value="0x21"/>
184 <value name="TFMT4_10_10_10_2_UINT" value="0x22"/>
185 <!-- 0x23 .. 0x24 -->
186 <value name="TFMT4_11_11_10_FLOAT" value="0x25"/>
187
188 <value name="TFMT4_16_16_UNORM" value="0x26"/>
189 <value name="TFMT4_16_16_SNORM" value="0x27"/>
190 <value name="TFMT4_16_16_FLOAT" value="0x28"/>
191 <value name="TFMT4_16_16_UINT" value="0x29"/>
192 <value name="TFMT4_16_16_SINT" value="0x2a"/>
193
194 <value name="TFMT4_32_FLOAT" value="0x2b"/>
195 <value name="TFMT4_32_UINT" value="0x2c"/>
196 <value name="TFMT4_32_SINT" value="0x2d"/>
197
198 <!-- 0x2e .. 0x32 -->
199
200 <!-- 64-bit formats -->
201 <value name="TFMT4_16_16_16_16_UNORM" value="0x33"/>
202 <value name="TFMT4_16_16_16_16_SNORM" value="0x34"/>
203 <value name="TFMT4_16_16_16_16_FLOAT" value="0x35"/>
204 <value name="TFMT4_16_16_16_16_UINT" value="0x36"/>
205 <value name="TFMT4_16_16_16_16_SINT" value="0x37"/>
206
207 <value name="TFMT4_32_32_FLOAT" value="0x38"/>
208 <value name="TFMT4_32_32_UINT" value="0x39"/>
209 <value name="TFMT4_32_32_SINT" value="0x3a"/>
210
211 <!-- 96-bit formats -->
212 <value name="TFMT4_32_32_32_FLOAT" value="0x3b"/>
213 <value name="TFMT4_32_32_32_UINT" value="0x3c"/>
214 <value name="TFMT4_32_32_32_SINT" value="0x3d"/>
215
216 <!-- 0x3e -->
217
218 <!-- 128-bit formats -->
219 <value name="TFMT4_32_32_32_32_FLOAT" value="0x3f"/>
220 <value name="TFMT4_32_32_32_32_UINT" value="0x40"/>
221 <value name="TFMT4_32_32_32_32_SINT" value="0x41"/>
222
223 <!-- 0x42 .. 0x46 -->
224 <value name="TFMT4_X8Z24_UNORM" value="0x47"/>
225 <!-- 0x48 .. 0x55 -->
226
227 <!-- compressed formats -->
228 <value name="TFMT4_DXT1" value="0x56"/>
229 <value name="TFMT4_DXT3" value="0x57"/>
230 <value name="TFMT4_DXT5" value="0x58"/>
231 <!-- 0x59 -->
232 <value name="TFMT4_RGTC1_UNORM" value="0x5a"/>
233 <value name="TFMT4_RGTC1_SNORM" value="0x5b"/>
234 <!-- 0x5c .. 0x5d -->
235 <value name="TFMT4_RGTC2_UNORM" value="0x5e"/>
236 <value name="TFMT4_RGTC2_SNORM" value="0x5f"/>
237 <!-- 0x60 -->
238 <value name="TFMT4_BPTC_UFLOAT" value="0x61"/>
239 <value name="TFMT4_BPTC_FLOAT" value="0x62"/>
240 <value name="TFMT4_BPTC" value="0x63"/>
241 <value name="TFMT4_ATC_RGB" value="0x64"/>
242 <value name="TFMT4_ATC_RGBA_EXPLICIT" value="0x65"/>
243 <value name="TFMT4_ATC_RGBA_INTERPOLATED" value="0x66"/>
244 <value name="TFMT4_ETC2_RG11_UNORM" value="0x67"/>
245 <value name="TFMT4_ETC2_RG11_SNORM" value="0x68"/>
246 <value name="TFMT4_ETC2_R11_UNORM" value="0x69"/>
247 <value name="TFMT4_ETC2_R11_SNORM" value="0x6a"/>
248 <value name="TFMT4_ETC1" value="0x6b"/>
249 <value name="TFMT4_ETC2_RGB8" value="0x6c"/>
250 <value name="TFMT4_ETC2_RGBA8" value="0x6d"/>
251 <value name="TFMT4_ETC2_RGB8A1" value="0x6e"/>
252 <value name="TFMT4_ASTC_4x4" value="0x6f"/>
253 <value name="TFMT4_ASTC_5x4" value="0x70"/>
254 <value name="TFMT4_ASTC_5x5" value="0x71"/>
255 <value name="TFMT4_ASTC_6x5" value="0x72"/>
256 <value name="TFMT4_ASTC_6x6" value="0x73"/>
257 <value name="TFMT4_ASTC_8x5" value="0x74"/>
258 <value name="TFMT4_ASTC_8x6" value="0x75"/>
259 <value name="TFMT4_ASTC_8x8" value="0x76"/>
260 <value name="TFMT4_ASTC_10x5" value="0x77"/>
261 <value name="TFMT4_ASTC_10x6" value="0x78"/>
262 <value name="TFMT4_ASTC_10x8" value="0x79"/>
263 <value name="TFMT4_ASTC_10x10" value="0x7a"/>
264 <value name="TFMT4_ASTC_12x10" value="0x7b"/>
265 <value name="TFMT4_ASTC_12x12" value="0x7c"/>
266 <!-- 0x7d .. 0x7f -->
267
268 <value name="TFMT4_NONE" value="0xff"/>
269 </enum>
270
271 <enum name="a4xx_tex_fetchsize">
272 <doc>
273 Size pixel to fetch, in bytes. Doesn't seem to be required, setting
274 it to 0x0 seems to work ok, but may be less optimal.
275 </doc>
276 <value name="TFETCH4_1_BYTE" value="0"/>
277 <value name="TFETCH4_2_BYTE" value="1"/>
278 <value name="TFETCH4_4_BYTE" value="2"/>
279 <value name="TFETCH4_8_BYTE" value="3"/>
280 <value name="TFETCH4_16_BYTE" value="4"/>
281 </enum>
282
283 <enum name="a4xx_depth_format">
284 <value name="DEPTH4_NONE" value="0"/>
285 <value name="DEPTH4_16" value="1"/>
286 <value name="DEPTH4_24_8" value="2"/>
287 <value name="DEPTH4_32" value="3"/>
288 </enum>
289
290 <!--
291 NOTE counters extracted from test-perf log with the following awful
292 script:
293 ##################
294 #!/bin/bash
295
296 log=$1
297
298 grep -F "counter
299 countable
300 group" $log | grep -v gl > shortlist.txt
301
302 countable=""
303 IFS=$'\n'; for line in $(cat shortlist.txt); do
304 # parse ######### group[$n]: $name
305 l=${line########### group}
306 if [ $l != $line ]; then
307 group=`echo $line | awk '{print $3}'`
308 echo "Group: $group"
309 continue
310 fi
311 # parse ######### counter[$n]: $name
312 l=${line########### counter}
313 if [ $l != $line ]; then
314 countable=`echo $line | awk '{print $3}'`
315 #echo " Countable: $countable"
316 continue
317 fi
318 # parse countable:
319 l=${line## countable:}
320 if [ $l != $line ]; then
321 val=`echo $line | awk '{print $2}'`
322 echo "<value value=\"$val\" name=\"$countable\"/>"
323 fi
324
325 done
326 ##################
327 -->
328 <enum name="a4xx_ccu_perfcounter_select">
329 <value value="0" name="CCU_BUSY_CYCLES"/>
330 <value value="2" name="CCU_RB_DEPTH_RETURN_STALL"/>
331 <value value="3" name="CCU_RB_COLOR_RETURN_STALL"/>
332 <value value="6" name="CCU_DEPTH_BLOCKS"/>
333 <value value="7" name="CCU_COLOR_BLOCKS"/>
334 <value value="8" name="CCU_DEPTH_BLOCK_HIT"/>
335 <value value="9" name="CCU_COLOR_BLOCK_HIT"/>
336 <value value="10" name="CCU_DEPTH_FLAG1_COUNT"/>
337 <value value="11" name="CCU_DEPTH_FLAG2_COUNT"/>
338 <value value="12" name="CCU_DEPTH_FLAG3_COUNT"/>
339 <value value="13" name="CCU_DEPTH_FLAG4_COUNT"/>
340 <value value="14" name="CCU_COLOR_FLAG1_COUNT"/>
341 <value value="15" name="CCU_COLOR_FLAG2_COUNT"/>
342 <value value="16" name="CCU_COLOR_FLAG3_COUNT"/>
343 <value value="17" name="CCU_COLOR_FLAG4_COUNT"/>
344 <value value="18" name="CCU_PARTIAL_BLOCK_READ"/>
345 </enum>
346
347 <!--
348 NOTE other than CP_ALWAYS_COUNT (which is the only one we use so far),
349 on a3xx the countable #'s from AMD_performance_monitor disagreed with
350 TRM. All these #'s for a4xx come from AMD_performance_monitor, so
351 perhaps they should be taken with a grain of salt
352 -->
353 <enum name="a4xx_cp_perfcounter_select">
354 <!-- first ctr at least seems same as a3xx, so we can measure freq -->
355 <value value="0" name="CP_ALWAYS_COUNT"/>
356 <value value="1" name="CP_BUSY"/>
357 <value value="2" name="CP_PFP_IDLE"/>
358 <value value="3" name="CP_PFP_BUSY_WORKING"/>
359 <value value="4" name="CP_PFP_STALL_CYCLES_ANY"/>
360 <value value="5" name="CP_PFP_STARVE_CYCLES_ANY"/>
361 <value value="6" name="CP_PFP_STARVED_PER_LOAD_ADDR"/>
362 <value value="7" name="CP_PFP_STALLED_PER_STORE_ADDR"/>
363 <value value="8" name="CP_PFP_PC_PROFILE"/>
364 <value value="9" name="CP_PFP_MATCH_PM4_PKT_PROFILE"/>
365 <value value="10" name="CP_PFP_COND_INDIRECT_DISCARDED"/>
366 <value value="11" name="CP_LONG_RESUMPTIONS"/>
367 <value value="12" name="CP_RESUME_CYCLES"/>
368 <value value="13" name="CP_RESUME_TO_BOUNDARY_CYCLES"/>
369 <value value="14" name="CP_LONG_PREEMPTIONS"/>
370 <value value="15" name="CP_PREEMPT_CYCLES"/>
371 <value value="16" name="CP_PREEMPT_TO_BOUNDARY_CYCLES"/>
372 <value value="17" name="CP_ME_FIFO_EMPTY_PFP_IDLE"/>
373 <value value="18" name="CP_ME_FIFO_EMPTY_PFP_BUSY"/>
374 <value value="19" name="CP_ME_FIFO_NOT_EMPTY_NOT_FULL"/>
375 <value value="20" name="CP_ME_FIFO_FULL_ME_BUSY"/>
376 <value value="21" name="CP_ME_FIFO_FULL_ME_NON_WORKING"/>
377 <value value="22" name="CP_ME_WAITING_FOR_PACKETS"/>
378 <value value="23" name="CP_ME_BUSY_WORKING"/>
379 <value value="24" name="CP_ME_STARVE_CYCLES_ANY"/>
380 <value value="25" name="CP_ME_STARVE_CYCLES_PER_PROFILE"/>
381 <value value="26" name="CP_ME_STALL_CYCLES_PER_PROFILE"/>
382 <value value="27" name="CP_ME_PC_PROFILE"/>
383 <value value="28" name="CP_RCIU_FIFO_EMPTY"/>
384 <value value="29" name="CP_RCIU_FIFO_NOT_EMPTY_NOT_FULL"/>
385 <value value="30" name="CP_RCIU_FIFO_FULL"/>
386 <value value="31" name="CP_RCIU_FIFO_FULL_NO_CONTEXT"/>
387 <value value="32" name="CP_RCIU_FIFO_FULL_AHB_MASTER"/>
388 <value value="33" name="CP_RCIU_FIFO_FULL_OTHER"/>
389 <value value="34" name="CP_AHB_IDLE"/>
390 <value value="35" name="CP_AHB_STALL_ON_GRANT_NO_SPLIT"/>
391 <value value="36" name="CP_AHB_STALL_ON_GRANT_SPLIT"/>
392 <value value="37" name="CP_AHB_STALL_ON_GRANT_SPLIT_PROFILE"/>
393 <value value="38" name="CP_AHB_BUSY_WORKING"/>
394 <value value="39" name="CP_AHB_BUSY_STALL_ON_HRDY"/>
395 <value value="40" name="CP_AHB_BUSY_STALL_ON_HRDY_PROFILE"/>
396 </enum>
397
398 <enum name="a4xx_gras_ras_perfcounter_select">
399 <value value="0" name="RAS_SUPER_TILES"/>
400 <value value="1" name="RAS_8X8_TILES"/>
401 <value value="2" name="RAS_4X4_TILES"/>
402 <value value="3" name="RAS_BUSY_CYCLES"/>
403 <value value="4" name="RAS_STALL_CYCLES_BY_RB"/>
404 <value value="5" name="RAS_STALL_CYCLES_BY_VSC"/>
405 <value value="6" name="RAS_STARVE_CYCLES_BY_TSE"/>
406 <value value="7" name="RAS_SUPERTILE_CYCLES"/>
407 <value value="8" name="RAS_TILE_CYCLES"/>
408 <value value="9" name="RAS_FULLY_COVERED_SUPER_TILES"/>
409 <value value="10" name="RAS_FULLY_COVERED_8X8_TILES"/>
410 <value value="11" name="RAS_4X4_PRIM"/>
411 <value value="12" name="RAS_8X4_4X8_PRIM"/>
412 <value value="13" name="RAS_8X8_PRIM"/>
413 </enum>
414
415 <enum name="a4xx_gras_tse_perfcounter_select">
416 <value value="0" name="TSE_INPUT_PRIM"/>
417 <value value="1" name="TSE_INPUT_NULL_PRIM"/>
418 <value value="2" name="TSE_TRIVAL_REJ_PRIM"/>
419 <value value="3" name="TSE_CLIPPED_PRIM"/>
420 <value value="4" name="TSE_NEW_PRIM"/>
421 <value value="5" name="TSE_ZERO_AREA_PRIM"/>
422 <value value="6" name="TSE_FACENESS_CULLED_PRIM"/>
423 <value value="7" name="TSE_ZERO_PIXEL_PRIM"/>
424 <value value="8" name="TSE_OUTPUT_NULL_PRIM"/>
425 <value value="9" name="TSE_OUTPUT_VISIBLE_PRIM"/>
426 <value value="10" name="TSE_PRE_CLIP_PRIM"/>
427 <value value="11" name="TSE_POST_CLIP_PRIM"/>
428 <value value="12" name="TSE_BUSY_CYCLES"/>
429 <value value="13" name="TSE_PC_STARVE"/>
430 <value value="14" name="TSE_RAS_STALL"/>
431 <value value="15" name="TSE_STALL_BARYPLANE_FIFO_FULL"/>
432 <value value="16" name="TSE_STALL_ZPLANE_FIFO_FULL"/>
433 </enum>
434
435 <enum name="a4xx_hlsq_perfcounter_select">
436 <value value="0" name="HLSQ_SP_VS_STAGE_CONSTANT"/>
437 <value value="1" name="HLSQ_SP_VS_STAGE_INSTRUCTIONS"/>
438 <value value="2" name="HLSQ_SP_FS_STAGE_CONSTANT"/>
439 <value value="3" name="HLSQ_SP_FS_STAGE_INSTRUCTIONS"/>
440 <value value="4" name="HLSQ_TP_STATE"/>
441 <value value="5" name="HLSQ_QUADS"/>
442 <value value="6" name="HLSQ_PIXELS"/>
443 <value value="7" name="HLSQ_VERTICES"/>
444 <value value="13" name="HLSQ_SP_VS_STAGE_DATA_BYTES"/>
445 <value value="14" name="HLSQ_SP_FS_STAGE_DATA_BYTES"/>
446 <value value="15" name="HLSQ_BUSY_CYCLES"/>
447 <value value="16" name="HLSQ_STALL_CYCLES_SP_STATE"/>
448 <value value="17" name="HLSQ_STALL_CYCLES_SP_VS_STAGE"/>
449 <value value="18" name="HLSQ_STALL_CYCLES_SP_FS_STAGE"/>
450 <value value="19" name="HLSQ_STALL_CYCLES_UCHE"/>
451 <value value="20" name="HLSQ_RBBM_LOAD_CYCLES"/>
452 <value value="21" name="HLSQ_DI_TO_VS_START_SP"/>
453 <value value="22" name="HLSQ_DI_TO_FS_START_SP"/>
454 <value value="23" name="HLSQ_VS_STAGE_START_TO_DONE_SP"/>
455 <value value="24" name="HLSQ_FS_STAGE_START_TO_DONE_SP"/>
456 <value value="25" name="HLSQ_SP_STATE_COPY_CYCLES_VS_STAGE"/>
457 <value value="26" name="HLSQ_SP_STATE_COPY_CYCLES_FS_STAGE"/>
458 <value value="27" name="HLSQ_UCHE_LATENCY_CYCLES"/>
459 <value value="28" name="HLSQ_UCHE_LATENCY_COUNT"/>
460 <value value="29" name="HLSQ_STARVE_CYCLES_VFD"/>
461 </enum>
462
463 <enum name="a4xx_pc_perfcounter_select">
464 <value value="0" name="PC_VIS_STREAMS_LOADED"/>
465 <value value="2" name="PC_VPC_PRIMITIVES"/>
466 <value value="3" name="PC_DEAD_PRIM"/>
467 <value value="4" name="PC_LIVE_PRIM"/>
468 <value value="5" name="PC_DEAD_DRAWCALLS"/>
469 <value value="6" name="PC_LIVE_DRAWCALLS"/>
470 <value value="7" name="PC_VERTEX_MISSES"/>
471 <value value="9" name="PC_STALL_CYCLES_VFD"/>
472 <value value="10" name="PC_STALL_CYCLES_TSE"/>
473 <value value="11" name="PC_STALL_CYCLES_UCHE"/>
474 <value value="12" name="PC_WORKING_CYCLES"/>
475 <value value="13" name="PC_IA_VERTICES"/>
476 <value value="14" name="PC_GS_PRIMITIVES"/>
477 <value value="15" name="PC_HS_INVOCATIONS"/>
478 <value value="16" name="PC_DS_INVOCATIONS"/>
479 <value value="17" name="PC_DS_PRIMITIVES"/>
480 <value value="20" name="PC_STARVE_CYCLES_FOR_INDEX"/>
481 <value value="21" name="PC_STARVE_CYCLES_FOR_TESS_FACTOR"/>
482 <value value="22" name="PC_STARVE_CYCLES_FOR_VIZ_STREAM"/>
483 <value value="23" name="PC_STALL_CYCLES_TESS"/>
484 <value value="24" name="PC_STARVE_CYCLES_FOR_POSITION"/>
485 <value value="25" name="PC_MODE0_DRAWCALL"/>
486 <value value="26" name="PC_MODE1_DRAWCALL"/>
487 <value value="27" name="PC_MODE2_DRAWCALL"/>
488 <value value="28" name="PC_MODE3_DRAWCALL"/>
489 <value value="29" name="PC_MODE4_DRAWCALL"/>
490 <value value="30" name="PC_PREDICATED_DEAD_DRAWCALL"/>
491 <value value="31" name="PC_STALL_CYCLES_BY_TSE_ONLY"/>
492 <value value="32" name="PC_STALL_CYCLES_BY_VPC_ONLY"/>
493 <value value="33" name="PC_VPC_POS_DATA_TRANSACTION"/>
494 <value value="34" name="PC_BUSY_CYCLES"/>
495 <value value="35" name="PC_STARVE_CYCLES_DI"/>
496 <value value="36" name="PC_STALL_CYCLES_VPC"/>
497 <value value="37" name="TESS_WORKING_CYCLES"/>
498 <value value="38" name="TESS_NUM_CYCLES_SETUP_WORKING"/>
499 <value value="39" name="TESS_NUM_CYCLES_PTGEN_WORKING"/>
500 <value value="40" name="TESS_NUM_CYCLES_CONNGEN_WORKING"/>
501 <value value="41" name="TESS_BUSY_CYCLES"/>
502 <value value="42" name="TESS_STARVE_CYCLES_PC"/>
503 <value value="43" name="TESS_STALL_CYCLES_PC"/>
504 </enum>
505
506 <enum name="a4xx_pwr_perfcounter_select">
507 <!-- NOTE not actually used.. see RBBM_RBBM_CTL.RESET_PWR_CTR0/1 -->
508 <value value="0" name="PWR_CORE_CLOCK_CYCLES"/>
509 <value value="1" name="PWR_BUSY_CLOCK_CYCLES"/>
510 </enum>
511
512 <enum name="a4xx_rb_perfcounter_select">
513 <value value="0" name="RB_BUSY_CYCLES"/>
514 <value value="1" name="RB_BUSY_CYCLES_BINNING"/>
515 <value value="2" name="RB_BUSY_CYCLES_RENDERING"/>
516 <value value="3" name="RB_BUSY_CYCLES_RESOLVE"/>
517 <value value="4" name="RB_STARVE_CYCLES_BY_SP"/>
518 <value value="5" name="RB_STARVE_CYCLES_BY_RAS"/>
519 <value value="6" name="RB_STARVE_CYCLES_BY_MARB"/>
520 <value value="7" name="RB_STALL_CYCLES_BY_MARB"/>
521 <value value="8" name="RB_STALL_CYCLES_BY_HLSQ"/>
522 <value value="9" name="RB_RB_RB_MARB_DATA"/>
523 <value value="10" name="RB_SP_RB_QUAD"/>
524 <value value="11" name="RB_RAS_RB_Z_QUADS"/>
525 <value value="12" name="RB_GMEM_CH0_READ"/>
526 <value value="13" name="RB_GMEM_CH1_READ"/>
527 <value value="14" name="RB_GMEM_CH0_WRITE"/>
528 <value value="15" name="RB_GMEM_CH1_WRITE"/>
529 <value value="16" name="RB_CP_CONTEXT_DONE"/>
530 <value value="17" name="RB_CP_CACHE_FLUSH"/>
531 <value value="18" name="RB_CP_ZPASS_DONE"/>
532 <value value="19" name="RB_STALL_FIFO0_FULL"/>
533 <value value="20" name="RB_STALL_FIFO1_FULL"/>
534 <value value="21" name="RB_STALL_FIFO2_FULL"/>
535 <value value="22" name="RB_STALL_FIFO3_FULL"/>
536 <value value="23" name="RB_RB_HLSQ_TRANSACTIONS"/>
537 <value value="24" name="RB_Z_READ"/>
538 <value value="25" name="RB_Z_WRITE"/>
539 <value value="26" name="RB_C_READ"/>
540 <value value="27" name="RB_C_WRITE"/>
541 <value value="28" name="RB_C_READ_LATENCY"/>
542 <value value="29" name="RB_Z_READ_LATENCY"/>
543 <value value="30" name="RB_STALL_BY_UCHE"/>
544 <value value="31" name="RB_MARB_UCHE_TRANSACTIONS"/>
545 <value value="32" name="RB_CACHE_STALL_MISS"/>
546 <value value="33" name="RB_CACHE_STALL_FIFO_FULL"/>
547 <value value="34" name="RB_8BIT_BLENDER_UNITS_ACTIVE"/>
548 <value value="35" name="RB_16BIT_BLENDER_UNITS_ACTIVE"/>
549 <value value="36" name="RB_SAMPLER_UNITS_ACTIVE"/>
550 <value value="38" name="RB_TOTAL_PASS"/>
551 <value value="39" name="RB_Z_PASS"/>
552 <value value="40" name="RB_Z_FAIL"/>
553 <value value="41" name="RB_S_FAIL"/>
554 <value value="42" name="RB_POWER0"/>
555 <value value="43" name="RB_POWER1"/>
556 <value value="44" name="RB_POWER2"/>
557 <value value="45" name="RB_POWER3"/>
558 <value value="46" name="RB_POWER4"/>
559 <value value="47" name="RB_POWER5"/>
560 <value value="48" name="RB_POWER6"/>
561 <value value="49" name="RB_POWER7"/>
562 </enum>
563
564 <enum name="a4xx_rbbm_perfcounter_select">
565 <value value="0" name="RBBM_ALWAYS_ON"/>
566 <value value="1" name="RBBM_VBIF_BUSY"/>
567 <value value="2" name="RBBM_TSE_BUSY"/>
568 <value value="3" name="RBBM_RAS_BUSY"/>
569 <value value="4" name="RBBM_PC_DCALL_BUSY"/>
570 <value value="5" name="RBBM_PC_VSD_BUSY"/>
571 <value value="6" name="RBBM_VFD_BUSY"/>
572 <value value="7" name="RBBM_VPC_BUSY"/>
573 <value value="8" name="RBBM_UCHE_BUSY"/>
574 <value value="9" name="RBBM_VSC_BUSY"/>
575 <value value="10" name="RBBM_HLSQ_BUSY"/>
576 <value value="11" name="RBBM_ANY_RB_BUSY"/>
577 <value value="12" name="RBBM_ANY_TPL1_BUSY"/>
578 <value value="13" name="RBBM_ANY_SP_BUSY"/>
579 <value value="14" name="RBBM_ANY_MARB_BUSY"/>
580 <value value="15" name="RBBM_ANY_ARB_BUSY"/>
581 <value value="16" name="RBBM_AHB_STATUS_BUSY"/>
582 <value value="17" name="RBBM_AHB_STATUS_STALLED"/>
583 <value value="18" name="RBBM_AHB_STATUS_TXFR"/>
584 <value value="19" name="RBBM_AHB_STATUS_TXFR_SPLIT"/>
585 <value value="20" name="RBBM_AHB_STATUS_TXFR_ERROR"/>
586 <value value="21" name="RBBM_AHB_STATUS_LONG_STALL"/>
587 <value value="22" name="RBBM_STATUS_MASKED"/>
588 <value value="23" name="RBBM_CP_BUSY_GFX_CORE_IDLE"/>
589 <value value="24" name="RBBM_TESS_BUSY"/>
590 <value value="25" name="RBBM_COM_BUSY"/>
591 <value value="32" name="RBBM_DCOM_BUSY"/>
592 <value value="33" name="RBBM_ANY_CCU_BUSY"/>
593 <value value="34" name="RBBM_DPM_BUSY"/>
594 </enum>
595
596 <enum name="a4xx_sp_perfcounter_select">
597 <value value="0" name="SP_LM_LOAD_INSTRUCTIONS"/>
598 <value value="1" name="SP_LM_STORE_INSTRUCTIONS"/>
599 <value value="2" name="SP_LM_ATOMICS"/>
600 <value value="3" name="SP_GM_LOAD_INSTRUCTIONS"/>
601 <value value="4" name="SP_GM_STORE_INSTRUCTIONS"/>
602 <value value="5" name="SP_GM_ATOMICS"/>
603 <value value="6" name="SP_VS_STAGE_TEX_INSTRUCTIONS"/>
604 <value value="7" name="SP_VS_STAGE_CFLOW_INSTRUCTIONS"/>
605 <value value="8" name="SP_VS_STAGE_EFU_INSTRUCTIONS"/>
606 <value value="9" name="SP_VS_STAGE_FULL_ALU_INSTRUCTIONS"/>
607 <value value="10" name="SP_VS_STAGE_HALF_ALU_INSTRUCTIONS"/>
608 <value value="11" name="SP_FS_STAGE_TEX_INSTRUCTIONS"/>
609 <value value="12" name="SP_FS_STAGE_CFLOW_INSTRUCTIONS"/>
610 <value value="13" name="SP_FS_STAGE_EFU_INSTRUCTIONS"/>
611 <value value="14" name="SP_FS_STAGE_FULL_ALU_INSTRUCTIONS"/>
612 <value value="15" name="SP_FS_STAGE_HALF_ALU_INSTRUCTIONS"/>
613 <value value="17" name="SP_VS_INSTRUCTIONS"/>
614 <value value="18" name="SP_FS_INSTRUCTIONS"/>
615 <value value="19" name="SP_ADDR_LOCK_COUNT"/>
616 <value value="20" name="SP_UCHE_READ_TRANS"/>
617 <value value="21" name="SP_UCHE_WRITE_TRANS"/>
618 <value value="22" name="SP_EXPORT_VPC_TRANS"/>
619 <value value="23" name="SP_EXPORT_RB_TRANS"/>
620 <value value="24" name="SP_PIXELS_KILLED"/>
621 <value value="25" name="SP_ICL1_REQUESTS"/>
622 <value value="26" name="SP_ICL1_MISSES"/>
623 <value value="27" name="SP_ICL0_REQUESTS"/>
624 <value value="28" name="SP_ICL0_MISSES"/>
625 <value value="29" name="SP_ALU_WORKING_CYCLES"/>
626 <value value="30" name="SP_EFU_WORKING_CYCLES"/>
627 <value value="31" name="SP_STALL_CYCLES_BY_VPC"/>
628 <value value="32" name="SP_STALL_CYCLES_BY_TP"/>
629 <value value="33" name="SP_STALL_CYCLES_BY_UCHE"/>
630 <value value="34" name="SP_STALL_CYCLES_BY_RB"/>
631 <value value="35" name="SP_BUSY_CYCLES"/>
632 <value value="36" name="SP_HS_INSTRUCTIONS"/>
633 <value value="37" name="SP_DS_INSTRUCTIONS"/>
634 <value value="38" name="SP_GS_INSTRUCTIONS"/>
635 <value value="39" name="SP_CS_INSTRUCTIONS"/>
636 <value value="40" name="SP_SCHEDULER_NON_WORKING"/>
637 <value value="41" name="SP_WAVE_CONTEXTS"/>
638 <value value="42" name="SP_WAVE_CONTEXT_CYCLES"/>
639 <value value="43" name="SP_POWER0"/>
640 <value value="44" name="SP_POWER1"/>
641 <value value="45" name="SP_POWER2"/>
642 <value value="46" name="SP_POWER3"/>
643 <value value="47" name="SP_POWER4"/>
644 <value value="48" name="SP_POWER5"/>
645 <value value="49" name="SP_POWER6"/>
646 <value value="50" name="SP_POWER7"/>
647 <value value="51" name="SP_POWER8"/>
648 <value value="52" name="SP_POWER9"/>
649 <value value="53" name="SP_POWER10"/>
650 <value value="54" name="SP_POWER11"/>
651 <value value="55" name="SP_POWER12"/>
652 <value value="56" name="SP_POWER13"/>
653 <value value="57" name="SP_POWER14"/>
654 <value value="58" name="SP_POWER15"/>
655 </enum>
656
657 <enum name="a4xx_tp_perfcounter_select">
658 <value value="0" name="TP_L1_REQUESTS"/>
659 <value value="1" name="TP_L1_MISSES"/>
660 <value value="8" name="TP_QUADS_OFFSET"/>
661 <value value="9" name="TP_QUAD_SHADOW"/>
662 <value value="10" name="TP_QUADS_ARRAY"/>
663 <value value="11" name="TP_QUADS_GRADIENT"/>
664 <value value="12" name="TP_QUADS_1D2D"/>
665 <value value="13" name="TP_QUADS_3DCUBE"/>
666 <value value="16" name="TP_BUSY_CYCLES"/>
667 <value value="17" name="TP_STALL_CYCLES_BY_ARB"/>
668 <value value="20" name="TP_STATE_CACHE_REQUESTS"/>
669 <value value="21" name="TP_STATE_CACHE_MISSES"/>
670 <value value="22" name="TP_POWER0"/>
671 <value value="23" name="TP_POWER1"/>
672 <value value="24" name="TP_POWER2"/>
673 <value value="25" name="TP_POWER3"/>
674 <value value="26" name="TP_POWER4"/>
675 <value value="27" name="TP_POWER5"/>
676 <value value="28" name="TP_POWER6"/>
677 <value value="29" name="TP_POWER7"/>
678 </enum>
679
680 <enum name="a4xx_uche_perfcounter_select">
681 <value value="0" name="UCHE_VBIF_READ_BEATS_TP"/>
682 <value value="1" name="UCHE_VBIF_READ_BEATS_VFD"/>
683 <value value="2" name="UCHE_VBIF_READ_BEATS_HLSQ"/>
684 <value value="3" name="UCHE_VBIF_READ_BEATS_MARB"/>
685 <value value="4" name="UCHE_VBIF_READ_BEATS_SP"/>
686 <value value="5" name="UCHE_READ_REQUESTS_TP"/>
687 <value value="6" name="UCHE_READ_REQUESTS_VFD"/>
688 <value value="7" name="UCHE_READ_REQUESTS_HLSQ"/>
689 <value value="8" name="UCHE_READ_REQUESTS_MARB"/>
690 <value value="9" name="UCHE_READ_REQUESTS_SP"/>
691 <value value="10" name="UCHE_WRITE_REQUESTS_MARB"/>
692 <value value="11" name="UCHE_WRITE_REQUESTS_SP"/>
693 <value value="12" name="UCHE_TAG_CHECK_FAILS"/>
694 <value value="13" name="UCHE_EVICTS"/>
695 <value value="14" name="UCHE_FLUSHES"/>
696 <value value="15" name="UCHE_VBIF_LATENCY_CYCLES"/>
697 <value value="16" name="UCHE_VBIF_LATENCY_SAMPLES"/>
698 <value value="17" name="UCHE_BUSY_CYCLES"/>
699 <value value="18" name="UCHE_VBIF_READ_BEATS_PC"/>
700 <value value="19" name="UCHE_READ_REQUESTS_PC"/>
701 <value value="20" name="UCHE_WRITE_REQUESTS_VPC"/>
702 <value value="21" name="UCHE_STALL_BY_VBIF"/>
703 <value value="22" name="UCHE_WRITE_REQUESTS_VSC"/>
704 <value value="23" name="UCHE_POWER0"/>
705 <value value="24" name="UCHE_POWER1"/>
706 <value value="25" name="UCHE_POWER2"/>
707 <value value="26" name="UCHE_POWER3"/>
708 <value value="27" name="UCHE_POWER4"/>
709 <value value="28" name="UCHE_POWER5"/>
710 <value value="29" name="UCHE_POWER6"/>
711 <value value="30" name="UCHE_POWER7"/>
712 </enum>
713
714 <enum name="a4xx_vbif_perfcounter_select">
715 <value value="0" name="AXI_READ_REQUESTS_ID_0"/>
716 <value value="1" name="AXI_READ_REQUESTS_ID_1"/>
717 <value value="2" name="AXI_READ_REQUESTS_ID_2"/>
718 <value value="3" name="AXI_READ_REQUESTS_ID_3"/>
719 <value value="4" name="AXI_READ_REQUESTS_ID_4"/>
720 <value value="5" name="AXI_READ_REQUESTS_ID_5"/>
721 <value value="6" name="AXI_READ_REQUESTS_ID_6"/>
722 <value value="7" name="AXI_READ_REQUESTS_ID_7"/>
723 <value value="8" name="AXI_READ_REQUESTS_ID_8"/>
724 <value value="9" name="AXI_READ_REQUESTS_ID_9"/>
725 <value value="10" name="AXI_READ_REQUESTS_ID_10"/>
726 <value value="11" name="AXI_READ_REQUESTS_ID_11"/>
727 <value value="12" name="AXI_READ_REQUESTS_ID_12"/>
728 <value value="13" name="AXI_READ_REQUESTS_ID_13"/>
729 <value value="14" name="AXI_READ_REQUESTS_ID_14"/>
730 <value value="15" name="AXI_READ_REQUESTS_ID_15"/>
731 <value value="16" name="AXI0_READ_REQUESTS_TOTAL"/>
732 <value value="17" name="AXI1_READ_REQUESTS_TOTAL"/>
733 <value value="18" name="AXI2_READ_REQUESTS_TOTAL"/>
734 <value value="19" name="AXI3_READ_REQUESTS_TOTAL"/>
735 <value value="20" name="AXI_READ_REQUESTS_TOTAL"/>
736 <value value="21" name="AXI_WRITE_REQUESTS_ID_0"/>
737 <value value="22" name="AXI_WRITE_REQUESTS_ID_1"/>
738 <value value="23" name="AXI_WRITE_REQUESTS_ID_2"/>
739 <value value="24" name="AXI_WRITE_REQUESTS_ID_3"/>
740 <value value="25" name="AXI_WRITE_REQUESTS_ID_4"/>
741 <value value="26" name="AXI_WRITE_REQUESTS_ID_5"/>
742 <value value="27" name="AXI_WRITE_REQUESTS_ID_6"/>
743 <value value="28" name="AXI_WRITE_REQUESTS_ID_7"/>
744 <value value="29" name="AXI_WRITE_REQUESTS_ID_8"/>
745 <value value="30" name="AXI_WRITE_REQUESTS_ID_9"/>
746 <value value="31" name="AXI_WRITE_REQUESTS_ID_10"/>
747 <value value="32" name="AXI_WRITE_REQUESTS_ID_11"/>
748 <value value="33" name="AXI_WRITE_REQUESTS_ID_12"/>
749 <value value="34" name="AXI_WRITE_REQUESTS_ID_13"/>
750 <value value="35" name="AXI_WRITE_REQUESTS_ID_14"/>
751 <value value="36" name="AXI_WRITE_REQUESTS_ID_15"/>
752 <value value="37" name="AXI0_WRITE_REQUESTS_TOTAL"/>
753 <value value="38" name="AXI1_WRITE_REQUESTS_TOTAL"/>
754 <value value="39" name="AXI2_WRITE_REQUESTS_TOTAL"/>
755 <value value="40" name="AXI3_WRITE_REQUESTS_TOTAL"/>
756 <value value="41" name="AXI_WRITE_REQUESTS_TOTAL"/>
757 <value value="42" name="AXI_TOTAL_REQUESTS"/>
758 <value value="43" name="AXI_READ_DATA_BEATS_ID_0"/>
759 <value value="44" name="AXI_READ_DATA_BEATS_ID_1"/>
760 <value value="45" name="AXI_READ_DATA_BEATS_ID_2"/>
761 <value value="46" name="AXI_READ_DATA_BEATS_ID_3"/>
762 <value value="47" name="AXI_READ_DATA_BEATS_ID_4"/>
763 <value value="48" name="AXI_READ_DATA_BEATS_ID_5"/>
764 <value value="49" name="AXI_READ_DATA_BEATS_ID_6"/>
765 <value value="50" name="AXI_READ_DATA_BEATS_ID_7"/>
766 <value value="51" name="AXI_READ_DATA_BEATS_ID_8"/>
767 <value value="52" name="AXI_READ_DATA_BEATS_ID_9"/>
768 <value value="53" name="AXI_READ_DATA_BEATS_ID_10"/>
769 <value value="54" name="AXI_READ_DATA_BEATS_ID_11"/>
770 <value value="55" name="AXI_READ_DATA_BEATS_ID_12"/>
771 <value value="56" name="AXI_READ_DATA_BEATS_ID_13"/>
772 <value value="57" name="AXI_READ_DATA_BEATS_ID_14"/>
773 <value value="58" name="AXI_READ_DATA_BEATS_ID_15"/>
774 <value value="59" name="AXI0_READ_DATA_BEATS_TOTAL"/>
775 <value value="60" name="AXI1_READ_DATA_BEATS_TOTAL"/>
776 <value value="61" name="AXI2_READ_DATA_BEATS_TOTAL"/>
777 <value value="62" name="AXI3_READ_DATA_BEATS_TOTAL"/>
778 <value value="63" name="AXI_READ_DATA_BEATS_TOTAL"/>
779 <value value="64" name="AXI_WRITE_DATA_BEATS_ID_0"/>
780 <value value="65" name="AXI_WRITE_DATA_BEATS_ID_1"/>
781 <value value="66" name="AXI_WRITE_DATA_BEATS_ID_2"/>
782 <value value="67" name="AXI_WRITE_DATA_BEATS_ID_3"/>
783 <value value="68" name="AXI_WRITE_DATA_BEATS_ID_4"/>
784 <value value="69" name="AXI_WRITE_DATA_BEATS_ID_5"/>
785 <value value="70" name="AXI_WRITE_DATA_BEATS_ID_6"/>
786 <value value="71" name="AXI_WRITE_DATA_BEATS_ID_7"/>
787 <value value="72" name="AXI_WRITE_DATA_BEATS_ID_8"/>
788 <value value="73" name="AXI_WRITE_DATA_BEATS_ID_9"/>
789 <value value="74" name="AXI_WRITE_DATA_BEATS_ID_10"/>
790 <value value="75" name="AXI_WRITE_DATA_BEATS_ID_11"/>
791 <value value="76" name="AXI_WRITE_DATA_BEATS_ID_12"/>
792 <value value="77" name="AXI_WRITE_DATA_BEATS_ID_13"/>
793 <value value="78" name="AXI_WRITE_DATA_BEATS_ID_14"/>
794 <value value="79" name="AXI_WRITE_DATA_BEATS_ID_15"/>
795 <value value="80" name="AXI0_WRITE_DATA_BEATS_TOTAL"/>
796 <value value="81" name="AXI1_WRITE_DATA_BEATS_TOTAL"/>
797 <value value="82" name="AXI2_WRITE_DATA_BEATS_TOTAL"/>
798 <value value="83" name="AXI3_WRITE_DATA_BEATS_TOTAL"/>
799 <value value="84" name="AXI_WRITE_DATA_BEATS_TOTAL"/>
800 <value value="85" name="AXI_DATA_BEATS_TOTAL"/>
801 <value value="86" name="CYCLES_HELD_OFF_ID_0"/>
802 <value value="87" name="CYCLES_HELD_OFF_ID_1"/>
803 <value value="88" name="CYCLES_HELD_OFF_ID_2"/>
804 <value value="89" name="CYCLES_HELD_OFF_ID_3"/>
805 <value value="90" name="CYCLES_HELD_OFF_ID_4"/>
806 <value value="91" name="CYCLES_HELD_OFF_ID_5"/>
807 <value value="92" name="CYCLES_HELD_OFF_ID_6"/>
808 <value value="93" name="CYCLES_HELD_OFF_ID_7"/>
809 <value value="94" name="CYCLES_HELD_OFF_ID_8"/>
810 <value value="95" name="CYCLES_HELD_OFF_ID_9"/>
811 <value value="96" name="CYCLES_HELD_OFF_ID_10"/>
812 <value value="97" name="CYCLES_HELD_OFF_ID_11"/>
813 <value value="98" name="CYCLES_HELD_OFF_ID_12"/>
814 <value value="99" name="CYCLES_HELD_OFF_ID_13"/>
815 <value value="100" name="CYCLES_HELD_OFF_ID_14"/>
816 <value value="101" name="CYCLES_HELD_OFF_ID_15"/>
817 <value value="102" name="AXI_READ_REQUEST_HELD_OFF"/>
818 <value value="103" name="AXI_WRITE_REQUEST_HELD_OFF"/>
819 <value value="104" name="AXI_REQUEST_HELD_OFF"/>
820 <value value="105" name="AXI_WRITE_DATA_HELD_OFF"/>
821 <value value="106" name="OCMEM_AXI_READ_REQUEST_HELD_OFF"/>
822 <value value="107" name="OCMEM_AXI_WRITE_REQUEST_HELD_OFF"/>
823 <value value="108" name="OCMEM_AXI_REQUEST_HELD_OFF"/>
824 <value value="109" name="OCMEM_AXI_WRITE_DATA_HELD_OFF"/>
825 <value value="110" name="ELAPSED_CYCLES_DDR"/>
826 <value value="111" name="ELAPSED_CYCLES_OCMEM"/>
827 </enum>
828
829 <enum name="a4xx_vfd_perfcounter_select">
830 <value value="0" name="VFD_UCHE_BYTE_FETCHED"/>
831 <value value="1" name="VFD_UCHE_TRANS"/>
832 <value value="3" name="VFD_FETCH_INSTRUCTIONS"/>
833 <value value="5" name="VFD_BUSY_CYCLES"/>
834 <value value="6" name="VFD_STALL_CYCLES_UCHE"/>
835 <value value="7" name="VFD_STALL_CYCLES_HLSQ"/>
836 <value value="8" name="VFD_STALL_CYCLES_VPC_BYPASS"/>
837 <value value="9" name="VFD_STALL_CYCLES_VPC_ALLOC"/>
838 <value value="13" name="VFD_MODE_0_FIBERS"/>
839 <value value="14" name="VFD_MODE_1_FIBERS"/>
840 <value value="15" name="VFD_MODE_2_FIBERS"/>
841 <value value="16" name="VFD_MODE_3_FIBERS"/>
842 <value value="17" name="VFD_MODE_4_FIBERS"/>
843 <value value="18" name="VFD_BFIFO_STALL"/>
844 <value value="19" name="VFD_NUM_VERTICES_TOTAL"/>
845 <value value="20" name="VFD_PACKER_FULL"/>
846 <value value="21" name="VFD_UCHE_REQUEST_FIFO_FULL"/>
847 <value value="22" name="VFD_STARVE_CYCLES_PC"/>
848 <value value="23" name="VFD_STARVE_CYCLES_UCHE"/>
849 </enum>
850
851 <enum name="a4xx_vpc_perfcounter_select">
852 <value value="2" name="VPC_SP_LM_COMPONENTS"/>
853 <value value="3" name="VPC_SP0_LM_BYTES"/>
854 <value value="4" name="VPC_SP1_LM_BYTES"/>
855 <value value="5" name="VPC_SP2_LM_BYTES"/>
856 <value value="6" name="VPC_SP3_LM_BYTES"/>
857 <value value="7" name="VPC_WORKING_CYCLES"/>
858 <value value="8" name="VPC_STALL_CYCLES_LM"/>
859 <value value="9" name="VPC_STARVE_CYCLES_RAS"/>
860 <value value="10" name="VPC_STREAMOUT_CYCLES"/>
861 <value value="12" name="VPC_UCHE_TRANSACTIONS"/>
862 <value value="13" name="VPC_STALL_CYCLES_UCHE"/>
863 <value value="14" name="VPC_BUSY_CYCLES"/>
864 <value value="15" name="VPC_STARVE_CYCLES_SP"/>
865 </enum>
866
867 <enum name="a4xx_vsc_perfcounter_select">
868 <value value="0" name="VSC_BUSY_CYCLES"/>
869 <value value="1" name="VSC_WORKING_CYCLES"/>
870 <value value="2" name="VSC_STALL_CYCLES_UCHE"/>
871 <value value="3" name="VSC_STARVE_CYCLES_RAS"/>
872 <value value="4" name="VSC_EOT_NUM"/>
873 </enum>
874
875 <domain name="A4XX" width="32">
876 <!-- RB registers -->
877 <reg32 offset="0x0cc0" name="RB_GMEM_BASE_ADDR"/>
878 <reg32 offset="0x0cc7" name="RB_PERFCTR_RB_SEL_0" type="a4xx_rb_perfcounter_select"/>
879 <reg32 offset="0x0cc8" name="RB_PERFCTR_RB_SEL_1" type="a4xx_rb_perfcounter_select"/>
880 <reg32 offset="0x0cc9" name="RB_PERFCTR_RB_SEL_2" type="a4xx_rb_perfcounter_select"/>
881 <reg32 offset="0x0cca" name="RB_PERFCTR_RB_SEL_3" type="a4xx_rb_perfcounter_select"/>
882 <reg32 offset="0x0ccb" name="RB_PERFCTR_RB_SEL_4" type="a4xx_rb_perfcounter_select"/>
883 <reg32 offset="0x0ccc" name="RB_PERFCTR_RB_SEL_5" type="a4xx_rb_perfcounter_select"/>
884 <reg32 offset="0x0ccd" name="RB_PERFCTR_RB_SEL_6" type="a4xx_rb_perfcounter_select"/>
885 <reg32 offset="0x0cce" name="RB_PERFCTR_RB_SEL_7" type="a4xx_rb_perfcounter_select"/>
886 <reg32 offset="0x0ccf" name="RB_PERFCTR_CCU_SEL_0" type="a4xx_ccu_perfcounter_select"/>
887 <reg32 offset="0x0cd0" name="RB_PERFCTR_CCU_SEL_1" type="a4xx_ccu_perfcounter_select"/>
888 <reg32 offset="0x0cd1" name="RB_PERFCTR_CCU_SEL_2" type="a4xx_ccu_perfcounter_select"/>
889 <reg32 offset="0x0cd2" name="RB_PERFCTR_CCU_SEL_3" type="a4xx_ccu_perfcounter_select"/>
890 <reg32 offset="0x0ce0" name="RB_FRAME_BUFFER_DIMENSION">
891 <bitfield name="WIDTH" low="0" high="13" type="uint"/>
892 <bitfield name="HEIGHT" low="16" high="29" type="uint"/>
893 </reg32>
894 <reg32 offset="0x20cc" name="RB_CLEAR_COLOR_DW0"/>
895 <reg32 offset="0x20cd" name="RB_CLEAR_COLOR_DW1"/>
896 <reg32 offset="0x20ce" name="RB_CLEAR_COLOR_DW2"/>
897 <reg32 offset="0x20cf" name="RB_CLEAR_COLOR_DW3"/>
898 <reg32 offset="0x20a0" name="RB_MODE_CONTROL">
899 <!--
900 for non-bypass mode, these are bin width/height.. although
901 possibly bigger bitfields to hold entire width/height for
902 gmem-bypass?? Either way, it appears to need to be multiple
903 of 32..
904 -->
905 <bitfield name="WIDTH" low="0" high="5" shr="5" type="uint"/>
906 <bitfield name="HEIGHT" low="8" high="13" shr="5" type="uint"/>
907 <bitfield name="ENABLE_GMEM" pos="16" type="boolean"/>
908 </reg32>
909 <reg32 offset="0x20a1" name="RB_RENDER_CONTROL">
910 <bitfield name="BINNING_PASS" pos="0" type="boolean"/>
911 <!-- nearly everything has bit3 set.. -->
912 <!-- bit5 set on resolve and tiling pass -->
913 <bitfield name="DISABLE_COLOR_PIPE" pos="5" type="boolean"/>
914 </reg32>
915 <reg32 offset="0x20a2" name="RB_MSAA_CONTROL">
916 <bitfield name="DISABLE" pos="12" type="boolean"/>
917 <bitfield name="SAMPLES" low="13" high="15" type="uint"/>
918 </reg32>
919 <reg32 offset="0x20a3" name="RB_RENDER_CONTROL2">
920 <bitfield name="COORD_MASK" low="0" high="3" type="hex"/>
921 <bitfield name="SAMPLEMASK" pos="4" type="boolean"/>
922 <bitfield name="FACENESS" pos="5" type="boolean"/>
923 <bitfield name="SAMPLEID" pos="6" type="boolean"/>
924 <bitfield name="MSAA_SAMPLES" low="7" high="9" type="uint"/>
925 <bitfield name="SAMPLEID_HR" pos="11" type="boolean"/>
926 <bitfield name="VARYING" pos="12" type="boolean"/>
927 </reg32>
928 <array offset="0x20a4" name="RB_MRT" stride="5" length="8">
929 <reg32 offset="0x0" name="CONTROL">
930 <bitfield name="READ_DEST_ENABLE" pos="3" type="boolean"/>
931 <!-- both these bits seem to get set when enabling GL_BLEND.. -->
932 <bitfield name="BLEND" pos="4" type="boolean"/>
933 <bitfield name="BLEND2" pos="5" type="boolean"/>
934 <bitfield name="ROP_ENABLE" pos="6" type="boolean"/>
935 <bitfield name="ROP_CODE" low="8" high="11" type="a3xx_rop_code"/>
936 <bitfield name="COMPONENT_ENABLE" low="24" high="27" type="hex"/>
937 </reg32>
938 <reg32 offset="0x1" name="BUF_INFO">
939 <bitfield name="COLOR_FORMAT" low="0" high="5" type="a4xx_color_fmt"/>
940 <!--
941 guestimate position of COLOR_TILE_MODE.. this works out if
942 common value is 2, like on a3xx..
943 -->
944 <bitfield name="COLOR_TILE_MODE" low="6" high="7" type="a4xx_tile_mode"/>
945 <bitfield name="DITHER_MODE" low="9" high="10" type="adreno_rb_dither_mode"/>
946 <bitfield name="COLOR_SWAP" low="11" high="12" type="a3xx_color_swap"/>
947 <bitfield name="COLOR_SRGB" pos="13" type="boolean"/>
948 <!-- note: possibly some # of lsb's aren't there: -->
949 <doc>
950 Pitch (actually, appears to be pitch in bytes, so really is a stride)
951 in GMEM, so pitch of the current tile.
952 </doc>
953 <bitfield name="COLOR_BUF_PITCH" low="14" high="31" shr="4" type="uint"/>
954 </reg32>
955 <reg32 offset="0x2" name="BASE"/>
956 <reg32 offset="0x3" name="CONTROL3">
957 <!-- probably missing some lsb's.. and guessing upper size -->
958 <!-- pitch * cpp * msaa: -->
959 <bitfield name="STRIDE" low="3" high="25" type="uint"/>
960 </reg32>
961 <reg32 offset="0x4" name="BLEND_CONTROL">
962 <bitfield name="RGB_SRC_FACTOR" low="0" high="4" type="adreno_rb_blend_factor"/>
963 <bitfield name="RGB_BLEND_OPCODE" low="5" high="7" type="a3xx_rb_blend_opcode"/>
964 <bitfield name="RGB_DEST_FACTOR" low="8" high="12" type="adreno_rb_blend_factor"/>
965 <bitfield name="ALPHA_SRC_FACTOR" low="16" high="20" type="adreno_rb_blend_factor"/>
966 <bitfield name="ALPHA_BLEND_OPCODE" low="21" high="23" type="a3xx_rb_blend_opcode"/>
967 <bitfield name="ALPHA_DEST_FACTOR" low="24" high="28" type="adreno_rb_blend_factor"/>
968 </reg32>
969 </array>
970
971 <reg32 offset="0x20f0" name="RB_BLEND_RED">
972 <bitfield name="UINT" low="0" high="7" type="hex"/>
973 <bitfield name="SINT" low="8" high="15" type="hex"/>
974 <bitfield name="FLOAT" low="16" high="31" type="float"/>
975 </reg32>
976 <reg32 offset="0x20f1" name="RB_BLEND_RED_F32" type="float"/>
977
978 <reg32 offset="0x20f2" name="RB_BLEND_GREEN">
979 <bitfield name="UINT" low="0" high="7" type="hex"/>
980 <bitfield name="SINT" low="8" high="15" type="hex"/>
981 <bitfield name="FLOAT" low="16" high="31" type="float"/>
982 </reg32>
983 <reg32 offset="0x20f3" name="RB_BLEND_GREEN_F32" type="float"/>
984
985 <reg32 offset="0x20f4" name="RB_BLEND_BLUE">
986 <bitfield name="UINT" low="0" high="7" type="hex"/>
987 <bitfield name="SINT" low="8" high="15" type="hex"/>
988 <bitfield name="FLOAT" low="16" high="31" type="float"/>
989 </reg32>
990 <reg32 offset="0x20f5" name="RB_BLEND_BLUE_F32" type="float"/>
991
992 <reg32 offset="0x20f6" name="RB_BLEND_ALPHA">
993 <bitfield name="UINT" low="0" high="7" type="hex"/>
994 <bitfield name="SINT" low="8" high="15" type="hex"/>
995 <bitfield name="FLOAT" low="16" high="31" type="float"/>
996 </reg32>
997 <reg32 offset="0x20f7" name="RB_BLEND_ALPHA_F32" type="float"/>
998
999 <reg32 offset="0x20f8" name="RB_ALPHA_CONTROL">
1000 <bitfield name="ALPHA_REF" low="0" high="7" type="hex"/>
1001 <bitfield name="ALPHA_TEST" pos="8" type="boolean"/>
1002 <bitfield name="ALPHA_TEST_FUNC" low="9" high="11" type="adreno_compare_func"/>
1003 </reg32>
1004 <reg32 offset="0x20f9" name="RB_FS_OUTPUT">
1005 <!-- per-mrt enable bit -->
1006 <bitfield name="ENABLE_BLEND" low="0" high="7"/>
1007 <bitfield name="INDEPENDENT_BLEND" pos="8" type="boolean"/>
1008 <!-- a guess? -->
1009 <bitfield name="SAMPLE_MASK" low="16" high="31"/>
1010 </reg32>
1011 <reg32 offset="0x20fa" name="RB_SAMPLE_COUNT_CONTROL">
1012 <bitfield name="COPY" pos="1" type="boolean"/>
1013 <bitfield name="ADDR" low="2" high="31" shr="2"/>
1014 </reg32>
1015 <!-- always 00000000 for binning pass, else 0000000f: -->
1016 <reg32 offset="0x20fb" name="RB_RENDER_COMPONENTS">
1017 <bitfield name="RT0" low="0" high="3"/>
1018 <bitfield name="RT1" low="4" high="7"/>
1019 <bitfield name="RT2" low="8" high="11"/>
1020 <bitfield name="RT3" low="12" high="15"/>
1021 <bitfield name="RT4" low="16" high="19"/>
1022 <bitfield name="RT5" low="20" high="23"/>
1023 <bitfield name="RT6" low="24" high="27"/>
1024 <bitfield name="RT7" low="28" high="31"/>
1025 </reg32>
1026
1027 <reg32 offset="0x20fc" name="RB_COPY_CONTROL">
1028 <!-- not sure # of bits -->
1029 <bitfield name="MSAA_RESOLVE" low="0" high="1" type="a3xx_msaa_samples"/>
1030 <bitfield name="MODE" low="4" high="6" type="adreno_rb_copy_control_mode"/>
1031 <bitfield name="FASTCLEAR" low="8" high="11" type="hex"/>
1032 <bitfield name="GMEM_BASE" low="14" high="31" shr="14" type="hex"/>
1033 </reg32>
1034 <reg32 offset="0x20fd" name="RB_COPY_DEST_BASE">
1035 <bitfield name="BASE" low="5" high="31" shr="5" type="hex"/>
1036 </reg32>
1037 <reg32 offset="0x20fe" name="RB_COPY_DEST_PITCH">
1038 <doc>actually, appears to be pitch in bytes, so really is a stride</doc>
1039 <!-- not actually sure about max pitch... -->
1040 <bitfield name="PITCH" low="0" high="31" shr="5" type="uint"/>
1041 </reg32>
1042 <reg32 offset="0x20ff" name="RB_COPY_DEST_INFO">
1043 <bitfield name="FORMAT" low="2" high="7" type="a4xx_color_fmt"/>
1044 <bitfield name="SWAP" low="8" high="9" type="a3xx_color_swap"/>
1045 <bitfield name="DITHER_MODE" low="10" high="11" type="adreno_rb_dither_mode"/>
1046 <bitfield name="COMPONENT_ENABLE" low="14" high="17" type="hex"/>
1047 <bitfield name="ENDIAN" low="18" high="20" type="adreno_rb_surface_endian"/>
1048 <bitfield name="TILE" low="24" high="25" type="a4xx_tile_mode"/>
1049 </reg32>
1050 <reg32 offset="0x2100" name="RB_FS_OUTPUT_REG">
1051 <!-- bit0 set except for binning pass.. -->
1052 <bitfield name="MRT" low="0" high="3" type="uint"/>
1053 <bitfield name="FRAG_WRITES_Z" pos="5" type="boolean"/>
1054 </reg32>
1055 <reg32 offset="0x2101" name="RB_DEPTH_CONTROL">
1056 <!--
1057 guessing that this matches a2xx with the stencil fields
1058 moved out into RB_STENCIL_CONTROL?
1059 -->
1060 <bitfield name="FRAG_WRITES_Z" pos="0" type="boolean"/>
1061 <bitfield name="Z_ENABLE" pos="1" type="boolean"/>
1062 <bitfield name="Z_WRITE_ENABLE" pos="2" type="boolean"/>
1063 <bitfield name="ZFUNC" low="4" high="6" type="adreno_compare_func"/>
1064 <bitfield name="Z_CLAMP_ENABLE" pos="7" type="boolean"/>
1065 <bitfield name="EARLY_Z_DISABLE" pos="16" type="boolean"/>
1066 <bitfield name="FORCE_FRAGZ_TO_FS" pos="17" type="boolean"/>
1067 <doc>Z_TEST_ENABLE bit is set for zfunc other than GL_ALWAYS or GL_NEVER</doc>
1068 <bitfield name="Z_TEST_ENABLE" pos="31" type="boolean"/>
1069 </reg32>
1070 <reg32 offset="0x2102" name="RB_DEPTH_CLEAR"/>
1071 <reg32 offset="0x2103" name="RB_DEPTH_INFO">
1072 <bitfield name="DEPTH_FORMAT" low="0" high="1" type="a4xx_depth_format"/>
1073 <doc>
1074 DEPTH_BASE is offset in GMEM to depth/stencil buffer, ie
1075 bin_w * bin_h / 1024 (possible rounded up to multiple of
1076 something?? ie. 39 becomes 40, 78 becomes 80.. 75 becomes
1077 80.. so maybe it needs to be multiple of 8??
1078 </doc>
1079 <bitfield name="DEPTH_BASE" low="12" high="31" shr="12" type="hex"/>
1080 </reg32>
1081 <reg32 offset="0x2104" name="RB_DEPTH_PITCH" shr="5" type="uint">
1082 <doc>stride of depth/stencil buffer</doc>
1083 </reg32>
1084 <reg32 offset="0x2105" name="RB_DEPTH_PITCH2" shr="5" type="uint">
1085 <doc>???</doc>
1086 </reg32>
1087 <reg32 offset="0x2106" name="RB_STENCIL_CONTROL">
1088 <bitfield name="STENCIL_ENABLE" pos="0" type="boolean"/>
1089 <bitfield name="STENCIL_ENABLE_BF" pos="1" type="boolean"/>
1090 <!--
1091 set for stencil operations that require read from stencil
1092 buffer, but not for example for stencil clear (which does
1093 not require read).. so guessing this is analogous to
1094 READ_DEST_ENABLE for color buffer..
1095 -->
1096 <bitfield name="STENCIL_READ" pos="2" type="boolean"/>
1097 <bitfield name="FUNC" low="8" high="10" type="adreno_compare_func"/>
1098 <bitfield name="FAIL" low="11" high="13" type="adreno_stencil_op"/>
1099 <bitfield name="ZPASS" low="14" high="16" type="adreno_stencil_op"/>
1100 <bitfield name="ZFAIL" low="17" high="19" type="adreno_stencil_op"/>
1101 <bitfield name="FUNC_BF" low="20" high="22" type="adreno_compare_func"/>
1102 <bitfield name="FAIL_BF" low="23" high="25" type="adreno_stencil_op"/>
1103 <bitfield name="ZPASS_BF" low="26" high="28" type="adreno_stencil_op"/>
1104 <bitfield name="ZFAIL_BF" low="29" high="31" type="adreno_stencil_op"/>
1105 </reg32>
1106 <reg32 offset="0x2107" name="RB_STENCIL_CONTROL2">
1107 <!--
1108 This seems to be set by blob if there is a stencil buffer
1109 at all in GMEM, regardless of whether it is enabled for
1110 a particular draw (ie. RB_STENCIL_CONTROL). Not really
1111 sure if that is required or just a quirk of the blob
1112 -->
1113 <bitfield name="STENCIL_BUFFER" pos="0" type="boolean"/>
1114 </reg32>
1115 <reg32 offset="0x2108" name="RB_STENCIL_INFO">
1116 <bitfield name="SEPARATE_STENCIL" pos="0" type="boolean"/>
1117 <doc>Base address for stencil when not using interleaved depth/stencil</doc>
1118 <bitfield name="STENCIL_BASE" low="12" high="31" shr="12" type="hex"/>
1119 </reg32>
1120 <reg32 offset="0x2109" name="RB_STENCIL_PITCH" shr="5" type="uint">
1121 <doc>pitch of stencil buffer when not using interleaved depth/stencil</doc>
1122 </reg32>
1123
1124 <reg32 offset="0x210b" name="RB_STENCILREFMASK" type="adreno_rb_stencilrefmask"/>
1125 <reg32 offset="0x210c" name="RB_STENCILREFMASK_BF" type="adreno_rb_stencilrefmask"/>
1126 <reg32 offset="0x210d" name="RB_BIN_OFFSET" type="adreno_reg_xy"/>
1127 <array offset="0x2120" name="RB_VPORT_Z_CLAMP" stride="2" length="16">
1128 <reg32 offset="0x0" name="MIN"/>
1129 <reg32 offset="0x1" name="MAX"/>
1130 </array>
1131
1132 <!-- RBBM registers -->
1133 <reg32 offset="0x0000" name="RBBM_HW_VERSION"/>
1134 <reg32 offset="0x0002" name="RBBM_HW_CONFIGURATION"/>
1135 <array offset="0x4" name="RBBM_CLOCK_CTL_TP" stride="1" length="4">
1136 <reg32 offset="0x0" name="REG"/>
1137 </array>
1138 <array offset="0x8" name="RBBM_CLOCK_CTL2_TP" stride="1" length="4">
1139 <reg32 offset="0x0" name="REG"/>
1140 </array>
1141 <array offset="0xc" name="RBBM_CLOCK_HYST_TP" stride="1" length="4">
1142 <reg32 offset="0x0" name="REG"/>
1143 </array>
1144 <array offset="0x10" name="RBBM_CLOCK_DELAY_TP" stride="1" length="4">
1145 <reg32 offset="0x0" name="REG"/>
1146 </array>
1147 <reg32 offset="0x0014" name="RBBM_CLOCK_CTL_UCHE "/>
1148 <reg32 offset="0x0015" name="RBBM_CLOCK_CTL2_UCHE"/>
1149 <reg32 offset="0x0016" name="RBBM_CLOCK_CTL3_UCHE"/>
1150 <reg32 offset="0x0017" name="RBBM_CLOCK_CTL4_UCHE"/>
1151 <reg32 offset="0x0018" name="RBBM_CLOCK_HYST_UCHE"/>
1152 <reg32 offset="0x0019" name="RBBM_CLOCK_DELAY_UCHE"/>
1153 <reg32 offset="0x001a" name="RBBM_CLOCK_MODE_GPC"/>
1154 <reg32 offset="0x001b" name="RBBM_CLOCK_DELAY_GPC"/>
1155 <reg32 offset="0x001c" name="RBBM_CLOCK_HYST_GPC"/>
1156 <reg32 offset="0x001d" name="RBBM_CLOCK_CTL_TSE_RAS_RBBM"/>
1157 <reg32 offset="0x001e" name="RBBM_CLOCK_HYST_TSE_RAS_RBBM"/>
1158 <reg32 offset="0x001f" name="RBBM_CLOCK_DELAY_TSE_RAS_RBBM"/>
1159 <reg32 offset="0x0020" name="RBBM_CLOCK_CTL"/>
1160 <reg32 offset="0x0021" name="RBBM_SP_HYST_CNT"/>
1161 <reg32 offset="0x0022" name="RBBM_SW_RESET_CMD"/>
1162 <reg32 offset="0x0023" name="RBBM_AHB_CTL0"/>
1163 <reg32 offset="0x0024" name="RBBM_AHB_CTL1"/>
1164 <reg32 offset="0x0025" name="RBBM_AHB_CMD"/>
1165 <reg32 offset="0x0026" name="RBBM_RB_SUB_BLOCK_SEL_CTL"/>
1166 <reg32 offset="0x0028" name="RBBM_RAM_ACC_63_32"/>
1167 <reg32 offset="0x002b" name="RBBM_WAIT_IDLE_CLOCKS_CTL"/>
1168 <reg32 offset="0x002f" name="RBBM_INTERFACE_HANG_INT_CTL"/>
1169 <reg32 offset="0x0034" name="RBBM_INTERFACE_HANG_MASK_CTL4"/>
1170 <reg32 offset="0x0036" name="RBBM_INT_CLEAR_CMD"/>
1171 <reg32 offset="0x0037" name="RBBM_INT_0_MASK"/>
1172 <reg32 offset="0x003e" name="RBBM_RBBM_CTL"/>
1173 <reg32 offset="0x003f" name="RBBM_AHB_DEBUG_CTL"/>
1174 <reg32 offset="0x0041" name="RBBM_VBIF_DEBUG_CTL"/>
1175 <reg32 offset="0x0042" name="RBBM_CLOCK_CTL2"/>
1176 <reg32 offset="0x0045" name="RBBM_BLOCK_SW_RESET_CMD"/>
1177 <reg32 offset="0x0047" name="RBBM_RESET_CYCLES"/>
1178 <reg32 offset="0x0049" name="RBBM_EXT_TRACE_BUS_CTL"/>
1179 <reg32 offset="0x004a" name="RBBM_CFG_DEBBUS_SEL_A"/>
1180 <reg32 offset="0x004b" name="RBBM_CFG_DEBBUS_SEL_B"/>
1181 <reg32 offset="0x004c" name="RBBM_CFG_DEBBUS_SEL_C"/>
1182 <reg32 offset="0x004d" name="RBBM_CFG_DEBBUS_SEL_D"/>
1183 <reg32 offset="0x0098" name="RBBM_POWER_CNTL_IP">
1184 <bitfield name="SW_COLLAPSE" pos="0" type="boolean"/>
1185 <bitfield name="SP_TP_PWR_ON" pos="20" type="boolean"/>
1186 </reg32>
1187 <reg32 offset="0x009c" name="RBBM_PERFCTR_CP_0_LO"/>
1188 <reg32 offset="0x009d" name="RBBM_PERFCTR_CP_0_HI"/>
1189 <reg32 offset="0x009e" name="RBBM_PERFCTR_CP_1_LO"/>
1190 <reg32 offset="0x009f" name="RBBM_PERFCTR_CP_1_HI"/>
1191 <reg32 offset="0x00a0" name="RBBM_PERFCTR_CP_2_LO"/>
1192 <reg32 offset="0x00a1" name="RBBM_PERFCTR_CP_2_HI"/>
1193 <reg32 offset="0x00a2" name="RBBM_PERFCTR_CP_3_LO"/>
1194 <reg32 offset="0x00a3" name="RBBM_PERFCTR_CP_3_HI"/>
1195 <reg32 offset="0x00a4" name="RBBM_PERFCTR_CP_4_LO"/>
1196 <reg32 offset="0x00a5" name="RBBM_PERFCTR_CP_4_HI"/>
1197 <reg32 offset="0x00a6" name="RBBM_PERFCTR_CP_5_LO"/>
1198 <reg32 offset="0x00a7" name="RBBM_PERFCTR_CP_5_HI"/>
1199 <reg32 offset="0x00a8" name="RBBM_PERFCTR_CP_6_LO"/>
1200 <reg32 offset="0x00a9" name="RBBM_PERFCTR_CP_6_HI"/>
1201 <reg32 offset="0x00aa" name="RBBM_PERFCTR_CP_7_LO"/>
1202 <reg32 offset="0x00ab" name="RBBM_PERFCTR_CP_7_HI"/>
1203 <reg32 offset="0x00ac" name="RBBM_PERFCTR_RBBM_0_LO"/>
1204 <reg32 offset="0x00ad" name="RBBM_PERFCTR_RBBM_0_HI"/>
1205 <reg32 offset="0x00ae" name="RBBM_PERFCTR_RBBM_1_LO"/>
1206 <reg32 offset="0x00af" name="RBBM_PERFCTR_RBBM_1_HI"/>
1207 <reg32 offset="0x00b0" name="RBBM_PERFCTR_RBBM_2_LO"/>
1208 <reg32 offset="0x00b1" name="RBBM_PERFCTR_RBBM_2_HI"/>
1209 <reg32 offset="0x00b2" name="RBBM_PERFCTR_RBBM_3_LO"/>
1210 <reg32 offset="0x00b3" name="RBBM_PERFCTR_RBBM_3_HI"/>
1211 <reg32 offset="0x00b4" name="RBBM_PERFCTR_PC_0_LO"/>
1212 <reg32 offset="0x00b5" name="RBBM_PERFCTR_PC_0_HI"/>
1213 <reg32 offset="0x00b6" name="RBBM_PERFCTR_PC_1_LO"/>
1214 <reg32 offset="0x00b7" name="RBBM_PERFCTR_PC_1_HI"/>
1215 <reg32 offset="0x00b8" name="RBBM_PERFCTR_PC_2_LO"/>
1216 <reg32 offset="0x00b9" name="RBBM_PERFCTR_PC_2_HI"/>
1217 <reg32 offset="0x00ba" name="RBBM_PERFCTR_PC_3_LO"/>
1218 <reg32 offset="0x00bb" name="RBBM_PERFCTR_PC_3_HI"/>
1219 <reg32 offset="0x00bc" name="RBBM_PERFCTR_PC_4_LO"/>
1220 <reg32 offset="0x00bd" name="RBBM_PERFCTR_PC_4_HI"/>
1221 <reg32 offset="0x00be" name="RBBM_PERFCTR_PC_5_LO"/>
1222 <reg32 offset="0x00bf" name="RBBM_PERFCTR_PC_5_HI"/>
1223 <reg32 offset="0x00c0" name="RBBM_PERFCTR_PC_6_LO"/>
1224 <reg32 offset="0x00c1" name="RBBM_PERFCTR_PC_6_HI"/>
1225 <reg32 offset="0x00c2" name="RBBM_PERFCTR_PC_7_LO"/>
1226 <reg32 offset="0x00c3" name="RBBM_PERFCTR_PC_7_HI"/>
1227 <reg32 offset="0x00c4" name="RBBM_PERFCTR_VFD_0_LO"/>
1228 <reg32 offset="0x00c5" name="RBBM_PERFCTR_VFD_0_HI"/>
1229 <reg32 offset="0x00c6" name="RBBM_PERFCTR_VFD_1_LO"/>
1230 <reg32 offset="0x00c7" name="RBBM_PERFCTR_VFD_1_HI"/>
1231 <reg32 offset="0x00c8" name="RBBM_PERFCTR_VFD_2_LO"/>
1232 <reg32 offset="0x00c9" name="RBBM_PERFCTR_VFD_2_HI"/>
1233 <reg32 offset="0x00ca" name="RBBM_PERFCTR_VFD_3_LO"/>
1234 <reg32 offset="0x00cb" name="RBBM_PERFCTR_VFD_3_HI"/>
1235 <reg32 offset="0x00cc" name="RBBM_PERFCTR_VFD_4_LO"/>
1236 <reg32 offset="0x00cd" name="RBBM_PERFCTR_VFD_4_HI"/>
1237 <reg32 offset="0x00ce" name="RBBM_PERFCTR_VFD_5_LO"/>
1238 <reg32 offset="0x00cf" name="RBBM_PERFCTR_VFD_5_HI"/>
1239 <reg32 offset="0x00d0" name="RBBM_PERFCTR_VFD_6_LO"/>
1240 <reg32 offset="0x00d1" name="RBBM_PERFCTR_VFD_6_HI"/>
1241 <reg32 offset="0x00d2" name="RBBM_PERFCTR_VFD_7_LO"/>
1242 <reg32 offset="0x00d3" name="RBBM_PERFCTR_VFD_7_HI"/>
1243 <reg32 offset="0x00d4" name="RBBM_PERFCTR_HLSQ_0_LO"/>
1244 <reg32 offset="0x00d5" name="RBBM_PERFCTR_HLSQ_0_HI"/>
1245 <reg32 offset="0x00d6" name="RBBM_PERFCTR_HLSQ_1_LO"/>
1246 <reg32 offset="0x00d7" name="RBBM_PERFCTR_HLSQ_1_HI"/>
1247 <reg32 offset="0x00d8" name="RBBM_PERFCTR_HLSQ_2_LO"/>
1248 <reg32 offset="0x00d9" name="RBBM_PERFCTR_HLSQ_2_HI"/>
1249 <reg32 offset="0x00da" name="RBBM_PERFCTR_HLSQ_3_LO"/>
1250 <reg32 offset="0x00db" name="RBBM_PERFCTR_HLSQ_3_HI"/>
1251 <reg32 offset="0x00dc" name="RBBM_PERFCTR_HLSQ_4_LO"/>
1252 <reg32 offset="0x00dd" name="RBBM_PERFCTR_HLSQ_4_HI"/>
1253 <reg32 offset="0x00de" name="RBBM_PERFCTR_HLSQ_5_LO"/>
1254 <reg32 offset="0x00df" name="RBBM_PERFCTR_HLSQ_5_HI"/>
1255 <reg32 offset="0x00e0" name="RBBM_PERFCTR_HLSQ_6_LO"/>
1256 <reg32 offset="0x00e1" name="RBBM_PERFCTR_HLSQ_6_HI"/>
1257 <reg32 offset="0x00e2" name="RBBM_PERFCTR_HLSQ_7_LO"/>
1258 <reg32 offset="0x00e3" name="RBBM_PERFCTR_HLSQ_7_HI"/>
1259 <reg32 offset="0x00e4" name="RBBM_PERFCTR_VPC_0_LO"/>
1260 <reg32 offset="0x00e5" name="RBBM_PERFCTR_VPC_0_HI"/>
1261 <reg32 offset="0x00e6" name="RBBM_PERFCTR_VPC_1_LO"/>
1262 <reg32 offset="0x00e7" name="RBBM_PERFCTR_VPC_1_HI"/>
1263 <reg32 offset="0x00e8" name="RBBM_PERFCTR_VPC_2_LO"/>
1264 <reg32 offset="0x00e9" name="RBBM_PERFCTR_VPC_2_HI"/>
1265 <reg32 offset="0x00ea" name="RBBM_PERFCTR_VPC_3_LO"/>
1266 <reg32 offset="0x00eb" name="RBBM_PERFCTR_VPC_3_HI"/>
1267 <reg32 offset="0x00ec" name="RBBM_PERFCTR_CCU_0_LO"/>
1268 <reg32 offset="0x00ed" name="RBBM_PERFCTR_CCU_0_HI"/>
1269 <reg32 offset="0x00ee" name="RBBM_PERFCTR_CCU_1_LO"/>
1270 <reg32 offset="0x00ef" name="RBBM_PERFCTR_CCU_1_HI"/>
1271 <reg32 offset="0x00f0" name="RBBM_PERFCTR_CCU_2_LO"/>
1272 <reg32 offset="0x00f1" name="RBBM_PERFCTR_CCU_2_HI"/>
1273 <reg32 offset="0x00f2" name="RBBM_PERFCTR_CCU_3_LO"/>
1274 <reg32 offset="0x00f3" name="RBBM_PERFCTR_CCU_3_HI"/>
1275 <reg32 offset="0x00f4" name="RBBM_PERFCTR_TSE_0_LO"/>
1276 <reg32 offset="0x00f5" name="RBBM_PERFCTR_TSE_0_HI"/>
1277 <reg32 offset="0x00f6" name="RBBM_PERFCTR_TSE_1_LO"/>
1278 <reg32 offset="0x00f7" name="RBBM_PERFCTR_TSE_1_HI"/>
1279 <reg32 offset="0x00f8" name="RBBM_PERFCTR_TSE_2_LO"/>
1280 <reg32 offset="0x00f9" name="RBBM_PERFCTR_TSE_2_HI"/>
1281 <reg32 offset="0x00fa" name="RBBM_PERFCTR_TSE_3_LO"/>
1282 <reg32 offset="0x00fb" name="RBBM_PERFCTR_TSE_3_HI"/>
1283 <reg32 offset="0x00fc" name="RBBM_PERFCTR_RAS_0_LO"/>
1284 <reg32 offset="0x00fd" name="RBBM_PERFCTR_RAS_0_HI"/>
1285 <reg32 offset="0x00fe" name="RBBM_PERFCTR_RAS_1_LO"/>
1286 <reg32 offset="0x00ff" name="RBBM_PERFCTR_RAS_1_HI"/>
1287 <reg32 offset="0x0100" name="RBBM_PERFCTR_RAS_2_LO"/>
1288 <reg32 offset="0x0101" name="RBBM_PERFCTR_RAS_2_HI"/>
1289 <reg32 offset="0x0102" name="RBBM_PERFCTR_RAS_3_LO"/>
1290 <reg32 offset="0x0103" name="RBBM_PERFCTR_RAS_3_HI"/>
1291 <reg32 offset="0x0104" name="RBBM_PERFCTR_UCHE_0_LO"/>
1292 <reg32 offset="0x0105" name="RBBM_PERFCTR_UCHE_0_HI"/>
1293 <reg32 offset="0x0106" name="RBBM_PERFCTR_UCHE_1_LO"/>
1294 <reg32 offset="0x0107" name="RBBM_PERFCTR_UCHE_1_HI"/>
1295 <reg32 offset="0x0108" name="RBBM_PERFCTR_UCHE_2_LO"/>
1296 <reg32 offset="0x0109" name="RBBM_PERFCTR_UCHE_2_HI"/>
1297 <reg32 offset="0x010a" name="RBBM_PERFCTR_UCHE_3_LO"/>
1298 <reg32 offset="0x010b" name="RBBM_PERFCTR_UCHE_3_HI"/>
1299 <reg32 offset="0x010c" name="RBBM_PERFCTR_UCHE_4_LO"/>
1300 <reg32 offset="0x010d" name="RBBM_PERFCTR_UCHE_4_HI"/>
1301 <reg32 offset="0x010e" name="RBBM_PERFCTR_UCHE_5_LO"/>
1302 <reg32 offset="0x010f" name="RBBM_PERFCTR_UCHE_5_HI"/>
1303 <reg32 offset="0x0110" name="RBBM_PERFCTR_UCHE_6_LO"/>
1304 <reg32 offset="0x0111" name="RBBM_PERFCTR_UCHE_6_HI"/>
1305 <reg32 offset="0x0112" name="RBBM_PERFCTR_UCHE_7_LO"/>
1306 <reg32 offset="0x0113" name="RBBM_PERFCTR_UCHE_7_HI"/>
1307 <reg32 offset="0x0114" name="RBBM_PERFCTR_TP_0_LO"/>
1308 <reg32 offset="0x0115" name="RBBM_PERFCTR_TP_0_HI"/>
1309 <reg32 offset="0x0116" name="RBBM_PERFCTR_TP_1_LO"/>
1310 <reg32 offset="0x0117" name="RBBM_PERFCTR_TP_1_HI"/>
1311 <reg32 offset="0x0118" name="RBBM_PERFCTR_TP_2_LO"/>
1312 <reg32 offset="0x0119" name="RBBM_PERFCTR_TP_2_HI"/>
1313 <reg32 offset="0x011a" name="RBBM_PERFCTR_TP_3_LO"/>
1314 <reg32 offset="0x011b" name="RBBM_PERFCTR_TP_3_HI"/>
1315 <reg32 offset="0x011c" name="RBBM_PERFCTR_TP_4_LO"/>
1316 <reg32 offset="0x011d" name="RBBM_PERFCTR_TP_4_HI"/>
1317 <reg32 offset="0x011e" name="RBBM_PERFCTR_TP_5_LO"/>
1318 <reg32 offset="0x011f" name="RBBM_PERFCTR_TP_5_HI"/>
1319 <reg32 offset="0x0120" name="RBBM_PERFCTR_TP_6_LO"/>
1320 <reg32 offset="0x0121" name="RBBM_PERFCTR_TP_6_HI"/>
1321 <reg32 offset="0x0122" name="RBBM_PERFCTR_TP_7_LO"/>
1322 <reg32 offset="0x0123" name="RBBM_PERFCTR_TP_7_HI"/>
1323 <reg32 offset="0x0124" name="RBBM_PERFCTR_SP_0_LO"/>
1324 <reg32 offset="0x0125" name="RBBM_PERFCTR_SP_0_HI"/>
1325 <reg32 offset="0x0126" name="RBBM_PERFCTR_SP_1_LO"/>
1326 <reg32 offset="0x0127" name="RBBM_PERFCTR_SP_1_HI"/>
1327 <reg32 offset="0x0128" name="RBBM_PERFCTR_SP_2_LO"/>
1328 <reg32 offset="0x0129" name="RBBM_PERFCTR_SP_2_HI"/>
1329 <reg32 offset="0x012a" name="RBBM_PERFCTR_SP_3_LO"/>
1330 <reg32 offset="0x012b" name="RBBM_PERFCTR_SP_3_HI"/>
1331 <reg32 offset="0x012c" name="RBBM_PERFCTR_SP_4_LO"/>
1332 <reg32 offset="0x012d" name="RBBM_PERFCTR_SP_4_HI"/>
1333 <reg32 offset="0x012e" name="RBBM_PERFCTR_SP_5_LO"/>
1334 <reg32 offset="0x012f" name="RBBM_PERFCTR_SP_5_HI"/>
1335 <reg32 offset="0x0130" name="RBBM_PERFCTR_SP_6_LO"/>
1336 <reg32 offset="0x0131" name="RBBM_PERFCTR_SP_6_HI"/>
1337 <reg32 offset="0x0132" name="RBBM_PERFCTR_SP_7_LO"/>
1338 <reg32 offset="0x0133" name="RBBM_PERFCTR_SP_7_HI"/>
1339 <reg32 offset="0x0134" name="RBBM_PERFCTR_SP_8_LO"/>
1340 <reg32 offset="0x0135" name="RBBM_PERFCTR_SP_8_HI"/>
1341 <reg32 offset="0x0136" name="RBBM_PERFCTR_SP_9_LO"/>
1342 <reg32 offset="0x0137" name="RBBM_PERFCTR_SP_9_HI"/>
1343 <reg32 offset="0x0138" name="RBBM_PERFCTR_SP_10_LO"/>
1344 <reg32 offset="0x0139" name="RBBM_PERFCTR_SP_10_HI"/>
1345 <reg32 offset="0x013a" name="RBBM_PERFCTR_SP_11_LO"/>
1346 <reg32 offset="0x013b" name="RBBM_PERFCTR_SP_11_HI"/>
1347 <reg32 offset="0x013c" name="RBBM_PERFCTR_RB_0_LO"/>
1348 <reg32 offset="0x013d" name="RBBM_PERFCTR_RB_0_HI"/>
1349 <reg32 offset="0x013e" name="RBBM_PERFCTR_RB_1_LO"/>
1350 <reg32 offset="0x013f" name="RBBM_PERFCTR_RB_1_HI"/>
1351 <reg32 offset="0x0140" name="RBBM_PERFCTR_RB_2_LO"/>
1352 <reg32 offset="0x0141" name="RBBM_PERFCTR_RB_2_HI"/>
1353 <reg32 offset="0x0142" name="RBBM_PERFCTR_RB_3_LO"/>
1354 <reg32 offset="0x0143" name="RBBM_PERFCTR_RB_3_HI"/>
1355 <reg32 offset="0x0144" name="RBBM_PERFCTR_RB_4_LO"/>
1356 <reg32 offset="0x0145" name="RBBM_PERFCTR_RB_4_HI"/>
1357 <reg32 offset="0x0146" name="RBBM_PERFCTR_RB_5_LO"/>
1358 <reg32 offset="0x0147" name="RBBM_PERFCTR_RB_5_HI"/>
1359 <reg32 offset="0x0148" name="RBBM_PERFCTR_RB_6_LO"/>
1360 <reg32 offset="0x0149" name="RBBM_PERFCTR_RB_6_HI"/>
1361 <reg32 offset="0x014a" name="RBBM_PERFCTR_RB_7_LO"/>
1362 <reg32 offset="0x014b" name="RBBM_PERFCTR_RB_7_HI"/>
1363 <reg32 offset="0x014c" name="RBBM_PERFCTR_VSC_0_LO"/>
1364 <reg32 offset="0x014d" name="RBBM_PERFCTR_VSC_0_HI"/>
1365 <reg32 offset="0x014e" name="RBBM_PERFCTR_VSC_1_LO"/>
1366 <reg32 offset="0x014f" name="RBBM_PERFCTR_VSC_1_HI"/>
1367 <reg32 offset="0x0166" name="RBBM_PERFCTR_PWR_0_LO"/>
1368 <reg32 offset="0x0167" name="RBBM_PERFCTR_PWR_0_HI"/>
1369 <reg32 offset="0x0168" name="RBBM_PERFCTR_PWR_1_LO"/>
1370 <reg32 offset="0x0169" name="RBBM_PERFCTR_PWR_1_HI"/>
1371 <reg32 offset="0x016e" name="RBBM_ALWAYSON_COUNTER_LO"/>
1372 <reg32 offset="0x016f" name="RBBM_ALWAYSON_COUNTER_HI"/>
1373 <array offset="0x0068" name="RBBM_CLOCK_CTL_SP" stride="1" length="4">
1374 <reg32 offset="0x0" name="REG"/>
1375 </array>
1376 <array offset="0x006c" name="RBBM_CLOCK_CTL2_SP" stride="1" length="4">
1377 <reg32 offset="0x0" name="REG"/>
1378 </array>
1379 <array offset="0x0070" name="RBBM_CLOCK_HYST_SP" stride="1" length="4">
1380 <reg32 offset="0x0" name="REG"/>
1381 </array>
1382 <array offset="0x0074" name="RBBM_CLOCK_DELAY_SP" stride="1" length="4">
1383 <reg32 offset="0x0" name="REG"/>
1384 </array>
1385 <array offset="0x0078" name="RBBM_CLOCK_CTL_RB" stride="1" length="4">
1386 <reg32 offset="0x0" name="REG"/>
1387 </array>
1388 <array offset="0x007c" name="RBBM_CLOCK_CTL2_RB" stride="1" length="4">
1389 <reg32 offset="0x0" name="REG"/>
1390 </array>
1391 <array offset="0x0082" name="RBBM_CLOCK_CTL_MARB_CCU" stride="1" length="4">
1392 <reg32 offset="0x0" name="REG"/>
1393 </array>
1394 <array offset="0x0086" name="RBBM_CLOCK_HYST_RB_MARB_CCU" stride="1" length="4">
1395 <reg32 offset="0x0" name="REG"/>
1396 </array>
1397 <reg32 offset="0x0080" name="RBBM_CLOCK_HYST_COM_DCOM"/>
1398 <reg32 offset="0x0081" name="RBBM_CLOCK_CTL_COM_DCOM"/>
1399 <reg32 offset="0x008a" name="RBBM_CLOCK_CTL_HLSQ"/>
1400 <reg32 offset="0x008b" name="RBBM_CLOCK_HYST_HLSQ"/>
1401 <reg32 offset="0x008c" name="RBBM_CLOCK_DELAY_HLSQ"/>
1402 <bitset name="A4XX_CGC_HLSQ">
1403 <bitfield name="EARLY_CYC" low="20" high="22" type="uint"/>
1404 </bitset>
1405 <reg32 offset="0x008d" name="RBBM_CLOCK_DELAY_COM_DCOM"/>
1406 <array offset="0x008e" name="RBBM_CLOCK_DELAY_RB_MARB_CCU_L1" stride="1" length="4">
1407 <reg32 offset="0x0" name="REG"/>
1408 </array>
1409 <bitset name="A4XX_INT0">
1410 <bitfield name="RBBM_GPU_IDLE" pos="0"/>
1411 <bitfield name="RBBM_AHB_ERROR" pos="1"/>
1412 <bitfield name="RBBM_REG_TIMEOUT" pos="2"/>
1413 <bitfield name="RBBM_ME_MS_TIMEOUT" pos="3"/>
1414 <bitfield name="RBBM_PFP_MS_TIMEOUT" pos="4"/>
1415 <bitfield name="RBBM_ATB_BUS_OVERFLOW" pos="5"/>
1416 <bitfield name="VFD_ERROR" pos="6"/>
1417 <bitfield name="CP_SW_INT" pos="7"/>
1418 <bitfield name="CP_T0_PACKET_IN_IB" pos="8"/>
1419 <bitfield name="CP_OPCODE_ERROR" pos="9"/>
1420 <bitfield name="CP_RESERVED_BIT_ERROR" pos="10"/>
1421 <bitfield name="CP_HW_FAULT" pos="11"/>
1422 <bitfield name="CP_DMA" pos="12"/>
1423 <bitfield name="CP_IB2_INT" pos="13"/>
1424 <bitfield name="CP_IB1_INT" pos="14"/>
1425 <bitfield name="CP_RB_INT" pos="15"/>
1426 <bitfield name="CP_REG_PROTECT_FAULT" pos="16"/>
1427 <bitfield name="CP_RB_DONE_TS" pos="17"/>
1428 <bitfield name="CP_VS_DONE_TS" pos="18"/>
1429 <bitfield name="CP_PS_DONE_TS" pos="19"/>
1430 <bitfield name="CACHE_FLUSH_TS" pos="20"/>
1431 <bitfield name="CP_AHB_ERROR_HALT" pos="21"/>
1432 <bitfield name="MISC_HANG_DETECT" pos="24"/>
1433 <bitfield name="UCHE_OOB_ACCESS" pos="25"/>
1434 </bitset>
1435
1436 <reg32 offset="0x0099" name="RBBM_SP_REGFILE_SLEEP_CNTL_0"/>
1437 <reg32 offset="0x009a" name="RBBM_SP_REGFILE_SLEEP_CNTL_1"/>
1438 <reg32 offset="0x0170" name="RBBM_PERFCTR_CTL"/>
1439 <reg32 offset="0x0171" name="RBBM_PERFCTR_LOAD_CMD0"/>
1440 <reg32 offset="0x0172" name="RBBM_PERFCTR_LOAD_CMD1"/>
1441 <reg32 offset="0x0173" name="RBBM_PERFCTR_LOAD_CMD2"/>
1442 <reg32 offset="0x0174" name="RBBM_PERFCTR_LOAD_VALUE_LO"/>
1443 <reg32 offset="0x0175" name="RBBM_PERFCTR_LOAD_VALUE_HI"/>
1444 <reg32 offset="0x0176" name="RBBM_PERFCTR_RBBM_SEL_0" type="a4xx_rbbm_perfcounter_select"/>
1445 <reg32 offset="0x0177" name="RBBM_PERFCTR_RBBM_SEL_1" type="a4xx_rbbm_perfcounter_select"/>
1446 <reg32 offset="0x0178" name="RBBM_PERFCTR_RBBM_SEL_2" type="a4xx_rbbm_perfcounter_select"/>
1447 <reg32 offset="0x0179" name="RBBM_PERFCTR_RBBM_SEL_3" type="a4xx_rbbm_perfcounter_select"/>
1448 <reg32 offset="0x017a" name="RBBM_GPU_BUSY_MASKED"/>
1449 <reg32 offset="0x017d" name="RBBM_INT_0_STATUS"/>
1450 <reg32 offset="0x0182" name="RBBM_CLOCK_STATUS"/>
1451 <reg32 offset="0x0189" name="RBBM_AHB_STATUS"/>
1452 <reg32 offset="0x018c" name="RBBM_AHB_ME_SPLIT_STATUS"/>
1453 <reg32 offset="0x018d" name="RBBM_AHB_PFP_SPLIT_STATUS"/>
1454 <reg32 offset="0x018f" name="RBBM_AHB_ERROR_STATUS"/>
1455 <reg32 offset="0x0191" name="RBBM_STATUS">
1456 <bitfield name="HI_BUSY" pos="0" type="boolean"/>
1457 <bitfield name="CP_ME_BUSY" pos="1" type="boolean"/>
1458 <bitfield name="CP_PFP_BUSY" pos="2" type="boolean"/>
1459 <bitfield name="CP_NRT_BUSY" pos="14" type="boolean"/>
1460 <bitfield name="VBIF_BUSY" pos="15" type="boolean"/>
1461 <bitfield name="TSE_BUSY" pos="16" type="boolean"/>
1462 <bitfield name="RAS_BUSY" pos="17" type="boolean"/>
1463 <bitfield name="RB_BUSY" pos="18" type="boolean"/>
1464 <bitfield name="PC_DCALL_BUSY" pos="19" type="boolean"/>
1465 <bitfield name="PC_VSD_BUSY" pos="20" type="boolean"/>
1466 <bitfield name="VFD_BUSY" pos="21" type="boolean"/>
1467 <bitfield name="VPC_BUSY" pos="22" type="boolean"/>
1468 <bitfield name="UCHE_BUSY" pos="23" type="boolean"/>
1469 <bitfield name="SP_BUSY" pos="24" type="boolean"/>
1470 <bitfield name="TPL1_BUSY" pos="25" type="boolean"/>
1471 <bitfield name="MARB_BUSY" pos="26" type="boolean"/>
1472 <bitfield name="VSC_BUSY" pos="27" type="boolean"/>
1473 <bitfield name="ARB_BUSY" pos="28" type="boolean"/>
1474 <bitfield name="HLSQ_BUSY" pos="29" type="boolean"/>
1475 <bitfield name="GPU_BUSY_NOHC" pos="30" type="boolean"/>
1476 <bitfield name="GPU_BUSY" pos="31" type="boolean"/>
1477 </reg32>
1478 <reg32 offset="0x019f" name="RBBM_INTERFACE_RRDY_STATUS5"/>
1479 <reg32 offset="0x01b0" name="RBBM_POWER_STATUS">
1480 <bitfield name="SP_TP_PWR_ON" pos="20" type="boolean"/>
1481 </reg32>
1482 <reg32 offset="0x01b8" name="RBBM_WAIT_IDLE_CLOCKS_CTL2"/>
1483
1484 <!-- CP registers -->
1485 <reg32 offset="0x0228" name="CP_SCRATCH_UMASK"/>
1486 <reg32 offset="0x0229" name="CP_SCRATCH_ADDR"/>
1487 <reg32 offset="0x0200" name="CP_RB_BASE"/>
1488 <reg32 offset="0x0201" name="CP_RB_CNTL"/>
1489 <reg32 offset="0x0205" name="CP_RB_WPTR"/>
1490 <reg32 offset="0x0203" name="CP_RB_RPTR_ADDR"/>
1491 <reg32 offset="0x0204" name="CP_RB_RPTR"/>
1492 <reg32 offset="0x0206" name="CP_IB1_BASE"/>
1493 <reg32 offset="0x0207" name="CP_IB1_BUFSZ"/>
1494 <reg32 offset="0x0208" name="CP_IB2_BASE"/>
1495 <reg32 offset="0x0209" name="CP_IB2_BUFSZ"/>
1496 <reg32 offset="0x020c" name="CP_ME_NRT_ADDR"/>
1497 <reg32 offset="0x020d" name="CP_ME_NRT_DATA"/>
1498 <reg32 offset="0x0217" name="CP_ME_RB_DONE_DATA"/>
1499 <reg32 offset="0x0219" name="CP_QUEUE_THRESH2"/>
1500 <reg32 offset="0x021b" name="CP_MERCIU_SIZE"/>
1501 <reg32 offset="0x021c" name="CP_ROQ_ADDR"/>
1502 <reg32 offset="0x021d" name="CP_ROQ_DATA"/>
1503 <reg32 offset="0x021e" name="CP_MEQ_ADDR"/>
1504 <reg32 offset="0x021f" name="CP_MEQ_DATA"/>
1505 <reg32 offset="0x0220" name="CP_MERCIU_ADDR"/>
1506 <reg32 offset="0x0221" name="CP_MERCIU_DATA"/>
1507 <reg32 offset="0x0222" name="CP_MERCIU_DATA2"/>
1508 <reg32 offset="0x0223" name="CP_PFP_UCODE_ADDR"/>
1509 <reg32 offset="0x0224" name="CP_PFP_UCODE_DATA"/>
1510 <reg32 offset="0x0225" name="CP_ME_RAM_WADDR"/>
1511 <reg32 offset="0x0226" name="CP_ME_RAM_RADDR"/>
1512 <reg32 offset="0x0227" name="CP_ME_RAM_DATA"/>
1513 <reg32 offset="0x022a" name="CP_PREEMPT"/>
1514 <reg32 offset="0x022c" name="CP_CNTL"/>
1515 <reg32 offset="0x022d" name="CP_ME_CNTL"/>
1516 <reg32 offset="0x022e" name="CP_DEBUG"/>
1517 <reg32 offset="0x0231" name="CP_DEBUG_ECO_CONTROL"/>
1518 <reg32 offset="0x0232" name="CP_DRAW_STATE_ADDR"/>
1519 <array offset="0x0240" name="CP_PROTECT" stride="1" length="16">
1520 <reg32 offset="0x0" name="REG" type="adreno_cp_protect"/>
1521 </array>
1522 <reg32 offset="0x0250" name="CP_PROTECT_CTRL"/>
1523 <reg32 offset="0x04c0" name="CP_ST_BASE"/>
1524 <reg32 offset="0x04ce" name="CP_STQ_AVAIL"/>
1525 <reg32 offset="0x04d0" name="CP_MERCIU_STAT"/>
1526 <reg32 offset="0x04d2" name="CP_WFI_PEND_CTR"/>
1527 <reg32 offset="0x04d8" name="CP_HW_FAULT"/>
1528 <reg32 offset="0x04da" name="CP_PROTECT_STATUS"/>
1529 <reg32 offset="0x04dd" name="CP_EVENTS_IN_FLIGHT"/>
1530 <reg32 offset="0x0500" name="CP_PERFCTR_CP_SEL_0" type="a4xx_cp_perfcounter_select"/>
1531 <reg32 offset="0x0501" name="CP_PERFCTR_CP_SEL_1" type="a4xx_cp_perfcounter_select"/>
1532 <reg32 offset="0x0502" name="CP_PERFCTR_CP_SEL_2" type="a4xx_cp_perfcounter_select"/>
1533 <reg32 offset="0x0503" name="CP_PERFCTR_CP_SEL_3" type="a4xx_cp_perfcounter_select"/>
1534 <reg32 offset="0x0504" name="CP_PERFCTR_CP_SEL_4" type="a4xx_cp_perfcounter_select"/>
1535 <reg32 offset="0x0505" name="CP_PERFCTR_CP_SEL_5" type="a4xx_cp_perfcounter_select"/>
1536 <reg32 offset="0x0506" name="CP_PERFCTR_CP_SEL_6" type="a4xx_cp_perfcounter_select"/>
1537 <reg32 offset="0x0507" name="CP_PERFCTR_CP_SEL_7" type="a4xx_cp_perfcounter_select"/>
1538 <reg32 offset="0x050b" name="CP_PERFCOMBINER_SELECT"/>
1539 <array offset="0x0578" name="CP_SCRATCH" stride="1" length="23">
1540 <reg32 offset="0x0" name="REG"/>
1541 </array>
1542
1543
1544 <!-- SP registers -->
1545 <reg32 offset="0x0ec0" name="SP_VS_STATUS"/>
1546 <reg32 offset="0x0ec3" name="SP_MODE_CONTROL"/>
1547
1548 <reg32 offset="0x0ec4" name="SP_PERFCTR_SP_SEL_0" type="a4xx_sp_perfcounter_select"/>
1549 <reg32 offset="0x0ec5" name="SP_PERFCTR_SP_SEL_1" type="a4xx_sp_perfcounter_select"/>
1550 <reg32 offset="0x0ec6" name="SP_PERFCTR_SP_SEL_2" type="a4xx_sp_perfcounter_select"/>
1551 <reg32 offset="0x0ec7" name="SP_PERFCTR_SP_SEL_3" type="a4xx_sp_perfcounter_select"/>
1552 <reg32 offset="0x0ec8" name="SP_PERFCTR_SP_SEL_4" type="a4xx_sp_perfcounter_select"/>
1553 <reg32 offset="0x0ec9" name="SP_PERFCTR_SP_SEL_5" type="a4xx_sp_perfcounter_select"/>
1554 <reg32 offset="0x0eca" name="SP_PERFCTR_SP_SEL_6" type="a4xx_sp_perfcounter_select"/>
1555 <reg32 offset="0x0ecb" name="SP_PERFCTR_SP_SEL_7" type="a4xx_sp_perfcounter_select"/>
1556 <reg32 offset="0x0ecc" name="SP_PERFCTR_SP_SEL_8" type="a4xx_sp_perfcounter_select"/>
1557 <reg32 offset="0x0ecd" name="SP_PERFCTR_SP_SEL_9" type="a4xx_sp_perfcounter_select"/>
1558 <reg32 offset="0x0ece" name="SP_PERFCTR_SP_SEL_10" type="a4xx_sp_perfcounter_select"/>
1559 <reg32 offset="0x0ecf" name="SP_PERFCTR_SP_SEL_11" type="a4xx_sp_perfcounter_select"/>
1560
1561 <reg32 offset="0x22c0" name="SP_SP_CTRL_REG">
1562 <bitfield name="BINNING_PASS" pos="19" type="boolean"/>
1563 </reg32>
1564 <reg32 offset="0x22c1" name="SP_INSTR_CACHE_CTRL">
1565 <!-- set when VS in buffer mode: -->
1566 <bitfield name="VS_BUFFER" pos="7" type="boolean"/>
1567 <!-- set when FS in buffer mode: -->
1568 <bitfield name="FS_BUFFER" pos="8" type="boolean"/>
1569 <!-- set when both VS or FS in buffer mode: -->
1570 <bitfield name="INSTR_BUFFER" pos="10" type="boolean"/>
1571 <!-- TODO other bits probably matter when other stages active? -->
1572 </reg32>
1573
1574 <bitset name="a4xx_sp_vs_fs_ctrl_reg0" inline="yes">
1575 <!--
1576 NOTE that SP_{VS,FS}_CTRL_REG1 are different, but so far REG0
1577 appears to be the same..
1578 -->
1579 <bitfield name="THREADMODE" pos="0" type="a3xx_threadmode"/>
1580 <!-- VARYING bit only for FS.. think it controls emitting (ei) flag? -->
1581 <bitfield name="VARYING" pos="1" type="boolean"/>
1582 <!-- maybe CACHEINVALID is two bits?? -->
1583 <bitfield name="CACHEINVALID" pos="2" type="boolean"/>
1584 <doc>
1585 The full/half register footprint is in units of four components,
1586 so if r0.x is used, that counts as all of r0.[xyzw] as used.
1587 There are separate full/half register footprint values as the
1588 full and half registers are independent (not overlapping).
1589 Presumably the thread scheduler hardware allocates the full/half
1590 register names from the actual physical register file and
1591 handles the register renaming.
1592 </doc>
1593 <bitfield name="HALFREGFOOTPRINT" low="4" high="9" type="uint"/>
1594 <bitfield name="FULLREGFOOTPRINT" low="10" high="15" type="uint"/>
1595 <!-- maybe INOUTREGOVERLAP is a bitflag? -->
1596 <bitfield name="INOUTREGOVERLAP" low="18" high="19" type="uint"/>
1597 <bitfield name="THREADSIZE" pos="20" type="a3xx_threadsize"/>
1598 <bitfield name="SUPERTHREADMODE" pos="21" type="boolean"/>
1599 <bitfield name="PIXLODENABLE" pos="22" type="boolean"/>
1600 </bitset>
1601
1602 <reg32 offset="0x22c4" name="SP_VS_CTRL_REG0" type="a4xx_sp_vs_fs_ctrl_reg0"/>
1603 <reg32 offset="0x22c5" name="SP_VS_CTRL_REG1">
1604 <bitfield name="CONSTLENGTH" low="0" high="7" type="uint"/>
1605 <bitfield name="INITIALOUTSTANDING" low="24" high="30" type="uint"/>
1606 </reg32>
1607 <reg32 offset="0x22c6" name="SP_VS_PARAM_REG">
1608 <bitfield name="POSREGID" low="0" high="7" type="a3xx_regid"/>
1609 <bitfield name="PSIZEREGID" low="8" high="15" type="a3xx_regid"/>
1610 <bitfield name="TOTALVSOUTVAR" low="20" high="31" type="uint"/>
1611 </reg32>
1612 <array offset="0x22c7" name="SP_VS_OUT" stride="1" length="16">
1613 <reg32 offset="0x0" name="REG">
1614 <bitfield name="A_REGID" low="0" high="8" type="a3xx_regid"/>
1615 <bitfield name="A_COMPMASK" low="9" high="12" type="hex"/>
1616 <bitfield name="B_REGID" low="16" high="24" type="a3xx_regid"/>
1617 <bitfield name="B_COMPMASK" low="25" high="28" type="hex"/>
1618 </reg32>
1619 </array>
1620 <array offset="0x22d8" name="SP_VS_VPC_DST" stride="1" length="8">
1621 <reg32 offset="0x0" name="REG">
1622 <doc>
1623 These seem to be offsets for storage of the varyings.
1624 Always seems to start from 8, possibly loc 0 and 4
1625 are for gl_Position and gl_PointSize?
1626 </doc>
1627 <bitfield name="OUTLOC0" low="0" high="7" type="uint"/>
1628 <bitfield name="OUTLOC1" low="8" high="15" type="uint"/>
1629 <bitfield name="OUTLOC2" low="16" high="23" type="uint"/>
1630 <bitfield name="OUTLOC3" low="24" high="31" type="uint"/>
1631 </reg32>
1632 </array>
1633
1634 <reg32 offset="0x22e0" name="SP_VS_OBJ_OFFSET_REG">
1635 <!-- always 00000000: -->
1636 <doc>
1637 From register spec:
1638 SP_FS_OBJ_OFFSET_REG.CONSTOBJECTSTARTOFFSET [16:24]: Constant object
1639 start offset in on chip RAM,
1640 128bit aligned
1641 </doc>
1642 <bitfield name="CONSTOBJECTOFFSET" low="16" high="24" type="uint"/>
1643 <bitfield name="SHADEROBJOFFSET" low="25" high="31" type="uint"/>
1644 </reg32>
1645 <reg32 offset="0x22e1" name="SP_VS_OBJ_START"/>
1646 <reg32 offset="0x22e2" name="SP_VS_PVT_MEM_PARAM"/>"
1647 <reg32 offset="0x22e3" name="SP_VS_PVT_MEM_ADDR"/>
1648 <reg32 offset="0x22e5" name="SP_VS_LENGTH_REG" type="uint"/>
1649 <reg32 offset="0x22e8" name="SP_FS_CTRL_REG0" type="a4xx_sp_vs_fs_ctrl_reg0"/>
1650 <reg32 offset="0x22e9" name="SP_FS_CTRL_REG1">
1651 <bitfield name="CONSTLENGTH" low="0" high="7" type="uint"/>
1652 <bitfield name="FACENESS" pos="19" type="boolean"/>
1653 <bitfield name="VARYING" pos="20" type="boolean"/>
1654 <bitfield name="FRAGCOORD" pos="21" type="boolean"/>
1655 </reg32>
1656 <reg32 offset="0x22ea" name="SP_FS_OBJ_OFFSET_REG">
1657 <bitfield name="CONSTOBJECTOFFSET" low="16" high="24" type="uint"/>
1658 <bitfield name="SHADEROBJOFFSET" low="25" high="31" type="uint"/>
1659 </reg32>
1660 <reg32 offset="0x22eb" name="SP_FS_OBJ_START"/>
1661 <reg32 offset="0x22ec" name="SP_FS_PVT_MEM_PARAM"/>"
1662 <reg32 offset="0x22ed" name="SP_FS_PVT_MEM_ADDR"/>
1663 <reg32 offset="0x22ef" name="SP_FS_LENGTH_REG" type="uint"/>
1664 <reg32 offset="0x22f0" name="SP_FS_OUTPUT_REG">
1665 <bitfield name="MRT" low="0" high="3" type="uint"/>
1666 <bitfield name="DEPTH_ENABLE" pos="7" type="boolean"/>
1667 <!-- TODO double check.. for now assume same as a3xx -->
1668 <bitfield name="DEPTH_REGID" low="8" high="15" type="a3xx_regid"/>
1669 <bitfield name="SAMPLEMASK_REGID" low="24" high="31" type="a3xx_regid"/>
1670 </reg32>
1671 <array offset="0x22f1" name="SP_FS_MRT" stride="1" length="8">
1672 <reg32 offset="0x0" name="REG">
1673 <bitfield name="REGID" low="0" high="7" type="a3xx_regid"/>
1674 <bitfield name="HALF_PRECISION" pos="8" type="boolean"/>
1675 <bitfield name="MRTFORMAT" low="12" high="17" type="a4xx_color_fmt"/>
1676 <bitfield name="COLOR_SRGB" pos="18" type="boolean"/>
1677 </reg32>
1678 </array>
1679 <reg32 offset="0x2300" name="SP_CS_CTRL_REG0"/>
1680 <reg32 offset="0x2301" name="SP_CS_OBJ_OFFSET_REG"/>
1681 <reg32 offset="0x2302" name="SP_CS_OBJ_START"/>
1682 <reg32 offset="0x2303" name="SP_CS_PVT_MEM_PARAM"/>
1683 <reg32 offset="0x2304" name="SP_CS_PVT_MEM_ADDR"/>
1684 <reg32 offset="0x2305" name="SP_CS_PVT_MEM_SIZE"/>
1685 <reg32 offset="0x2306" name="SP_CS_LENGTH_REG" type="uint"/>
1686 <reg32 offset="0x230d" name="SP_HS_OBJ_OFFSET_REG">
1687 <bitfield name="CONSTOBJECTOFFSET" low="16" high="24" type="uint"/>
1688 <bitfield name="SHADEROBJOFFSET" low="25" high="31" type="uint"/>
1689 </reg32>
1690 <reg32 offset="0x230e" name="SP_HS_OBJ_START"/>
1691 <reg32 offset="0x230f" name="SP_HS_PVT_MEM_PARAM"/>"
1692 <reg32 offset="0x2310" name="SP_HS_PVT_MEM_ADDR"/>
1693 <reg32 offset="0x2312" name="SP_HS_LENGTH_REG" type="uint"/>
1694
1695 <reg32 offset="0x231a" name="SP_DS_PARAM_REG">
1696 <bitfield name="POSREGID" low="0" high="7" type="a3xx_regid"/>
1697 <bitfield name="TOTALGSOUTVAR" low="20" high="31" type="uint"/>
1698 </reg32>
1699 <array offset="0x231b" name="SP_DS_OUT" stride="1" length="16">
1700 <reg32 offset="0x0" name="REG">
1701 <bitfield name="A_REGID" low="0" high="8" type="a3xx_regid"/>
1702 <bitfield name="A_COMPMASK" low="9" high="12" type="hex"/>
1703 <bitfield name="B_REGID" low="16" high="24" type="a3xx_regid"/>
1704 <bitfield name="B_COMPMASK" low="25" high="28" type="hex"/>
1705 </reg32>
1706 </array>
1707 <array offset="0x232c" name="SP_DS_VPC_DST" stride="1" length="8">
1708 <reg32 offset="0x0" name="REG">
1709 <doc>
1710 These seem to be offsets for storage of the varyings.
1711 Always seems to start from 8, possibly loc 0 and 4
1712 are for gl_Position and gl_PointSize?
1713 </doc>
1714 <bitfield name="OUTLOC0" low="0" high="7" type="uint"/>
1715 <bitfield name="OUTLOC1" low="8" high="15" type="uint"/>
1716 <bitfield name="OUTLOC2" low="16" high="23" type="uint"/>
1717 <bitfield name="OUTLOC3" low="24" high="31" type="uint"/>
1718 </reg32>
1719 </array>
1720 <reg32 offset="0x2334" name="SP_DS_OBJ_OFFSET_REG">
1721 <bitfield name="CONSTOBJECTOFFSET" low="16" high="24" type="uint"/>
1722 <bitfield name="SHADEROBJOFFSET" low="25" high="31" type="uint"/>
1723 </reg32>
1724 <reg32 offset="0x2335" name="SP_DS_OBJ_START"/>
1725 <reg32 offset="0x2336" name="SP_DS_PVT_MEM_PARAM"/>"
1726 <reg32 offset="0x2337" name="SP_DS_PVT_MEM_ADDR"/>
1727 <reg32 offset="0x2339" name="SP_DS_LENGTH_REG" type="uint"/>
1728
1729 <reg32 offset="0x2341" name="SP_GS_PARAM_REG">
1730 <bitfield name="POSREGID" low="0" high="7" type="a3xx_regid"/>
1731 <bitfield name="PRIMREGID" low="8" high="15" type="a3xx_regid"/>
1732 <bitfield name="TOTALGSOUTVAR" low="20" high="31" type="uint"/>
1733 </reg32>
1734 <array offset="0x2342" name="SP_GS_OUT" stride="1" length="16">
1735 <reg32 offset="0x0" name="REG">
1736 <bitfield name="A_REGID" low="0" high="8" type="a3xx_regid"/>
1737 <bitfield name="A_COMPMASK" low="9" high="12" type="hex"/>
1738 <bitfield name="B_REGID" low="16" high="24" type="a3xx_regid"/>
1739 <bitfield name="B_COMPMASK" low="25" high="28" type="hex"/>
1740 </reg32>
1741 </array>
1742 <array offset="0x2353" name="SP_GS_VPC_DST" stride="1" length="8">
1743 <reg32 offset="0x0" name="REG">
1744 <doc>
1745 These seem to be offsets for storage of the varyings.
1746 Always seems to start from 8, possibly loc 0 and 4
1747 are for gl_Position and gl_PointSize?
1748 </doc>
1749 <bitfield name="OUTLOC0" low="0" high="7" type="uint"/>
1750 <bitfield name="OUTLOC1" low="8" high="15" type="uint"/>
1751 <bitfield name="OUTLOC2" low="16" high="23" type="uint"/>
1752 <bitfield name="OUTLOC3" low="24" high="31" type="uint"/>
1753 </reg32>
1754 </array>
1755 <reg32 offset="0x235b" name="SP_GS_OBJ_OFFSET_REG">
1756 <bitfield name="CONSTOBJECTOFFSET" low="16" high="24" type="uint"/>
1757 <bitfield name="SHADEROBJOFFSET" low="25" high="31" type="uint"/>
1758 </reg32>
1759 <reg32 offset="0x235c" name="SP_GS_OBJ_START"/>
1760 <reg32 offset="0x235d" name="SP_GS_PVT_MEM_PARAM"/>"
1761 <reg32 offset="0x235e" name="SP_GS_PVT_MEM_ADDR"/>
1762 <reg32 offset="0x2360" name="SP_GS_LENGTH_REG" type="uint"/>
1763
1764 <!-- VPC registers -->
1765 <reg32 offset="0x0e60" name="VPC_DEBUG_RAM_SEL"/>
1766 <reg32 offset="0x0e61" name="VPC_DEBUG_RAM_READ"/>
1767 <reg32 offset="0x0e64" name="VPC_DEBUG_ECO_CONTROL"/>
1768 <reg32 offset="0x0e65" name="VPC_PERFCTR_VPC_SEL_0" type="a4xx_vpc_perfcounter_select"/>
1769 <reg32 offset="0x0e66" name="VPC_PERFCTR_VPC_SEL_1" type="a4xx_vpc_perfcounter_select"/>
1770 <reg32 offset="0x0e67" name="VPC_PERFCTR_VPC_SEL_2" type="a4xx_vpc_perfcounter_select"/>
1771 <reg32 offset="0x0e68" name="VPC_PERFCTR_VPC_SEL_3" type="a4xx_vpc_perfcounter_select"/>
1772 <reg32 offset="0x2140" name="VPC_ATTR">
1773 <bitfield name="TOTALATTR" low="0" high="8" type="uint"/>
1774 <!-- PSIZE bit set if gl_PointSize written: -->
1775 <bitfield name="PSIZE" pos="9" type="boolean"/>
1776 <bitfield name="THRDASSIGN" low="12" high="13" type="uint"/>
1777 <bitfield name="ENABLE" pos="25" type="boolean"/>
1778 </reg32>
1779 <reg32 offset="0x2141" name="VPC_PACK">
1780 <bitfield name="NUMBYPASSVAR" low="0" high="7" type="uint"/>
1781 <bitfield name="NUMFPNONPOSVAR" low="8" high="15" type="uint"/>
1782 <bitfield name="NUMNONPOSVSVAR" low="16" high="23" type="uint"/>
1783 </reg32>
1784 <array offset="0x2142" name="VPC_VARYING_INTERP" stride="1" length="8">
1785 <reg32 offset="0x0" name="MODE"/>
1786 </array>
1787 <array offset="0x214a" name="VPC_VARYING_PS_REPL" stride="1" length="8">
1788 <reg32 offset="0x0" name="MODE"/>
1789 </array>
1790
1791 <reg32 offset="0x216e" name="VPC_SO_FLUSH_WADDR_3"/>
1792
1793 <!-- VSC registers -->
1794 <reg32 offset="0x0c00" name="VSC_BIN_SIZE">
1795 <bitfield name="WIDTH" low="0" high="4" shr="5" type="uint"/>
1796 <bitfield name="HEIGHT" low="5" high="9" shr="5" type="uint"/>
1797 </reg32>
1798 <reg32 offset="0x0c01" name="VSC_SIZE_ADDRESS"/>
1799 <reg32 offset="0x0c02" name="VSC_SIZE_ADDRESS2"/>
1800 <reg32 offset="0x0c03" name="VSC_DEBUG_ECO_CONTROL"/>
1801 <array offset="0x0c08" name="VSC_PIPE_CONFIG" stride="1" length="8">
1802 <reg32 offset="0x0" name="REG">
1803 <doc>
1804 Configures the mapping between VSC_PIPE buffer and
1805 bin, X/Y specify the bin index in the horiz/vert
1806 direction (0,0 is upper left, 0,1 is leftmost bin
1807 on second row, and so on). W/H specify the number
1808 of bins assigned to this VSC_PIPE in the horiz/vert
1809 dimension.
1810 </doc>
1811 <bitfield name="X" low="0" high="9" type="uint"/>
1812 <bitfield name="Y" low="10" high="19" type="uint"/>
1813 <bitfield name="W" low="20" high="23" type="uint"/>
1814 <bitfield name="H" low="24" high="27" type="uint"/>
1815 </reg32>
1816 </array>
1817 <array offset="0x0c10" name="VSC_PIPE_DATA_ADDRESS" stride="1" length="8">
1818 <reg32 offset="0x0" name="REG"/>
1819 </array>
1820 <array offset="0x0c18" name="VSC_PIPE_DATA_LENGTH" stride="1" length="8">
1821 <reg32 offset="0x0" name="REG"/>
1822 </array>
1823 <reg32 offset="0x0c41" name="VSC_PIPE_PARTIAL_POSN_1"/>
1824 <reg32 offset="0x0c50" name="VSC_PERFCTR_VSC_SEL_0" type="a4xx_vsc_perfcounter_select"/>
1825 <reg32 offset="0x0c51" name="VSC_PERFCTR_VSC_SEL_1" type="a4xx_vsc_perfcounter_select"/>
1826
1827 <!-- VFD registers -->
1828 <reg32 offset="0x0e40" name="VFD_DEBUG_CONTROL"/>
1829 <reg32 offset="0x0e43" name="VFD_PERFCTR_VFD_SEL_0" type="a4xx_vfd_perfcounter_select"/>
1830 <reg32 offset="0x0e44" name="VFD_PERFCTR_VFD_SEL_1" type="a4xx_vfd_perfcounter_select"/>
1831 <reg32 offset="0x0e45" name="VFD_PERFCTR_VFD_SEL_2" type="a4xx_vfd_perfcounter_select"/>
1832 <reg32 offset="0x0e46" name="VFD_PERFCTR_VFD_SEL_3" type="a4xx_vfd_perfcounter_select"/>
1833 <reg32 offset="0x0e47" name="VFD_PERFCTR_VFD_SEL_4" type="a4xx_vfd_perfcounter_select"/>
1834 <reg32 offset="0x0e48" name="VFD_PERFCTR_VFD_SEL_5" type="a4xx_vfd_perfcounter_select"/>
1835 <reg32 offset="0x0e49" name="VFD_PERFCTR_VFD_SEL_6" type="a4xx_vfd_perfcounter_select"/>
1836 <reg32 offset="0x0e4a" name="VFD_PERFCTR_VFD_SEL_7" type="a4xx_vfd_perfcounter_select"/>
1837 <reg32 offset="0x21d0" name="VGT_CL_INITIATOR"/>
1838 <reg32 offset="0x21d9" name="VGT_EVENT_INITIATOR"/>
1839 <reg32 offset="0x2200" name="VFD_CONTROL_0">
1840 <doc>
1841 TOTALATTRTOVS is # of attributes to vertex shader, in register
1842 slots (ie. vec4+vec3 -> 7)
1843 </doc>
1844 <bitfield name="TOTALATTRTOVS" low="0" high="7" type="uint"/>
1845 <doc>
1846 BYPASSATTROVS seems to count varyings that are just directly
1847 assigned from attributes (ie, "vFoo = aFoo;")
1848 </doc>
1849 <bitfield name="BYPASSATTROVS" low="9" high="16" type="uint"/>
1850 <doc>STRMDECINSTRCNT is # of VFD_DECODE_INSTR registers valid</doc>
1851 <bitfield name="STRMDECINSTRCNT" low="20" high="25" type="uint"/>
1852 <doc>STRMFETCHINSTRCNT is # of VFD_FETCH_INSTR registers valid</doc>
1853 <bitfield name="STRMFETCHINSTRCNT" low="26" high="31" type="uint"/>
1854 </reg32>
1855 <reg32 offset="0x2201" name="VFD_CONTROL_1">
1856 <doc>MAXSTORAGE could be # of attributes/vbo's</doc>
1857 <bitfield name="MAXSTORAGE" low="0" high="15" type="uint"/>
1858 <bitfield name="REGID4VTX" low="16" high="23" type="a3xx_regid"/>
1859 <bitfield name="REGID4INST" low="24" high="31" type="a3xx_regid"/>
1860 </reg32>
1861 <reg32 offset="0x2202" name="VFD_CONTROL_2"/>
1862 <reg32 offset="0x2203" name="VFD_CONTROL_3">
1863 <bitfield name="REGID_VTXCNT" low="8" high="15" type="a3xx_regid"/>
1864 <bitfield name="REGID_TESSX" low="16" high="23" type="a3xx_regid"/>
1865 <bitfield name="REGID_TESSY" low="24" high="31" type="a3xx_regid"/>
1866 </reg32>
1867 <reg32 offset="0x2204" name="VFD_CONTROL_4"/>
1868 <reg32 offset="0x2208" name="VFD_INDEX_OFFSET"/>
1869 <array offset="0x220a" name="VFD_FETCH" stride="4" length="32">
1870 <reg32 offset="0x0" name="INSTR_0">
1871 <bitfield name="FETCHSIZE" low="0" high="6" type="uint"/>
1872 <bitfield name="BUFSTRIDE" low="7" high="16" type="uint"/>
1873 <bitfield name="SWITCHNEXT" pos="19" type="boolean"/>
1874 <bitfield name="INSTANCED" pos="20" type="boolean"/>
1875 </reg32>
1876 <reg32 offset="0x1" name="INSTR_1"/>
1877 <reg32 offset="0x2" name="INSTR_2">
1878 <bitfield name="SIZE" low="0" high="31"/>
1879 </reg32>
1880 <reg32 offset="0x3" name="INSTR_3">
1881 <!-- might well be bigger.. -->
1882 <bitfield name="STEPRATE" low="0" high="8" type="uint"/>
1883 </reg32>
1884 </array>
1885 <array offset="0x228a" name="VFD_DECODE" stride="1" length="32">
1886 <reg32 offset="0x0" name="INSTR">
1887 <bitfield name="WRITEMASK" low="0" high="3" type="hex"/>
1888 <!-- not sure if this is a bit flag and another flag above it, or?? -->
1889 <bitfield name="CONSTFILL" pos="4" type="boolean"/>
1890 <bitfield name="FORMAT" low="6" high="11" type="a4xx_vtx_fmt"/>
1891 <bitfield name="REGID" low="12" high="19" type="a3xx_regid"/>
1892 <bitfield name="INT" pos="20" type="boolean"/>
1893 <doc>SHIFTCNT appears to be size, ie. FLOAT_32_32_32 is 12, and BYTE_8 is 1</doc>
1894 <bitfield name="SWAP" low="22" high="23" type="a3xx_color_swap"/>
1895 <bitfield name="SHIFTCNT" low="24" high="28" type="uint"/>
1896 <bitfield name="LASTCOMPVALID" pos="29" type="boolean"/>
1897 <bitfield name="SWITCHNEXT" pos="30" type="boolean"/>
1898 </reg32>
1899 </array>
1900
1901 <!-- TPL1 registers -->
1902 <reg32 offset="0x0f00" name="TPL1_DEBUG_ECO_CONTROL"/>
1903 <!-- always 0000003a: -->
1904 <reg32 offset="0x0f03" name="TPL1_TP_MODE_CONTROL"/>
1905 <reg32 offset="0x0f04" name="TPL1_PERFCTR_TP_SEL_0" type="a4xx_tp_perfcounter_select"/>
1906 <reg32 offset="0x0f05" name="TPL1_PERFCTR_TP_SEL_1" type="a4xx_tp_perfcounter_select"/>
1907 <reg32 offset="0x0f06" name="TPL1_PERFCTR_TP_SEL_2" type="a4xx_tp_perfcounter_select"/>
1908 <reg32 offset="0x0f07" name="TPL1_PERFCTR_TP_SEL_3" type="a4xx_tp_perfcounter_select"/>
1909 <reg32 offset="0x0f08" name="TPL1_PERFCTR_TP_SEL_4" type="a4xx_tp_perfcounter_select"/>
1910 <reg32 offset="0x0f09" name="TPL1_PERFCTR_TP_SEL_5" type="a4xx_tp_perfcounter_select"/>
1911 <reg32 offset="0x0f0a" name="TPL1_PERFCTR_TP_SEL_6" type="a4xx_tp_perfcounter_select"/>
1912 <reg32 offset="0x0f0b" name="TPL1_PERFCTR_TP_SEL_7" type="a4xx_tp_perfcounter_select"/>
1913 <reg32 offset="0x2380" name="TPL1_TP_TEX_OFFSET"/>
1914 <reg32 offset="0x2381" name="TPL1_TP_TEX_COUNT">
1915 <bitfield name="VS" low="0" high="7" type="uint"/>
1916 <bitfield name="HS" low="8" high="15" type="uint"/>
1917 <bitfield name="DS" low="16" high="23" type="uint"/>
1918 <bitfield name="GS" low="24" high="31" type="uint"/>
1919 </reg32>
1920 <reg32 offset="0x2384" name="TPL1_TP_VS_BORDER_COLOR_BASE_ADDR"/>
1921 <reg32 offset="0x2387" name="TPL1_TP_HS_BORDER_COLOR_BASE_ADDR"/>
1922 <reg32 offset="0x238a" name="TPL1_TP_DS_BORDER_COLOR_BASE_ADDR"/>
1923 <reg32 offset="0x238d" name="TPL1_TP_GS_BORDER_COLOR_BASE_ADDR"/>
1924 <reg32 offset="0x23a0" name="TPL1_TP_FS_TEX_COUNT"/>
1925 <reg32 offset="0x23a1" name="TPL1_TP_FS_BORDER_COLOR_BASE_ADDR"/>
1926 <reg32 offset="0x23a4" name="TPL1_TP_CS_BORDER_COLOR_BASE_ADDR"/>
1927 <reg32 offset="0x23a5" name="TPL1_TP_CS_SAMPLER_BASE_ADDR"/>
1928 <reg32 offset="0x23a6" name="TPL1_TP_CS_TEXMEMOBJ_BASE_ADDR"/>
1929
1930 <!-- GRAS registers -->
1931 <reg32 offset="0x0c80" name="GRAS_TSE_STATUS"/>
1932 <reg32 offset="0x0c81" name="GRAS_DEBUG_ECO_CONTROL"/>
1933 <reg32 offset="0x0c88" name="GRAS_PERFCTR_TSE_SEL_0" type="a4xx_gras_tse_perfcounter_select"/>
1934 <reg32 offset="0x0c89" name="GRAS_PERFCTR_TSE_SEL_1" type="a4xx_gras_tse_perfcounter_select"/>
1935 <reg32 offset="0x0c8a" name="GRAS_PERFCTR_TSE_SEL_2" type="a4xx_gras_tse_perfcounter_select"/>
1936 <reg32 offset="0x0c8b" name="GRAS_PERFCTR_TSE_SEL_3" type="a4xx_gras_tse_perfcounter_select"/>
1937 <reg32 offset="0x0c8c" name="GRAS_PERFCTR_RAS_SEL_0" type="a4xx_gras_ras_perfcounter_select"/>
1938 <reg32 offset="0x0c8d" name="GRAS_PERFCTR_RAS_SEL_1" type="a4xx_gras_ras_perfcounter_select"/>
1939 <reg32 offset="0x0c8e" name="GRAS_PERFCTR_RAS_SEL_2" type="a4xx_gras_ras_perfcounter_select"/>
1940 <reg32 offset="0x0c8f" name="GRAS_PERFCTR_RAS_SEL_3" type="a4xx_gras_ras_perfcounter_select"/>
1941 <reg32 offset="0x2000" name="GRAS_CL_CLIP_CNTL">
1942 <bitfield name="CLIP_DISABLE" pos="15" type="boolean"/>
1943 <bitfield name="ZNEAR_CLIP_DISABLE" pos="16" type="boolean"/>
1944 <bitfield name="ZFAR_CLIP_DISABLE" pos="17" type="boolean"/>
1945 <bitfield name="ZERO_GB_SCALE_Z" pos="22" type="boolean"/>
1946 </reg32>
1947 <reg32 offset="0x2003" name="GRAS_CLEAR_CNTL">
1948 <!-- probably not the right name, but.. -->
1949 <!-- bit0 set for everything *but* fastclear -->
1950 <bitfield name="NOT_FASTCLEAR" pos="0" type="boolean"/>
1951 </reg32>
1952 <reg32 offset="0x2004" name="GRAS_CL_GB_CLIP_ADJ">
1953 <bitfield name="HORZ" low="0" high="9" type="uint"/>
1954 <bitfield name="VERT" low="10" high="19" type="uint"/>
1955 </reg32>
1956 <reg32 offset="0x2008" name="GRAS_CL_VPORT_XOFFSET_0" type="float"/>
1957 <reg32 offset="0x2009" name="GRAS_CL_VPORT_XSCALE_0" type="float"/>
1958 <reg32 offset="0x200a" name="GRAS_CL_VPORT_YOFFSET_0" type="float"/>
1959 <reg32 offset="0x200b" name="GRAS_CL_VPORT_YSCALE_0" type="float"/>
1960 <reg32 offset="0x200c" name="GRAS_CL_VPORT_ZOFFSET_0" type="float"/>
1961 <reg32 offset="0x200d" name="GRAS_CL_VPORT_ZSCALE_0" type="float"/>
1962 <reg32 offset="0x2070" name="GRAS_SU_POINT_MINMAX">
1963 <bitfield name="MIN" low="0" high="15" type="ufixed" radix="4"/>
1964 <bitfield name="MAX" low="16" high="31" type="ufixed" radix="4"/>
1965 </reg32>
1966 <reg32 offset="0x2071" name="GRAS_SU_POINT_SIZE" type="fixed" radix="4"/>
1967 <reg32 offset="0x2073" name="GRAS_ALPHA_CONTROL">
1968 <bitfield name="ALPHA_TEST_ENABLE" pos="2" type="boolean"/>
1969 <bitfield name="FORCE_FRAGZ_TO_FS" pos="3" type="boolean"/>
1970 </reg32>
1971 <reg32 offset="0x2074" name="GRAS_SU_POLY_OFFSET_SCALE" type="float"/>
1972 <reg32 offset="0x2075" name="GRAS_SU_POLY_OFFSET_OFFSET" type="float"/>
1973 <reg32 offset="0x2076" name="GRAS_SU_POLY_OFFSET_CLAMP" type="float"/>
1974 <reg32 offset="0x2077" name="GRAS_DEPTH_CONTROL">
1975 <!-- guestimating that this is GRAS based on addr -->
1976 <bitfield name="FORMAT" low="0" high="1" type="a4xx_depth_format"/>
1977 </reg32>
1978 <reg32 offset="0x2078" name="GRAS_SU_MODE_CONTROL">
1979 <bitfield name="CULL_FRONT" pos="0" type="boolean"/>
1980 <bitfield name="CULL_BACK" pos="1" type="boolean"/>
1981 <bitfield name="FRONT_CW" pos="2" type="boolean"/>
1982 <bitfield name="LINEHALFWIDTH" low="3" high="10" radix="2" type="fixed"/>
1983 <bitfield name="POLY_OFFSET" pos="11" type="boolean"/>
1984 <bitfield name="MSAA_ENABLE" pos="13" type="boolean"/>
1985 <!-- bit20 set whenever RENDER_MODE = RB_RENDERING_PASS -->
1986 <bitfield name="RENDERING_PASS" pos="20" type="boolean"/>
1987 </reg32>
1988 <reg32 offset="0x207b" name="GRAS_SC_CONTROL">
1989 <!-- complete wild-ass-guess for sizes of these bitfields.. -->
1990 <bitfield name="RENDER_MODE" low="2" high="3" type="a3xx_render_mode"/>
1991 <bitfield name="MSAA_SAMPLES" low="7" high="9" type="uint"/>
1992 <bitfield name="MSAA_DISABLE" pos="11" type="boolean"/>
1993 <bitfield name="RASTER_MODE" low="12" high="15"/>
1994 </reg32>
1995 <reg32 offset="0x207c" name="GRAS_SC_SCREEN_SCISSOR_TL" type="adreno_reg_xy"/>
1996 <reg32 offset="0x207d" name="GRAS_SC_SCREEN_SCISSOR_BR" type="adreno_reg_xy"/>
1997 <reg32 offset="0x209c" name="GRAS_SC_WINDOW_SCISSOR_BR" type="adreno_reg_xy"/>
1998 <reg32 offset="0x209d" name="GRAS_SC_WINDOW_SCISSOR_TL" type="adreno_reg_xy"/>
1999 <reg32 offset="0x209e" name="GRAS_SC_EXTENT_WINDOW_BR" type="adreno_reg_xy"/>
2000 <reg32 offset="0x209f" name="GRAS_SC_EXTENT_WINDOW_TL" type="adreno_reg_xy"/>
2001
2002 <!-- UCHE registers -->
2003 <reg32 offset="0x0e80" name="UCHE_CACHE_MODE_CONTROL"/>
2004 <reg32 offset="0x0e83" name="UCHE_TRAP_BASE_LO"/>
2005 <reg32 offset="0x0e84" name="UCHE_TRAP_BASE_HI"/>
2006 <reg32 offset="0x0e88" name="UCHE_CACHE_STATUS"/>
2007 <reg32 offset="0x0e8a" name="UCHE_INVALIDATE0"/>
2008 <reg32 offset="0x0e8b" name="UCHE_INVALIDATE1"/>
2009 <reg32 offset="0x0e8c" name="UCHE_CACHE_WAYS_VFD"/>
2010 <reg32 offset="0x0e8e" name="UCHE_PERFCTR_UCHE_SEL_0" type="a4xx_uche_perfcounter_select"/>
2011 <reg32 offset="0x0e8f" name="UCHE_PERFCTR_UCHE_SEL_1" type="a4xx_uche_perfcounter_select"/>
2012 <reg32 offset="0x0e90" name="UCHE_PERFCTR_UCHE_SEL_2" type="a4xx_uche_perfcounter_select"/>
2013 <reg32 offset="0x0e91" name="UCHE_PERFCTR_UCHE_SEL_3" type="a4xx_uche_perfcounter_select"/>
2014 <reg32 offset="0x0e92" name="UCHE_PERFCTR_UCHE_SEL_4" type="a4xx_uche_perfcounter_select"/>
2015 <reg32 offset="0x0e93" name="UCHE_PERFCTR_UCHE_SEL_5" type="a4xx_uche_perfcounter_select"/>
2016 <reg32 offset="0x0e94" name="UCHE_PERFCTR_UCHE_SEL_6" type="a4xx_uche_perfcounter_select"/>
2017 <reg32 offset="0x0e95" name="UCHE_PERFCTR_UCHE_SEL_7" type="a4xx_uche_perfcounter_select"/>
2018
2019 <!-- HLSQ registers -->
2020 <reg32 offset="0x0e00" name="HLSQ_TIMEOUT_THRESHOLD"/>
2021 <reg32 offset="0x0e04" name="HLSQ_DEBUG_ECO_CONTROL"/>
2022 <!-- always 00000000: -->
2023 <reg32 offset="0x0e05" name="HLSQ_MODE_CONTROL"/>
2024 <reg32 offset="0x0e0e" name="HLSQ_PERF_PIPE_MASK"/>
2025 <reg32 offset="0x0e06" name="HLSQ_PERFCTR_HLSQ_SEL_0" type="a4xx_hlsq_perfcounter_select"/>
2026 <reg32 offset="0x0e07" name="HLSQ_PERFCTR_HLSQ_SEL_1" type="a4xx_hlsq_perfcounter_select"/>
2027 <reg32 offset="0x0e08" name="HLSQ_PERFCTR_HLSQ_SEL_2" type="a4xx_hlsq_perfcounter_select"/>
2028 <reg32 offset="0x0e09" name="HLSQ_PERFCTR_HLSQ_SEL_3" type="a4xx_hlsq_perfcounter_select"/>
2029 <reg32 offset="0x0e0a" name="HLSQ_PERFCTR_HLSQ_SEL_4" type="a4xx_hlsq_perfcounter_select"/>
2030 <reg32 offset="0x0e0b" name="HLSQ_PERFCTR_HLSQ_SEL_5" type="a4xx_hlsq_perfcounter_select"/>
2031 <reg32 offset="0x0e0c" name="HLSQ_PERFCTR_HLSQ_SEL_6" type="a4xx_hlsq_perfcounter_select"/>
2032 <reg32 offset="0x0e0d" name="HLSQ_PERFCTR_HLSQ_SEL_7" type="a4xx_hlsq_perfcounter_select"/>
2033 <reg32 offset="0x23c0" name="HLSQ_CONTROL_0_REG">
2034 <!-- I guess same as a3xx, but so far only seen 08000050 -->
2035 <bitfield name="FSTHREADSIZE" pos="4" type="a3xx_threadsize"/>
2036 <bitfield name="FSSUPERTHREADENABLE" pos="6" type="boolean"/>
2037 <bitfield name="SPSHADERRESTART" pos="9" type="boolean"/>
2038 <bitfield name="RESERVED2" pos="10" type="boolean"/>
2039 <bitfield name="CHUNKDISABLE" pos="26" type="boolean"/>
2040 <bitfield name="CONSTMODE" pos="27" type="uint"/>
2041 <bitfield name="LAZYUPDATEDISABLE" pos="28" type="boolean"/>
2042 <bitfield name="SPCONSTFULLUPDATE" pos="29" type="boolean"/>
2043 <bitfield name="TPFULLUPDATE" pos="30" type="boolean"/>
2044 <bitfield name="SINGLECONTEXT" pos="31" type="boolean"/>
2045 </reg32>
2046 <reg32 offset="0x23c1" name="HLSQ_CONTROL_1_REG">
2047 <bitfield name="VSTHREADSIZE" pos="6" type="a3xx_threadsize"/>
2048 <bitfield name="VSSUPERTHREADENABLE" pos="8" type="boolean"/>
2049 <bitfield name="RESERVED1" pos="9" type="boolean"/>
2050 <bitfield name="COORDREGID" low="16" high="23" type="a3xx_regid"/>
2051 <!-- set if gl_FragCoord.[zw] used in frag shader: -->
2052 <bitfield name="ZWCOORDREGID" low="24" high="31" type="a3xx_regid"/>
2053 </reg32>
2054 <reg32 offset="0x23c2" name="HLSQ_CONTROL_2_REG">
2055 <bitfield name="PRIMALLOCTHRESHOLD" low="26" high="31" type="uint"/>
2056 <bitfield name="FACEREGID" low="2" high="9" type="a3xx_regid"/>
2057 <bitfield name="SAMPLEID_REGID" low="10" high="17" type="a3xx_regid"/>
2058 <bitfield name="SAMPLEMASK_REGID" low="18" high="25" type="a3xx_regid"/>
2059 </reg32>
2060 <reg32 offset="0x23c3" name="HLSQ_CONTROL_3_REG">
2061 <!-- register loaded with position (bary.f, gl_FragCoord, etc) -->
2062 <bitfield name="REGID" low="0" high="7" type="a3xx_regid"/>
2063 </reg32>
2064 <!-- 0x23c4 3 regids, lowest one goes to 0 when *not* per-sample shading -->
2065 <reg32 offset="0x23c4" name="HLSQ_CONTROL_4_REG"/>
2066
2067 <bitset name="a4xx_xs_control_reg" inline="yes">
2068 <bitfield name="CONSTLENGTH" low="0" high="7" type="uint"/>
2069 <bitfield name="CONSTOBJECTOFFSET" low="8" high="14" type="uint"/>
2070 <bitfield name="SSBO_ENABLE" pos="15"/>
2071 <bitfield name="ENABLED" pos="16"/>
2072 <bitfield name="SHADEROBJOFFSET" low="17" high="23" type="uint"/>
2073 <bitfield name="INSTRLENGTH" low="24" high="31" type="uint"/>
2074 </bitset>
2075 <reg32 offset="0x23c5" name="HLSQ_VS_CONTROL_REG" type="a4xx_xs_control_reg"/>
2076 <reg32 offset="0x23c6" name="HLSQ_FS_CONTROL_REG" type="a4xx_xs_control_reg"/>
2077 <reg32 offset="0x23c7" name="HLSQ_HS_CONTROL_REG" type="a4xx_xs_control_reg"/>
2078 <reg32 offset="0x23c8" name="HLSQ_DS_CONTROL_REG" type="a4xx_xs_control_reg"/>
2079 <reg32 offset="0x23c9" name="HLSQ_GS_CONTROL_REG" type="a4xx_xs_control_reg"/>
2080 <reg32 offset="0x23ca" name="HLSQ_CS_CONTROL_REG" type="a4xx_xs_control_reg"/>
2081 <reg32 offset="0x23cd" name="HLSQ_CL_NDRANGE_0">
2082 <bitfield name="KERNELDIM" low="0" high="1" type="uint"/>
2083 <!-- localsize is value minus one: -->
2084 <bitfield name="LOCALSIZEX" low="2" high="11" type="uint"/>
2085 <bitfield name="LOCALSIZEY" low="12" high="21" type="uint"/>
2086 <bitfield name="LOCALSIZEZ" low="22" high="31" type="uint"/>
2087 </reg32>
2088 <reg32 offset="0x23ce" name="HLSQ_CL_NDRANGE_1">
2089 <bitfield name="SIZE_X" low="0" high="31" type="uint"/>
2090 </reg32>
2091 <reg32 offset="0x23cf" name="HLSQ_CL_NDRANGE_2"/>
2092 <reg32 offset="0x23d0" name="HLSQ_CL_NDRANGE_3">
2093 <bitfield name="SIZE_Y" low="0" high="31" type="uint"/>
2094 </reg32>
2095 <reg32 offset="0x23d1" name="HLSQ_CL_NDRANGE_4"/>
2096 <reg32 offset="0x23d2" name="HLSQ_CL_NDRANGE_5">
2097 <bitfield name="SIZE_Z" low="0" high="31" type="uint"/>
2098 </reg32>
2099 <reg32 offset="0x23d3" name="HLSQ_CL_NDRANGE_6"/>
2100 <reg32 offset="0x23d4" name="HLSQ_CL_CONTROL_0">
2101 <bitfield name="WGIDCONSTID" low="0" high="7" type="a3xx_regid"/>
2102 <bitfield name="LOCALIDREGID" low="24" high="31" type="a3xx_regid"/>
2103 </reg32>
2104 <reg32 offset="0x23d5" name="HLSQ_CL_CONTROL_1"/>
2105 <reg32 offset="0x23d6" name="HLSQ_CL_KERNEL_CONST"/>
2106 <reg32 offset="0x23d7" name="HLSQ_CL_KERNEL_GROUP_X"/>
2107 <reg32 offset="0x23d8" name="HLSQ_CL_KERNEL_GROUP_Y"/>
2108 <reg32 offset="0x23d9" name="HLSQ_CL_KERNEL_GROUP_Z"/>
2109 <reg32 offset="0x23da" name="HLSQ_CL_WG_OFFSET"/>
2110 <reg32 offset="0x23db" name="HLSQ_UPDATE_CONTROL"/>
2111
2112 <!-- PC registers -->
2113 <reg32 offset="0x0d00" name="PC_BINNING_COMMAND">
2114 <bitfield name="BINNING_ENABLE" pos="0" type="boolean"/>
2115 </reg32>
2116 <reg32 offset="0x0d08" name="PC_TESSFACTOR_ADDR"/>
2117 <reg32 offset="0x0d0c" name="PC_DRAWCALL_SETUP_OVERRIDE"/>
2118 <reg32 offset="0x0d10" name="PC_PERFCTR_PC_SEL_0" type="a4xx_pc_perfcounter_select"/>
2119 <reg32 offset="0x0d11" name="PC_PERFCTR_PC_SEL_1" type="a4xx_pc_perfcounter_select"/>
2120 <reg32 offset="0x0d12" name="PC_PERFCTR_PC_SEL_2" type="a4xx_pc_perfcounter_select"/>
2121 <reg32 offset="0x0d13" name="PC_PERFCTR_PC_SEL_3" type="a4xx_pc_perfcounter_select"/>
2122 <reg32 offset="0x0d14" name="PC_PERFCTR_PC_SEL_4" type="a4xx_pc_perfcounter_select"/>
2123 <reg32 offset="0x0d15" name="PC_PERFCTR_PC_SEL_5" type="a4xx_pc_perfcounter_select"/>
2124 <reg32 offset="0x0d16" name="PC_PERFCTR_PC_SEL_6" type="a4xx_pc_perfcounter_select"/>
2125 <reg32 offset="0x0d17" name="PC_PERFCTR_PC_SEL_7" type="a4xx_pc_perfcounter_select"/>
2126 <reg32 offset="0x21c0" name="PC_BIN_BASE"/>
2127 <reg32 offset="0x21c2" name="PC_VSTREAM_CONTROL">
2128 <doc>SIZE is current pipe width * height (in tiles)</doc>
2129 <bitfield name="SIZE" low="16" high="21" type="uint"/>
2130 <doc>
2131 N is some sort of slot # between 0..(SIZE-1). In case
2132 multiple tiles use same pipe, each tile gets unique slot #
2133 </doc>
2134 <bitfield name="N" low="22" high="26" type="uint"/>
2135 </reg32>
2136 <reg32 offset="0x21c4" name="PC_PRIM_VTX_CNTL">
2137 <!-- bit0 set if there is >= 1 varying (actually used by FS) -->
2138 <bitfield name="VAROUT" low="0" high="3" type="uint">
2139 <doc>in groups of 4x vec4, blob only uses values
2140 0, 1, 2, 4, 6, 8</doc>
2141 </bitfield>
2142 <bitfield name="PRIMITIVE_RESTART" pos="20" type="boolean"/>
2143 <bitfield name="PROVOKING_VTX_LAST" pos="25" type="boolean"/>
2144 <!-- PSIZE bit set if gl_PointSize written: -->
2145 <bitfield name="PSIZE" pos="26" type="boolean"/>
2146 </reg32>
2147 <reg32 offset="0x21c5" name="PC_PRIM_VTX_CNTL2">
2148 <bitfield name="POLYMODE_FRONT_PTYPE" low="0" high="2" type="adreno_pa_su_sc_draw"/>
2149 <bitfield name="POLYMODE_BACK_PTYPE" low="3" high="5" type="adreno_pa_su_sc_draw"/>
2150 <bitfield name="POLYMODE_ENABLE" pos="6" type="boolean"/>
2151 </reg32>
2152 <reg32 offset="0x21c6" name="PC_RESTART_INDEX"/>
2153 <reg32 offset="0x21e5" name="PC_GS_PARAM">
2154 <bitfield name="MAX_VERTICES" low="0" high="9" type="uint"/><!-- +1, i.e. max is 1024 -->
2155 <bitfield name="INVOCATIONS" low="11" high="15" type="uint"/><!-- +1, i.e. max is 32 -->
2156 <bitfield name="PRIMTYPE" low="23" high="24" type="adreno_pa_su_sc_draw"/>
2157 <bitfield name="LAYER" pos="31" type="boolean"/>
2158 </reg32>
2159 <reg32 offset="0x21e7" name="PC_HS_PARAM">
2160 <bitfield name="VERTICES_OUT" low="0" high="5" type="uint"/>
2161 <bitfield name="SPACING" low="21" high="22" type="a4xx_tess_spacing"/>
2162 <bitfield name="CW" pos="23" type="boolean"/>
2163 <bitfield name="CONNECTED" pos="24" type="boolean"/>
2164 </reg32>
2165
2166 <!-- VBIF registers -->
2167 <reg32 offset="0x3000" name="VBIF_VERSION"/>
2168 <reg32 offset="0x3001" name="VBIF_CLKON">
2169 <bitfield name="FORCE_ON_TESTBUS" pos="0" type="boolean"/>
2170 </reg32>
2171 <reg32 offset="0x301c" name="VBIF_ABIT_SORT"/>
2172 <reg32 offset="0x301d" name="VBIF_ABIT_SORT_CONF"/>
2173 <reg32 offset="0x302a" name="VBIF_GATE_OFF_WRREQ_EN"/>
2174 <reg32 offset="0x302c" name="VBIF_IN_RD_LIM_CONF0"/>
2175 <reg32 offset="0x302d" name="VBIF_IN_RD_LIM_CONF1"/>
2176 <reg32 offset="0x3030" name="VBIF_IN_WR_LIM_CONF0"/>
2177 <reg32 offset="0x3031" name="VBIF_IN_WR_LIM_CONF1"/>
2178 <reg32 offset="0x3049" name="VBIF_ROUND_ROBIN_QOS_ARB"/>
2179 <reg32 offset="0x30c0" name="VBIF_PERF_CNT_EN0"/>
2180 <reg32 offset="0x30c1" name="VBIF_PERF_CNT_EN1"/>
2181 <reg32 offset="0x30c2" name="VBIF_PERF_CNT_EN2"/>
2182 <reg32 offset="0x30c3" name="VBIF_PERF_CNT_EN3"/>
2183 <reg32 offset="0x30d0" name="VBIF_PERF_CNT_SEL0" type="a4xx_vbif_perfcounter_select"/>
2184 <reg32 offset="0x30d1" name="VBIF_PERF_CNT_SEL1" type="a4xx_vbif_perfcounter_select"/>
2185 <reg32 offset="0x30d2" name="VBIF_PERF_CNT_SEL2" type="a4xx_vbif_perfcounter_select"/>
2186 <reg32 offset="0x30d3" name="VBIF_PERF_CNT_SEL3" type="a4xx_vbif_perfcounter_select"/>
2187 <reg32 offset="0x30d8" name="VBIF_PERF_CNT_LOW0"/>
2188 <reg32 offset="0x30d9" name="VBIF_PERF_CNT_LOW1"/>
2189 <reg32 offset="0x30da" name="VBIF_PERF_CNT_LOW2"/>
2190 <reg32 offset="0x30db" name="VBIF_PERF_CNT_LOW3"/>
2191 <reg32 offset="0x30e0" name="VBIF_PERF_CNT_HIGH0"/>
2192 <reg32 offset="0x30e1" name="VBIF_PERF_CNT_HIGH1"/>
2193 <reg32 offset="0x30e2" name="VBIF_PERF_CNT_HIGH2"/>
2194 <reg32 offset="0x30e3" name="VBIF_PERF_CNT_HIGH3"/>
2195 <reg32 offset="0x3100" name="VBIF_PERF_PWR_CNT_EN0"/>
2196 <reg32 offset="0x3101" name="VBIF_PERF_PWR_CNT_EN1"/>
2197 <reg32 offset="0x3102" name="VBIF_PERF_PWR_CNT_EN2"/>
2198
2199 <!--
2200 Unknown registers:
2201 (mostly related to DX11 features not used yet, I guess?)
2202 -->
2203
2204 <!-- always 00000006: -->
2205 <reg32 offset="0x0cc5" name="UNKNOWN_0CC5"/>
2206
2207 <!-- always 00000000: -->
2208 <reg32 offset="0x0cc6" name="UNKNOWN_0CC6"/>
2209
2210 <!-- always 00000001: -->
2211 <reg32 offset="0x0d01" name="UNKNOWN_0D01"/>
2212
2213 <!-- always 00000000: -->
2214 <reg32 offset="0x0e42" name="UNKNOWN_0E42"/>
2215
2216 <!-- always 00040000: -->
2217 <reg32 offset="0x0ec2" name="UNKNOWN_0EC2"/>
2218
2219 <!-- always 00000000: -->
2220 <reg32 offset="0x2001" name="UNKNOWN_2001"/>
2221
2222 <!-- always 00000000: -->
2223 <reg32 offset="0x209b" name="UNKNOWN_209B"/>
2224
2225 <!-- always 00000000: -->
2226 <reg32 offset="0x20ef" name="UNKNOWN_20EF"/>
2227
2228 <!-- always 00000000: -->
2229 <reg32 offset="0x2152" name="UNKNOWN_2152"/>
2230
2231 <!-- always 00000000: -->
2232 <reg32 offset="0x2153" name="UNKNOWN_2153"/>
2233
2234 <!-- always 00000000: -->
2235 <reg32 offset="0x2154" name="UNKNOWN_2154"/>
2236
2237 <!-- always 00000000: -->
2238 <reg32 offset="0x2155" name="UNKNOWN_2155"/>
2239
2240 <!-- always 00000000: -->
2241 <reg32 offset="0x2156" name="UNKNOWN_2156"/>
2242
2243 <!-- always 00000000: -->
2244 <reg32 offset="0x2157" name="UNKNOWN_2157"/>
2245
2246 <!-- always 0000000b: -->
2247 <reg32 offset="0x21c3" name="UNKNOWN_21C3"/>
2248
2249 <!-- always 00000001: -->
2250 <reg32 offset="0x21e6" name="UNKNOWN_21E6"/>
2251
2252 <!-- always 00000000: -->
2253 <reg32 offset="0x2209" name="UNKNOWN_2209"/>
2254
2255 <!-- always 00000000: -->
2256 <reg32 offset="0x22d7" name="UNKNOWN_22D7"/>
2257
2258 <!-- always 00fcfc00: -->
2259 <reg32 offset="0x2352" name="UNKNOWN_2352"/>
2260
2261 </domain>
2262
2263
2264 <domain name="A4XX_TEX_SAMP" width="32">
2265 <doc>Texture sampler dwords</doc>
2266 <enum name="a4xx_tex_filter">
2267 <value name="A4XX_TEX_NEAREST" value="0"/>
2268 <value name="A4XX_TEX_LINEAR" value="1"/>
2269 <value name="A4XX_TEX_ANISO" value="2"/>
2270 </enum>
2271 <enum name="a4xx_tex_clamp">
2272 <value name="A4XX_TEX_REPEAT" value="0"/>
2273 <value name="A4XX_TEX_CLAMP_TO_EDGE" value="1"/>
2274 <value name="A4XX_TEX_MIRROR_REPEAT" value="2"/>
2275 <value name="A4XX_TEX_CLAMP_TO_BORDER" value="3"/>
2276 <value name="A4XX_TEX_MIRROR_CLAMP" value="4"/>
2277 </enum>
2278 <enum name="a4xx_tex_aniso">
2279 <value name="A4XX_TEX_ANISO_1" value="0"/>
2280 <value name="A4XX_TEX_ANISO_2" value="1"/>
2281 <value name="A4XX_TEX_ANISO_4" value="2"/>
2282 <value name="A4XX_TEX_ANISO_8" value="3"/>
2283 <value name="A4XX_TEX_ANISO_16" value="4"/>
2284 </enum>
2285 <reg32 offset="0" name="0">
2286 <bitfield name="MIPFILTER_LINEAR_NEAR" pos="0" type="boolean"/>
2287 <bitfield name="XY_MAG" low="1" high="2" type="a4xx_tex_filter"/>
2288 <bitfield name="XY_MIN" low="3" high="4" type="a4xx_tex_filter"/>
2289 <bitfield name="WRAP_S" low="5" high="7" type="a4xx_tex_clamp"/>
2290 <bitfield name="WRAP_T" low="8" high="10" type="a4xx_tex_clamp"/>
2291 <bitfield name="WRAP_R" low="11" high="13" type="a4xx_tex_clamp"/>
2292 <bitfield name="ANISO" low="14" high="16" type="a4xx_tex_aniso"/>
2293 <bitfield name="LOD_BIAS" low="19" high="31" type="fixed" radix="8"/><!-- no idea how many bits for real -->
2294 </reg32>
2295 <reg32 offset="1" name="1">
2296 <bitfield name="COMPARE_FUNC" low="1" high="3" type="adreno_compare_func"/>
2297 <bitfield name="CUBEMAPSEAMLESSFILTOFF" pos="4" type="boolean"/>
2298 <bitfield name="UNNORM_COORDS" pos="5" type="boolean"/>
2299 <bitfield name="MIPFILTER_LINEAR_FAR" pos="6" type="boolean"/>
2300 <bitfield name="MAX_LOD" low="8" high="19" type="ufixed" radix="8"/>
2301 <bitfield name="MIN_LOD" low="20" high="31" type="ufixed" radix="8"/>
2302 </reg32>
2303 </domain>
2304
2305 <domain name="A4XX_TEX_CONST" width="32">
2306 <doc>Texture constant dwords</doc>
2307 <enum name="a4xx_tex_swiz">
2308 <!-- same as a2xx? -->
2309 <value name="A4XX_TEX_X" value="0"/>
2310 <value name="A4XX_TEX_Y" value="1"/>
2311 <value name="A4XX_TEX_Z" value="2"/>
2312 <value name="A4XX_TEX_W" value="3"/>
2313 <value name="A4XX_TEX_ZERO" value="4"/>
2314 <value name="A4XX_TEX_ONE" value="5"/>
2315 </enum>
2316 <enum name="a4xx_tex_type">
2317 <value name="A4XX_TEX_1D" value="0"/>
2318 <value name="A4XX_TEX_2D" value="1"/>
2319 <value name="A4XX_TEX_CUBE" value="2"/>
2320 <value name="A4XX_TEX_3D" value="3"/>
2321 </enum>
2322 <reg32 offset="0" name="0">
2323 <bitfield name="TILED" pos="0" type="boolean"/>
2324 <bitfield name="SRGB" pos="2" type="boolean"/>
2325 <bitfield name="SWIZ_X" low="4" high="6" type="a4xx_tex_swiz"/>
2326 <bitfield name="SWIZ_Y" low="7" high="9" type="a4xx_tex_swiz"/>
2327 <bitfield name="SWIZ_Z" low="10" high="12" type="a4xx_tex_swiz"/>
2328 <bitfield name="SWIZ_W" low="13" high="15" type="a4xx_tex_swiz"/>
2329 <bitfield name="MIPLVLS" low="16" high="19" type="uint"/>
2330 <bitfield name="FMT" low="22" high="28" type="a4xx_tex_fmt"/>
2331 <bitfield name="TYPE" low="29" high="30" type="a4xx_tex_type"/>
2332 </reg32>
2333 <reg32 offset="1" name="1">
2334 <bitfield name="HEIGHT" low="0" high="14" type="uint"/>
2335 <bitfield name="WIDTH" low="15" high="29" type="uint"/>
2336 </reg32>
2337 <reg32 offset="2" name="2">
2338 <bitfield name="FETCHSIZE" low="0" high="3" type="a4xx_tex_fetchsize"/>
2339 <doc>Pitch in bytes (so actually stride)</doc>
2340 <bitfield name="PITCH" low="9" high="29" type="uint"/>
2341 <bitfield name="SWAP" low="30" high="31" type="a3xx_color_swap"/>
2342 </reg32>
2343 <reg32 offset="3" name="3">
2344 <bitfield name="LAYERSZ" low="0" high="13" shr="12" type="uint"/>
2345 <bitfield name="DEPTH" low="18" high="30" type="uint"/>
2346 </reg32>
2347 <reg32 offset="4" name="4">
2348 <!--
2349 like a3xx we seem to have two LAYERSZ's.. although this one
2350 seems too small to be useful, and when it overflows blob just
2351 sets it to zero..
2352 -->
2353 <bitfield name="LAYERSZ" low="0" high="3" shr="12" type="uint"/>
2354 <bitfield name="BASE" low="5" high="31" shr="5"/>
2355 </reg32>
2356 <reg32 offset="5" name="5"/>
2357 <reg32 offset="6" name="6"/>
2358 <reg32 offset="7" name="7"/>
2359 </domain>
2360
2361 <domain name="A4XX_SSBO_0" width="32">
2362 <reg32 offset="0" name="0">
2363 <bitfield name="BASE" low="5" high="31" shr="5"/>
2364 </reg32>
2365 <reg32 offset="1" name="1">
2366 <doc>Pitch in bytes (so actually stride)</doc>
2367 <bitfield name="PITCH" low="0" high="21" type="uint"/>
2368 </reg32>
2369 <reg32 offset="2" name="2">
2370 <bitfield name="ARRAY_PITCH" low="12" high="25" shr="12" type="uint"/>
2371 </reg32>
2372 <reg32 offset="3" name="3">
2373 <!-- bytes per pixel: -->
2374 <bitfield name="CPP" low="0" high="5" type="uint"/>
2375 </reg32>
2376 </domain>
2377
2378 <domain name="A4XX_SSBO_1" width="32">
2379 <reg32 offset="0" name="0">
2380 <bitfield name="CPP" low="0" high="4" type="uint"/>
2381 <bitfield name="FMT" low="8" high="15" type="a4xx_color_fmt"/>
2382 <bitfield name="WIDTH" low="16" high="31" type="uint"/>
2383 </reg32>
2384 <reg32 offset="1" name="1">
2385 <bitfield name="HEIGHT" low="0" high="15" type="uint"/>
2386 <bitfield name="DEPTH" low="16" high="31" type="uint"/>
2387 </reg32>
2388 </domain>
2389
2390 </database>