1 /**************************************************************************
2 
3 Copyright 2002 ATI Technologies Inc., Ontario, Canada, and
4                      VMware, Inc.
5 
6 All Rights Reserved.
7 
8 Permission is hereby granted, free of charge, to any person obtaining a
9 copy of this software and associated documentation files (the "Software"),
10 to deal in the Software without restriction, including without limitation
11 on the rights to use, copy, modify, merge, publish, distribute, sub
12 license, and/or sell copies of the Software, and to permit persons to whom
13 the Software is furnished to do so, subject to the following conditions:
14 
15 The above copyright notice and this permission notice (including the next
16 paragraph) shall be included in all copies or substantial portions of the
17 Software.
18 
19 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21 FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
22 ATI, VMWARE AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,
23 DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
24 OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
25 USE OR OTHER DEALINGS IN THE SOFTWARE.
26 
27 **************************************************************************/
28 
29 /*
30  * Authors:
31  *   Keith Whitwell <keithw@vmware.com>
32  *
33  */
34 
35 #include <errno.h>
36 
37 #include "main/glheader.h"
38 #include "main/imports.h"
39 
40 #include "r200_context.h"
41 #include "r200_sanity.h"
42 #include "radeon_reg.h"
43 #include "r200_reg.h"
44 
45 /* Set this '1' to get more verbiage.
46  */
47 #define MORE_VERBOSE 1
48 
49 #if MORE_VERBOSE
50 #define VERBOSE (R200_DEBUG & RADEON_VERBOSE)
51 #define NORMAL  (1)
52 #else
53 #define VERBOSE 0
54 #define NORMAL  (R200_DEBUG & RADEON_VERBOSE)
55 #endif
56 
57 
58 /* New (1.3) state mechanism.  3 commands (packet, scalar, vector) in
59  * 1.3 cmdbuffers allow all previous state to be updated as well as
60  * the tcl scalar and vector areas.
61  */
62 static struct {
63    int start;
64    int len;
65    const char *name;
66 } packet[RADEON_MAX_STATE_PACKETS] = {
67    { RADEON_PP_MISC,7,"RADEON_PP_MISC" },
68    { RADEON_PP_CNTL,3,"RADEON_PP_CNTL" },
69    { RADEON_RB3D_COLORPITCH,1,"RADEON_RB3D_COLORPITCH" },
70    { RADEON_RE_LINE_PATTERN,2,"RADEON_RE_LINE_PATTERN" },
71    { RADEON_SE_LINE_WIDTH,1,"RADEON_SE_LINE_WIDTH" },
72    { RADEON_PP_LUM_MATRIX,1,"RADEON_PP_LUM_MATRIX" },
73    { RADEON_PP_ROT_MATRIX_0,2,"RADEON_PP_ROT_MATRIX_0" },
74    { RADEON_RB3D_STENCILREFMASK,3,"RADEON_RB3D_STENCILREFMASK" },
75    { RADEON_SE_VPORT_XSCALE,6,"RADEON_SE_VPORT_XSCALE" },
76    { RADEON_SE_CNTL,2,"RADEON_SE_CNTL" },
77    { RADEON_SE_CNTL_STATUS,1,"RADEON_SE_CNTL_STATUS" },
78    { RADEON_RE_MISC,1,"RADEON_RE_MISC" },
79    { RADEON_PP_TXFILTER_0,6,"RADEON_PP_TXFILTER_0" },
80    { RADEON_PP_BORDER_COLOR_0,1,"RADEON_PP_BORDER_COLOR_0" },
81    { RADEON_PP_TXFILTER_1,6,"RADEON_PP_TXFILTER_1" },
82    { RADEON_PP_BORDER_COLOR_1,1,"RADEON_PP_BORDER_COLOR_1" },
83    { RADEON_PP_TXFILTER_2,6,"RADEON_PP_TXFILTER_2" },
84    { RADEON_PP_BORDER_COLOR_2,1,"RADEON_PP_BORDER_COLOR_2" },
85    { RADEON_SE_ZBIAS_FACTOR,2,"RADEON_SE_ZBIAS_FACTOR" },
86    { RADEON_SE_TCL_OUTPUT_VTX_FMT,11,"RADEON_SE_TCL_OUTPUT_VTX_FMT" },
87    { RADEON_SE_TCL_MATERIAL_EMMISSIVE_RED,17,"RADEON_SE_TCL_MATERIAL_EMMISSIVE_RED" },
88    { R200_PP_TXCBLEND_0, 4, "R200_EMIT_PP_TXCBLEND_0" },
89    { R200_PP_TXCBLEND_1, 4, "R200_PP_TXCBLEND_1" },
90    { R200_PP_TXCBLEND_2, 4, "R200_PP_TXCBLEND_2" },
91    { R200_PP_TXCBLEND_3, 4, "R200_PP_TXCBLEND_3" },
92    { R200_PP_TXCBLEND_4, 4, "R200_PP_TXCBLEND_4" },
93    { R200_PP_TXCBLEND_5, 4, "R200_PP_TXCBLEND_5" },
94    { R200_PP_TXCBLEND_6, 4, "R200_PP_TXCBLEND_6" },
95    { R200_PP_TXCBLEND_7, 4, "R200_PP_TXCBLEND_7" },
96    { R200_SE_TCL_LIGHT_MODEL_CTL_0, 6, "R200_SE_TCL_LIGHT_MODEL_CTL_0" },
97    { R200_PP_TFACTOR_0, 6, "R200_PP_TFACTOR_0" },
98    { R200_SE_VTX_FMT_0, 4, "R200_SE_VTX_FMT_0" },
99    { R200_SE_VAP_CNTL, 1, "R200_SE_VAP_CNTL" },
100    { R200_SE_TCL_MATRIX_SEL_0, 5, "R200_SE_TCL_MATRIX_SEL_0" },
101    { R200_SE_TCL_TEX_PROC_CTL_2, 5, "R200_SE_TCL_TEX_PROC_CTL_2" },
102    { R200_SE_TCL_UCP_VERT_BLEND_CTL, 1, "R200_SE_TCL_UCP_VERT_BLEND_CTL" },
103    { R200_PP_TXFILTER_0, 6, "R200_PP_TXFILTER_0" },
104    { R200_PP_TXFILTER_1, 6, "R200_PP_TXFILTER_1" },
105    { R200_PP_TXFILTER_2, 6, "R200_PP_TXFILTER_2" },
106    { R200_PP_TXFILTER_3, 6, "R200_PP_TXFILTER_3" },
107    { R200_PP_TXFILTER_4, 6, "R200_PP_TXFILTER_4" },
108    { R200_PP_TXFILTER_5, 6, "R200_PP_TXFILTER_5" },
109    { R200_PP_TXOFFSET_0, 1, "R200_PP_TXOFFSET_0" },
110    { R200_PP_TXOFFSET_1, 1, "R200_PP_TXOFFSET_1" },
111    { R200_PP_TXOFFSET_2, 1, "R200_PP_TXOFFSET_2" },
112    { R200_PP_TXOFFSET_3, 1, "R200_PP_TXOFFSET_3" },
113    { R200_PP_TXOFFSET_4, 1, "R200_PP_TXOFFSET_4" },
114    { R200_PP_TXOFFSET_5, 1, "R200_PP_TXOFFSET_5" },
115    { R200_SE_VTE_CNTL, 1, "R200_SE_VTE_CNTL" },
116    { R200_SE_TCL_OUTPUT_VTX_COMP_SEL, 1, "R200_SE_TCL_OUTPUT_VTX_COMP_SEL" },
117    { R200_PP_TAM_DEBUG3, 1, "R200_PP_TAM_DEBUG3" },
118    { R200_PP_CNTL_X, 1, "R200_PP_CNTL_X" },
119    { R200_RB3D_DEPTHXY_OFFSET, 1, "R200_RB3D_DEPTHXY_OFFSET" },
120    { R200_RE_AUX_SCISSOR_CNTL, 1, "R200_RE_AUX_SCISSOR_CNTL" },
121    { R200_RE_SCISSOR_TL_0, 2, "R200_RE_SCISSOR_TL_0" },
122    { R200_RE_SCISSOR_TL_1, 2, "R200_RE_SCISSOR_TL_1" },
123    { R200_RE_SCISSOR_TL_2, 2, "R200_RE_SCISSOR_TL_2" },
124    { R200_SE_VAP_CNTL_STATUS, 1, "R200_SE_VAP_CNTL_STATUS" },
125    { R200_SE_VTX_STATE_CNTL, 1, "R200_SE_VTX_STATE_CNTL" },
126    { R200_RE_POINTSIZE, 1, "R200_RE_POINTSIZE" },
127    { R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_0, 4, "R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_0" },
128    { R200_PP_CUBIC_FACES_0, 1, "R200_PP_CUBIC_FACES_0" }, /* 61 */
129    { R200_PP_CUBIC_OFFSET_F1_0, 5, "R200_PP_CUBIC_OFFSET_F1_0" }, /* 62 */
130    { R200_PP_CUBIC_FACES_1, 1, "R200_PP_CUBIC_FACES_1" },
131    { R200_PP_CUBIC_OFFSET_F1_1, 5, "R200_PP_CUBIC_OFFSET_F1_1" },
132    { R200_PP_CUBIC_FACES_2, 1, "R200_PP_CUBIC_FACES_2" },
133    { R200_PP_CUBIC_OFFSET_F1_2, 5, "R200_PP_CUBIC_OFFSET_F1_2" },
134    { R200_PP_CUBIC_FACES_3, 1, "R200_PP_CUBIC_FACES_3" },
135    { R200_PP_CUBIC_OFFSET_F1_3, 5, "R200_PP_CUBIC_OFFSET_F1_3" },
136    { R200_PP_CUBIC_FACES_4, 1, "R200_PP_CUBIC_FACES_4" },
137    { R200_PP_CUBIC_OFFSET_F1_4, 5, "R200_PP_CUBIC_OFFSET_F1_4" },
138    { R200_PP_CUBIC_FACES_5, 1, "R200_PP_CUBIC_FACES_5" },
139    { R200_PP_CUBIC_OFFSET_F1_5, 5, "R200_PP_CUBIC_OFFSET_F1_5" },
140    { RADEON_PP_TEX_SIZE_0, 2, "RADEON_PP_TEX_SIZE_0" },
141    { RADEON_PP_TEX_SIZE_1, 2, "RADEON_PP_TEX_SIZE_1" },
142    { RADEON_PP_TEX_SIZE_2, 2, "RADEON_PP_TEX_SIZE_2" },
143    { R200_RB3D_BLENDCOLOR, 3, "R200_RB3D_BLENDCOLOR" },
144    { R200_SE_TCL_POINT_SPRITE_CNTL, 1, "R200_SE_TCL_POINT_SPRITE_CNTL" },
145    { RADEON_PP_CUBIC_FACES_0, 1, "RADEON_PP_CUBIC_FACES_0" },
146    { RADEON_PP_CUBIC_OFFSET_T0_0, 5, "RADEON_PP_CUBIC_OFFSET_T0_0" },
147    { RADEON_PP_CUBIC_FACES_1, 1, "RADEON_PP_CUBIC_FACES_1" },
148    { RADEON_PP_CUBIC_OFFSET_T1_0, 5, "RADEON_PP_CUBIC_OFFSET_T1_0" },
149    { RADEON_PP_CUBIC_FACES_2, 1, "RADEON_PP_CUBIC_FACES_2" },
150    { RADEON_PP_CUBIC_OFFSET_T2_0, 5, "RADEON_PP_CUBIC_OFFSET_T2_0" },
151    { R200_PP_TRI_PERF, 2, "R200_PP_TRI_PERF" },
152    { R200_PP_TXCBLEND_8, 32, "R200_PP_AFS_0"},   /* 85 */
153    { R200_PP_TXCBLEND_0, 32, "R200_PP_AFS_1"},
154    { R200_PP_TFACTOR_0, 8, "R200_ATF_TFACTOR"},
155    { R200_PP_TXFILTER_0, 8, "R200_PP_TXCTLALL_0"},
156    { R200_PP_TXFILTER_1, 8, "R200_PP_TXCTLALL_1"},
157    { R200_PP_TXFILTER_2, 8, "R200_PP_TXCTLALL_2"},
158    { R200_PP_TXFILTER_3, 8, "R200_PP_TXCTLALL_3"},
159    { R200_PP_TXFILTER_4, 8, "R200_PP_TXCTLALL_4"},
160    { R200_PP_TXFILTER_5, 8, "R200_PP_TXCTLALL_5"},
161    { R200_VAP_PVS_CNTL_1, 2, "R200_VAP_PVS_CNTL"},
162 };
163 
164 struct reg_names {
165    int idx;
166    const char *name;
167 };
168 
169 static struct reg_names reg_names[] = {
170    { R200_PP_MISC, "R200_PP_MISC" },
171    { R200_PP_FOG_COLOR, "R200_PP_FOG_COLOR" },
172    { R200_RE_SOLID_COLOR, "R200_RE_SOLID_COLOR" },
173    { R200_RB3D_BLENDCNTL, "R200_RB3D_BLENDCNTL" },
174    { R200_RB3D_DEPTHOFFSET, "R200_RB3D_DEPTHOFFSET" },
175    { R200_RB3D_DEPTHPITCH, "R200_RB3D_DEPTHPITCH" },
176    { R200_RB3D_ZSTENCILCNTL, "R200_RB3D_ZSTENCILCNTL" },
177    { R200_PP_CNTL, "R200_PP_CNTL" },
178    { R200_RB3D_CNTL, "R200_RB3D_CNTL" },
179    { R200_RB3D_COLOROFFSET, "R200_RB3D_COLOROFFSET" },
180    { R200_RE_WIDTH_HEIGHT, "R200_RE_WIDTH_HEIGHT" },
181    { R200_RB3D_COLORPITCH, "R200_RB3D_COLORPITCH" },
182    { R200_SE_CNTL, "R200_SE_CNTL" },
183    { R200_RE_CNTL, "R200_RE_CNTL" },
184    { R200_RE_MISC, "R200_RE_MISC" },
185    { R200_RE_STIPPLE_ADDR, "R200_RE_STIPPLE_ADDR" },
186    { R200_RE_STIPPLE_DATA, "R200_RE_STIPPLE_DATA" },
187    { R200_RE_LINE_PATTERN, "R200_RE_LINE_PATTERN" },
188    { R200_RE_LINE_STATE, "R200_RE_LINE_STATE" },
189    { R200_RE_SCISSOR_TL_0, "R200_RE_SCISSOR_TL_0" },
190    { R200_RE_SCISSOR_BR_0, "R200_RE_SCISSOR_BR_0" },
191    { R200_RE_SCISSOR_TL_1, "R200_RE_SCISSOR_TL_1" },
192    { R200_RE_SCISSOR_BR_1, "R200_RE_SCISSOR_BR_1" },
193    { R200_RE_SCISSOR_TL_2, "R200_RE_SCISSOR_TL_2" },
194    { R200_RE_SCISSOR_BR_2, "R200_RE_SCISSOR_BR_2" },
195    { R200_RB3D_DEPTHXY_OFFSET, "R200_RB3D_DEPTHXY_OFFSET" },
196    { R200_RB3D_STENCILREFMASK, "R200_RB3D_STENCILREFMASK" },
197    { R200_RB3D_ROPCNTL, "R200_RB3D_ROPCNTL" },
198    { R200_RB3D_PLANEMASK, "R200_RB3D_PLANEMASK" },
199    { R200_SE_VPORT_XSCALE, "R200_SE_VPORT_XSCALE" },
200    { R200_SE_VPORT_XOFFSET, "R200_SE_VPORT_XOFFSET" },
201    { R200_SE_VPORT_YSCALE, "R200_SE_VPORT_YSCALE" },
202    { R200_SE_VPORT_YOFFSET, "R200_SE_VPORT_YOFFSET" },
203    { R200_SE_VPORT_ZSCALE, "R200_SE_VPORT_ZSCALE" },
204    { R200_SE_VPORT_ZOFFSET, "R200_SE_VPORT_ZOFFSET" },
205    { R200_SE_ZBIAS_FACTOR, "R200_SE_ZBIAS_FACTOR" },
206    { R200_SE_ZBIAS_CONSTANT, "R200_SE_ZBIAS_CONSTANT" },
207    { R200_SE_LINE_WIDTH, "R200_SE_LINE_WIDTH" },
208    { R200_SE_VAP_CNTL, "R200_SE_VAP_CNTL" },
209    { R200_SE_VF_CNTL, "R200_SE_VF_CNTL" },
210    { R200_SE_VTX_FMT_0, "R200_SE_VTX_FMT_0" },
211    { R200_SE_VTX_FMT_1, "R200_SE_VTX_FMT_1" },
212    { R200_SE_TCL_OUTPUT_VTX_FMT_0, "R200_SE_TCL_OUTPUT_VTX_FMT_0" },
213    { R200_SE_TCL_OUTPUT_VTX_FMT_1, "R200_SE_TCL_OUTPUT_VTX_FMT_1" },
214    { R200_SE_VTE_CNTL, "R200_SE_VTE_CNTL" },
215    { R200_SE_VTX_NUM_ARRAYS, "R200_SE_VTX_NUM_ARRAYS" },
216    { R200_SE_VTX_AOS_ATTR01, "R200_SE_VTX_AOS_ATTR01" },
217    { R200_SE_VTX_AOS_ADDR0, "R200_SE_VTX_AOS_ADDR0" },
218    { R200_SE_VTX_AOS_ADDR1, "R200_SE_VTX_AOS_ADDR1" },
219    { R200_SE_VTX_AOS_ATTR23, "R200_SE_VTX_AOS_ATTR23" },
220    { R200_SE_VTX_AOS_ADDR2, "R200_SE_VTX_AOS_ADDR2" },
221    { R200_SE_VTX_AOS_ADDR3, "R200_SE_VTX_AOS_ADDR3" },
222    { R200_SE_VTX_AOS_ATTR45, "R200_SE_VTX_AOS_ATTR45" },
223    { R200_SE_VTX_AOS_ADDR4, "R200_SE_VTX_AOS_ADDR4" },
224    { R200_SE_VTX_AOS_ADDR5, "R200_SE_VTX_AOS_ADDR5" },
225    { R200_SE_VTX_AOS_ATTR67, "R200_SE_VTX_AOS_ATTR67" },
226    { R200_SE_VTX_AOS_ADDR6, "R200_SE_VTX_AOS_ADDR6" },
227    { R200_SE_VTX_AOS_ADDR7, "R200_SE_VTX_AOS_ADDR7" },
228    { R200_SE_VTX_AOS_ATTR89, "R200_SE_VTX_AOS_ATTR89" },
229    { R200_SE_VTX_AOS_ADDR8, "R200_SE_VTX_AOS_ADDR8" },
230    { R200_SE_VTX_AOS_ADDR9, "R200_SE_VTX_AOS_ADDR9" },
231    { R200_SE_VTX_AOS_ATTR1011, "R200_SE_VTX_AOS_ATTR1011" },
232    { R200_SE_VTX_AOS_ADDR10, "R200_SE_VTX_AOS_ADDR10" },
233    { R200_SE_VTX_AOS_ADDR11, "R200_SE_VTX_AOS_ADDR11" },
234    { R200_SE_VF_MAX_VTX_INDX, "R200_SE_VF_MAX_VTX_INDX" },
235    { R200_SE_VF_MIN_VTX_INDX, "R200_SE_VF_MIN_VTX_INDX" },
236    { R200_SE_VTX_STATE_CNTL, "R200_SE_VTX_STATE_CNTL" },
237    { R200_SE_TCL_VECTOR_INDX_REG, "R200_SE_TCL_VECTOR_INDX_REG" },
238    { R200_SE_TCL_VECTOR_DATA_REG, "R200_SE_TCL_VECTOR_DATA_REG" },
239    { R200_SE_TCL_SCALAR_INDX_REG, "R200_SE_TCL_SCALAR_INDX_REG" },
240    { R200_SE_TCL_SCALAR_DATA_REG, "R200_SE_TCL_SCALAR_DATA_REG" },
241    { R200_SE_TCL_MATRIX_SEL_0, "R200_SE_TCL_MATRIX_SEL_0" },
242    { R200_SE_TCL_MATRIX_SEL_1, "R200_SE_TCL_MATRIX_SEL_1" },
243    { R200_SE_TCL_MATRIX_SEL_2, "R200_SE_TCL_MATRIX_SEL_2" },
244    { R200_SE_TCL_MATRIX_SEL_3, "R200_SE_TCL_MATRIX_SEL_3" },
245    { R200_SE_TCL_MATRIX_SEL_4, "R200_SE_TCL_MATRIX_SEL_4" },
246    { R200_SE_TCL_LIGHT_MODEL_CTL_0, "R200_SE_TCL_LIGHT_MODEL_CTL_0" },
247    { R200_SE_TCL_LIGHT_MODEL_CTL_1, "R200_SE_TCL_LIGHT_MODEL_CTL_1" },
248    { R200_SE_TCL_PER_LIGHT_CTL_0, "R200_SE_TCL_PER_LIGHT_CTL_0" },
249    { R200_SE_TCL_PER_LIGHT_CTL_1, "R200_SE_TCL_PER_LIGHT_CTL_1" },
250    { R200_SE_TCL_PER_LIGHT_CTL_2, "R200_SE_TCL_PER_LIGHT_CTL_2" },
251    { R200_SE_TCL_PER_LIGHT_CTL_3, "R200_SE_TCL_PER_LIGHT_CTL_3" },
252    { R200_SE_TCL_TEX_PROC_CTL_2, "R200_SE_TCL_TEX_PROC_CTL_2" },
253    { R200_SE_TCL_TEX_PROC_CTL_3, "R200_SE_TCL_TEX_PROC_CTL_3" },
254    { R200_SE_TCL_TEX_PROC_CTL_0, "R200_SE_TCL_TEX_PROC_CTL_0" },
255    { R200_SE_TCL_TEX_PROC_CTL_1, "R200_SE_TCL_TEX_PROC_CTL_1" },
256    { R200_SE_TC_TEX_CYL_WRAP_CTL, "R200_SE_TC_TEX_CYL_WRAP_CTL" },
257    { R200_SE_TCL_UCP_VERT_BLEND_CTL, "R200_SE_TCL_UCP_VERT_BLEND_CTL" },
258    { R200_SE_TCL_POINT_SPRITE_CNTL, "R200_SE_TCL_POINT_SPRITE_CNTL" },
259    { R200_SE_VTX_ST_POS_0_X_4, "R200_SE_VTX_ST_POS_0_X_4" },
260    { R200_SE_VTX_ST_POS_0_Y_4, "R200_SE_VTX_ST_POS_0_Y_4" },
261    { R200_SE_VTX_ST_POS_0_Z_4, "R200_SE_VTX_ST_POS_0_Z_4" },
262    { R200_SE_VTX_ST_POS_0_W_4, "R200_SE_VTX_ST_POS_0_W_4" },
263    { R200_SE_VTX_ST_NORM_0_X, "R200_SE_VTX_ST_NORM_0_X" },
264    { R200_SE_VTX_ST_NORM_0_Y, "R200_SE_VTX_ST_NORM_0_Y" },
265    { R200_SE_VTX_ST_NORM_0_Z, "R200_SE_VTX_ST_NORM_0_Z" },
266    { R200_SE_VTX_ST_PVMS, "R200_SE_VTX_ST_PVMS" },
267    { R200_SE_VTX_ST_CLR_0_R, "R200_SE_VTX_ST_CLR_0_R" },
268    { R200_SE_VTX_ST_CLR_0_G, "R200_SE_VTX_ST_CLR_0_G" },
269    { R200_SE_VTX_ST_CLR_0_B, "R200_SE_VTX_ST_CLR_0_B" },
270    { R200_SE_VTX_ST_CLR_0_A, "R200_SE_VTX_ST_CLR_0_A" },
271    { R200_SE_VTX_ST_CLR_1_R, "R200_SE_VTX_ST_CLR_1_R" },
272    { R200_SE_VTX_ST_CLR_1_G, "R200_SE_VTX_ST_CLR_1_G" },
273    { R200_SE_VTX_ST_CLR_1_B, "R200_SE_VTX_ST_CLR_1_B" },
274    { R200_SE_VTX_ST_CLR_1_A, "R200_SE_VTX_ST_CLR_1_A" },
275    { R200_SE_VTX_ST_CLR_2_R, "R200_SE_VTX_ST_CLR_2_R" },
276    { R200_SE_VTX_ST_CLR_2_G, "R200_SE_VTX_ST_CLR_2_G" },
277    { R200_SE_VTX_ST_CLR_2_B, "R200_SE_VTX_ST_CLR_2_B" },
278    { R200_SE_VTX_ST_CLR_2_A, "R200_SE_VTX_ST_CLR_2_A" },
279    { R200_SE_VTX_ST_CLR_3_R, "R200_SE_VTX_ST_CLR_3_R" },
280    { R200_SE_VTX_ST_CLR_3_G, "R200_SE_VTX_ST_CLR_3_G" },
281    { R200_SE_VTX_ST_CLR_3_B, "R200_SE_VTX_ST_CLR_3_B" },
282    { R200_SE_VTX_ST_CLR_3_A, "R200_SE_VTX_ST_CLR_3_A" },
283    { R200_SE_VTX_ST_CLR_4_R, "R200_SE_VTX_ST_CLR_4_R" },
284    { R200_SE_VTX_ST_CLR_4_G, "R200_SE_VTX_ST_CLR_4_G" },
285    { R200_SE_VTX_ST_CLR_4_B, "R200_SE_VTX_ST_CLR_4_B" },
286    { R200_SE_VTX_ST_CLR_4_A, "R200_SE_VTX_ST_CLR_4_A" },
287    { R200_SE_VTX_ST_CLR_5_R, "R200_SE_VTX_ST_CLR_5_R" },
288    { R200_SE_VTX_ST_CLR_5_G, "R200_SE_VTX_ST_CLR_5_G" },
289    { R200_SE_VTX_ST_CLR_5_B, "R200_SE_VTX_ST_CLR_5_B" },
290    { R200_SE_VTX_ST_CLR_5_A, "R200_SE_VTX_ST_CLR_5_A" },
291    { R200_SE_VTX_ST_CLR_6_R, "R200_SE_VTX_ST_CLR_6_R" },
292    { R200_SE_VTX_ST_CLR_6_G, "R200_SE_VTX_ST_CLR_6_G" },
293    { R200_SE_VTX_ST_CLR_6_B, "R200_SE_VTX_ST_CLR_6_B" },
294    { R200_SE_VTX_ST_CLR_6_A, "R200_SE_VTX_ST_CLR_6_A" },
295    { R200_SE_VTX_ST_CLR_7_R, "R200_SE_VTX_ST_CLR_7_R" },
296    { R200_SE_VTX_ST_CLR_7_G, "R200_SE_VTX_ST_CLR_7_G" },
297    { R200_SE_VTX_ST_CLR_7_B, "R200_SE_VTX_ST_CLR_7_B" },
298    { R200_SE_VTX_ST_CLR_7_A, "R200_SE_VTX_ST_CLR_7_A" },
299    { R200_SE_VTX_ST_TEX_0_S, "R200_SE_VTX_ST_TEX_0_S" },
300    { R200_SE_VTX_ST_TEX_0_T, "R200_SE_VTX_ST_TEX_0_T" },
301    { R200_SE_VTX_ST_TEX_0_R, "R200_SE_VTX_ST_TEX_0_R" },
302    { R200_SE_VTX_ST_TEX_0_Q, "R200_SE_VTX_ST_TEX_0_Q" },
303    { R200_SE_VTX_ST_TEX_1_S, "R200_SE_VTX_ST_TEX_1_S" },
304    { R200_SE_VTX_ST_TEX_1_T, "R200_SE_VTX_ST_TEX_1_T" },
305    { R200_SE_VTX_ST_TEX_1_R, "R200_SE_VTX_ST_TEX_1_R" },
306    { R200_SE_VTX_ST_TEX_1_Q, "R200_SE_VTX_ST_TEX_1_Q" },
307    { R200_SE_VTX_ST_TEX_2_S, "R200_SE_VTX_ST_TEX_2_S" },
308    { R200_SE_VTX_ST_TEX_2_T, "R200_SE_VTX_ST_TEX_2_T" },
309    { R200_SE_VTX_ST_TEX_2_R, "R200_SE_VTX_ST_TEX_2_R" },
310    { R200_SE_VTX_ST_TEX_2_Q, "R200_SE_VTX_ST_TEX_2_Q" },
311    { R200_SE_VTX_ST_TEX_3_S, "R200_SE_VTX_ST_TEX_3_S" },
312    { R200_SE_VTX_ST_TEX_3_T, "R200_SE_VTX_ST_TEX_3_T" },
313    { R200_SE_VTX_ST_TEX_3_R, "R200_SE_VTX_ST_TEX_3_R" },
314    { R200_SE_VTX_ST_TEX_3_Q, "R200_SE_VTX_ST_TEX_3_Q" },
315    { R200_SE_VTX_ST_TEX_4_S, "R200_SE_VTX_ST_TEX_4_S" },
316    { R200_SE_VTX_ST_TEX_4_T, "R200_SE_VTX_ST_TEX_4_T" },
317    { R200_SE_VTX_ST_TEX_4_R, "R200_SE_VTX_ST_TEX_4_R" },
318    { R200_SE_VTX_ST_TEX_4_Q, "R200_SE_VTX_ST_TEX_4_Q" },
319    { R200_SE_VTX_ST_TEX_5_S, "R200_SE_VTX_ST_TEX_5_S" },
320    { R200_SE_VTX_ST_TEX_5_T, "R200_SE_VTX_ST_TEX_5_T" },
321    { R200_SE_VTX_ST_TEX_5_R, "R200_SE_VTX_ST_TEX_5_R" },
322    { R200_SE_VTX_ST_TEX_5_Q, "R200_SE_VTX_ST_TEX_5_Q" },
323    { R200_SE_VTX_ST_PNT_SPRT_SZ, "R200_SE_VTX_ST_PNT_SPRT_SZ" },
324    { R200_SE_VTX_ST_DISC_FOG, "R200_SE_VTX_ST_DISC_FOG" },
325    { R200_SE_VTX_ST_SHININESS_0, "R200_SE_VTX_ST_SHININESS_0" },
326    { R200_SE_VTX_ST_SHININESS_1, "R200_SE_VTX_ST_SHININESS_1" },
327    { R200_SE_VTX_ST_BLND_WT_0, "R200_SE_VTX_ST_BLND_WT_0" },
328    { R200_SE_VTX_ST_BLND_WT_1, "R200_SE_VTX_ST_BLND_WT_1" },
329    { R200_SE_VTX_ST_BLND_WT_2, "R200_SE_VTX_ST_BLND_WT_2" },
330    { R200_SE_VTX_ST_BLND_WT_3, "R200_SE_VTX_ST_BLND_WT_3" },
331    { R200_SE_VTX_ST_POS_1_X, "R200_SE_VTX_ST_POS_1_X" },
332    { R200_SE_VTX_ST_POS_1_Y, "R200_SE_VTX_ST_POS_1_Y" },
333    { R200_SE_VTX_ST_POS_1_Z, "R200_SE_VTX_ST_POS_1_Z" },
334    { R200_SE_VTX_ST_POS_1_W, "R200_SE_VTX_ST_POS_1_W" },
335    { R200_SE_VTX_ST_NORM_1_X, "R200_SE_VTX_ST_NORM_1_X" },
336    { R200_SE_VTX_ST_NORM_1_Y, "R200_SE_VTX_ST_NORM_1_Y" },
337    { R200_SE_VTX_ST_NORM_1_Z, "R200_SE_VTX_ST_NORM_1_Z" },
338    { R200_SE_VTX_ST_USR_CLR_0_R, "R200_SE_VTX_ST_USR_CLR_0_R" },
339    { R200_SE_VTX_ST_USR_CLR_0_G, "R200_SE_VTX_ST_USR_CLR_0_G" },
340    { R200_SE_VTX_ST_USR_CLR_0_B, "R200_SE_VTX_ST_USR_CLR_0_B" },
341    { R200_SE_VTX_ST_USR_CLR_0_A, "R200_SE_VTX_ST_USR_CLR_0_A" },
342    { R200_SE_VTX_ST_USR_CLR_1_R, "R200_SE_VTX_ST_USR_CLR_1_R" },
343    { R200_SE_VTX_ST_USR_CLR_1_G, "R200_SE_VTX_ST_USR_CLR_1_G" },
344    { R200_SE_VTX_ST_USR_CLR_1_B, "R200_SE_VTX_ST_USR_CLR_1_B" },
345    { R200_SE_VTX_ST_USR_CLR_1_A, "R200_SE_VTX_ST_USR_CLR_1_A" },
346    { R200_SE_VTX_ST_CLR_0_PKD, "R200_SE_VTX_ST_CLR_0_PKD" },
347    { R200_SE_VTX_ST_CLR_1_PKD, "R200_SE_VTX_ST_CLR_1_PKD" },
348    { R200_SE_VTX_ST_CLR_2_PKD, "R200_SE_VTX_ST_CLR_2_PKD" },
349    { R200_SE_VTX_ST_CLR_3_PKD, "R200_SE_VTX_ST_CLR_3_PKD" },
350    { R200_SE_VTX_ST_CLR_4_PKD, "R200_SE_VTX_ST_CLR_4_PKD" },
351    { R200_SE_VTX_ST_CLR_5_PKD, "R200_SE_VTX_ST_CLR_5_PKD" },
352    { R200_SE_VTX_ST_CLR_6_PKD, "R200_SE_VTX_ST_CLR_6_PKD" },
353    { R200_SE_VTX_ST_CLR_7_PKD, "R200_SE_VTX_ST_CLR_7_PKD" },
354    { R200_SE_VTX_ST_POS_0_X_2, "R200_SE_VTX_ST_POS_0_X_2" },
355    { R200_SE_VTX_ST_POS_0_Y_2, "R200_SE_VTX_ST_POS_0_Y_2" },
356    { R200_SE_VTX_ST_PAR_CLR_LD, "R200_SE_VTX_ST_PAR_CLR_LD" },
357    { R200_SE_VTX_ST_USR_CLR_PKD, "R200_SE_VTX_ST_USR_CLR_PKD" },
358    { R200_SE_VTX_ST_POS_0_X_3, "R200_SE_VTX_ST_POS_0_X_3" },
359    { R200_SE_VTX_ST_POS_0_Y_3, "R200_SE_VTX_ST_POS_0_Y_3" },
360    { R200_SE_VTX_ST_POS_0_Z_3, "R200_SE_VTX_ST_POS_0_Z_3" },
361    { R200_SE_VTX_ST_END_OF_PKT, "R200_SE_VTX_ST_END_OF_PKT" },
362    { R200_RE_POINTSIZE, "R200_RE_POINTSIZE" },
363    { R200_RE_TOP_LEFT, "R200_RE_TOP_LEFT" },
364    { R200_RE_AUX_SCISSOR_CNTL, "R200_RE_AUX_SCISSOR_CNTL" },
365    { R200_PP_TXFILTER_0, "R200_PP_TXFILTER_0" },
366    { R200_PP_TXFORMAT_0, "R200_PP_TXFORMAT_0" },
367    { R200_PP_TXSIZE_0, "R200_PP_TXSIZE_0" },
368    { R200_PP_TXFORMAT_X_0, "R200_PP_TXFORMAT_X_0" },
369    { R200_PP_TXPITCH_0, "R200_PP_TXPITCH_0" },
370    { R200_PP_BORDER_COLOR_0, "R200_PP_BORDER_COLOR_0" },
371    { R200_PP_CUBIC_FACES_0, "R200_PP_CUBIC_FACES_0" },
372    { R200_PP_TXMULTI_CTL_0, "R200_PP_TXMULTI_CTL_0" },
373    { R200_PP_TXFILTER_1, "R200_PP_TXFILTER_1" },
374    { R200_PP_TXFORMAT_1, "R200_PP_TXFORMAT_1" },
375    { R200_PP_TXSIZE_1, "R200_PP_TXSIZE_1" },
376    { R200_PP_TXFORMAT_X_1, "R200_PP_TXFORMAT_X_1" },
377    { R200_PP_TXPITCH_1, "R200_PP_TXPITCH_1" },
378    { R200_PP_BORDER_COLOR_1, "R200_PP_BORDER_COLOR_1" },
379    { R200_PP_CUBIC_FACES_1, "R200_PP_CUBIC_FACES_1" },
380    { R200_PP_TXMULTI_CTL_1, "R200_PP_TXMULTI_CTL_1" },
381    { R200_PP_TXFILTER_2, "R200_PP_TXFILTER_2" },
382    { R200_PP_TXFORMAT_2, "R200_PP_TXFORMAT_2" },
383    { R200_PP_TXSIZE_2, "R200_PP_TXSIZE_2" },
384    { R200_PP_TXFORMAT_X_2, "R200_PP_TXFORMAT_X_2" },
385    { R200_PP_TXPITCH_2, "R200_PP_TXPITCH_2" },
386    { R200_PP_BORDER_COLOR_2, "R200_PP_BORDER_COLOR_2" },
387    { R200_PP_CUBIC_FACES_2, "R200_PP_CUBIC_FACES_2" },
388    { R200_PP_TXMULTI_CTL_2, "R200_PP_TXMULTI_CTL_2" },
389    { R200_PP_TXFILTER_3, "R200_PP_TXFILTER_3" },
390    { R200_PP_TXFORMAT_3, "R200_PP_TXFORMAT_3" },
391    { R200_PP_TXSIZE_3, "R200_PP_TXSIZE_3" },
392    { R200_PP_TXFORMAT_X_3, "R200_PP_TXFORMAT_X_3" },
393    { R200_PP_TXPITCH_3, "R200_PP_TXPITCH_3" },
394    { R200_PP_BORDER_COLOR_3, "R200_PP_BORDER_COLOR_3" },
395    { R200_PP_CUBIC_FACES_3, "R200_PP_CUBIC_FACES_3" },
396    { R200_PP_TXMULTI_CTL_3, "R200_PP_TXMULTI_CTL_3" },
397    { R200_PP_TXFILTER_4, "R200_PP_TXFILTER_4" },
398    { R200_PP_TXFORMAT_4, "R200_PP_TXFORMAT_4" },
399    { R200_PP_TXSIZE_4, "R200_PP_TXSIZE_4" },
400    { R200_PP_TXFORMAT_X_4, "R200_PP_TXFORMAT_X_4" },
401    { R200_PP_TXPITCH_4, "R200_PP_TXPITCH_4" },
402    { R200_PP_BORDER_COLOR_4, "R200_PP_BORDER_COLOR_4" },
403    { R200_PP_CUBIC_FACES_4, "R200_PP_CUBIC_FACES_4" },
404    { R200_PP_TXMULTI_CTL_4, "R200_PP_TXMULTI_CTL_4" },
405    { R200_PP_TXFILTER_5, "R200_PP_TXFILTER_5" },
406    { R200_PP_TXFORMAT_5, "R200_PP_TXFORMAT_5" },
407    { R200_PP_TXSIZE_5, "R200_PP_TXSIZE_5" },
408    { R200_PP_TXFORMAT_X_5, "R200_PP_TXFORMAT_X_5" },
409    { R200_PP_TXPITCH_5, "R200_PP_TXPITCH_5" },
410    { R200_PP_BORDER_COLOR_5, "R200_PP_BORDER_COLOR_5" },
411    { R200_PP_CUBIC_FACES_5, "R200_PP_CUBIC_FACES_5" },
412    { R200_PP_TXMULTI_CTL_5, "R200_PP_TXMULTI_CTL_5" },
413    { R200_PP_TXOFFSET_0, "R200_PP_TXOFFSET_0" },
414    { R200_PP_CUBIC_OFFSET_F1_0, "R200_PP_CUBIC_OFFSET_F1_0" },
415    { R200_PP_CUBIC_OFFSET_F2_0, "R200_PP_CUBIC_OFFSET_F2_0" },
416    { R200_PP_CUBIC_OFFSET_F3_0, "R200_PP_CUBIC_OFFSET_F3_0" },
417    { R200_PP_CUBIC_OFFSET_F4_0, "R200_PP_CUBIC_OFFSET_F4_0" },
418    { R200_PP_CUBIC_OFFSET_F5_0, "R200_PP_CUBIC_OFFSET_F5_0" },
419    { R200_PP_TXOFFSET_1, "R200_PP_TXOFFSET_1" },
420    { R200_PP_CUBIC_OFFSET_F1_1, "R200_PP_CUBIC_OFFSET_F1_1" },
421    { R200_PP_CUBIC_OFFSET_F2_1, "R200_PP_CUBIC_OFFSET_F2_1" },
422    { R200_PP_CUBIC_OFFSET_F3_1, "R200_PP_CUBIC_OFFSET_F3_1" },
423    { R200_PP_CUBIC_OFFSET_F4_1, "R200_PP_CUBIC_OFFSET_F4_1" },
424    { R200_PP_CUBIC_OFFSET_F5_1, "R200_PP_CUBIC_OFFSET_F5_1" },
425    { R200_PP_TXOFFSET_2, "R200_PP_TXOFFSET_2" },
426    { R200_PP_CUBIC_OFFSET_F1_2, "R200_PP_CUBIC_OFFSET_F1_2" },
427    { R200_PP_CUBIC_OFFSET_F2_2, "R200_PP_CUBIC_OFFSET_F2_2" },
428    { R200_PP_CUBIC_OFFSET_F3_2, "R200_PP_CUBIC_OFFSET_F3_2" },
429    { R200_PP_CUBIC_OFFSET_F4_2, "R200_PP_CUBIC_OFFSET_F4_2" },
430    { R200_PP_CUBIC_OFFSET_F5_2, "R200_PP_CUBIC_OFFSET_F5_2" },
431    { R200_PP_TXOFFSET_3, "R200_PP_TXOFFSET_3" },
432    { R200_PP_CUBIC_OFFSET_F1_3, "R200_PP_CUBIC_OFFSET_F1_3" },
433    { R200_PP_CUBIC_OFFSET_F2_3, "R200_PP_CUBIC_OFFSET_F2_3" },
434    { R200_PP_CUBIC_OFFSET_F3_3, "R200_PP_CUBIC_OFFSET_F3_3" },
435    { R200_PP_CUBIC_OFFSET_F4_3, "R200_PP_CUBIC_OFFSET_F4_3" },
436    { R200_PP_CUBIC_OFFSET_F5_3, "R200_PP_CUBIC_OFFSET_F5_3" },
437    { R200_PP_TXOFFSET_4, "R200_PP_TXOFFSET_4" },
438    { R200_PP_CUBIC_OFFSET_F1_4, "R200_PP_CUBIC_OFFSET_F1_4" },
439    { R200_PP_CUBIC_OFFSET_F2_4, "R200_PP_CUBIC_OFFSET_F2_4" },
440    { R200_PP_CUBIC_OFFSET_F3_4, "R200_PP_CUBIC_OFFSET_F3_4" },
441    { R200_PP_CUBIC_OFFSET_F4_4, "R200_PP_CUBIC_OFFSET_F4_4" },
442    { R200_PP_CUBIC_OFFSET_F5_4, "R200_PP_CUBIC_OFFSET_F5_4" },
443    { R200_PP_TXOFFSET_5, "R200_PP_TXOFFSET_5" },
444    { R200_PP_CUBIC_OFFSET_F1_5, "R200_PP_CUBIC_OFFSET_F1_5" },
445    { R200_PP_CUBIC_OFFSET_F2_5, "R200_PP_CUBIC_OFFSET_F2_5" },
446    { R200_PP_CUBIC_OFFSET_F3_5, "R200_PP_CUBIC_OFFSET_F3_5" },
447    { R200_PP_CUBIC_OFFSET_F4_5, "R200_PP_CUBIC_OFFSET_F4_5" },
448    { R200_PP_CUBIC_OFFSET_F5_5, "R200_PP_CUBIC_OFFSET_F5_5" },
449    { R200_PP_TAM_DEBUG3, "R200_PP_TAM_DEBUG3" },
450    { R200_PP_TFACTOR_0, "R200_PP_TFACTOR_0" },
451    { R200_PP_TFACTOR_1, "R200_PP_TFACTOR_1" },
452    { R200_PP_TFACTOR_2, "R200_PP_TFACTOR_2" },
453    { R200_PP_TFACTOR_3, "R200_PP_TFACTOR_3" },
454    { R200_PP_TFACTOR_4, "R200_PP_TFACTOR_4" },
455    { R200_PP_TFACTOR_5, "R200_PP_TFACTOR_5" },
456    { R200_PP_TFACTOR_6, "R200_PP_TFACTOR_6" },
457    { R200_PP_TFACTOR_7, "R200_PP_TFACTOR_7" },
458    { R200_PP_TXCBLEND_0, "R200_PP_TXCBLEND_0" },
459    { R200_PP_TXCBLEND2_0, "R200_PP_TXCBLEND2_0" },
460    { R200_PP_TXABLEND_0, "R200_PP_TXABLEND_0" },
461    { R200_PP_TXABLEND2_0, "R200_PP_TXABLEND2_0" },
462    { R200_PP_TXCBLEND_1, "R200_PP_TXCBLEND_1" },
463    { R200_PP_TXCBLEND2_1, "R200_PP_TXCBLEND2_1" },
464    { R200_PP_TXABLEND_1, "R200_PP_TXABLEND_1" },
465    { R200_PP_TXABLEND2_1, "R200_PP_TXABLEND2_1" },
466    { R200_PP_TXCBLEND_2, "R200_PP_TXCBLEND_2" },
467    { R200_PP_TXCBLEND2_2, "R200_PP_TXCBLEND2_2" },
468    { R200_PP_TXABLEND_2, "R200_PP_TXABLEND_2" },
469    { R200_PP_TXABLEND2_2, "R200_PP_TXABLEND2_2" },
470    { R200_PP_TXCBLEND_3, "R200_PP_TXCBLEND_3" },
471    { R200_PP_TXCBLEND2_3, "R200_PP_TXCBLEND2_3" },
472    { R200_PP_TXABLEND_3, "R200_PP_TXABLEND_3" },
473    { R200_PP_TXABLEND2_3, "R200_PP_TXABLEND2_3" },
474    { R200_PP_TXCBLEND_4, "R200_PP_TXCBLEND_4" },
475    { R200_PP_TXCBLEND2_4, "R200_PP_TXCBLEND2_4" },
476    { R200_PP_TXABLEND_4, "R200_PP_TXABLEND_4" },
477    { R200_PP_TXABLEND2_4, "R200_PP_TXABLEND2_4" },
478    { R200_PP_TXCBLEND_5, "R200_PP_TXCBLEND_5" },
479    { R200_PP_TXCBLEND2_5, "R200_PP_TXCBLEND2_5" },
480    { R200_PP_TXABLEND_5, "R200_PP_TXABLEND_5" },
481    { R200_PP_TXABLEND2_5, "R200_PP_TXABLEND2_5" },
482    { R200_PP_TXCBLEND_6, "R200_PP_TXCBLEND_6" },
483    { R200_PP_TXCBLEND2_6, "R200_PP_TXCBLEND2_6" },
484    { R200_PP_TXABLEND_6, "R200_PP_TXABLEND_6" },
485    { R200_PP_TXABLEND2_6, "R200_PP_TXABLEND2_6" },
486    { R200_PP_TXCBLEND_7, "R200_PP_TXCBLEND_7" },
487    { R200_PP_TXCBLEND2_7, "R200_PP_TXCBLEND2_7" },
488    { R200_PP_TXABLEND_7, "R200_PP_TXABLEND_7" },
489    { R200_PP_TXABLEND2_7, "R200_PP_TXABLEND2_7" },
490    { R200_RB3D_BLENDCOLOR, "R200_RB3D_BLENDCOLOR" },
491    { R200_RB3D_ABLENDCNTL, "R200_RB3D_ABLENDCNTL" },
492    { R200_RB3D_CBLENDCNTL, "R200_RB3D_CBLENDCNTL" },
493    { R200_SE_TCL_OUTPUT_VTX_COMP_SEL, "R200_SE_TCL_OUTPUT_VTX_COMP_SEL" },
494    { R200_PP_CNTL_X, "R200_PP_CNTL_X" },
495    { R200_SE_VAP_CNTL_STATUS, "R200_SE_VAP_CNTL_STATUS" },
496    { R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_0, "R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_0" },
497    { R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_1, "R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_1" },
498    { R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_2, "R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_2" },
499    { R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_3, "R200_SE_TCL_INPUT_VTX_VECTOR_ADDR_3" },
500    { R200_PP_TRI_PERF, "R200_PP_TRI_PERF" },
501    { R200_PP_PERF_CNTL, "R200_PP_PERF_CNTL" },
502    { R200_PP_TXCBLEND_8, "R200_PP_TXCBLEND_8" },
503    { R200_PP_TXCBLEND2_8, "R200_PP_TXCBLEND2_8" },
504    { R200_PP_TXABLEND_8, "R200_PP_TXABLEND_8" },
505    { R200_PP_TXABLEND2_8, "R200_PP_TXABLEND2_8" },
506    { R200_PP_TXCBLEND_9, "R200_PP_TXCBLEND_9" },
507    { R200_PP_TXCBLEND2_9, "R200_PP_TXCBLEND2_9" },
508    { R200_PP_TXABLEND_9, "R200_PP_TXABLEND_9" },
509    { R200_PP_TXABLEND2_9, "R200_PP_TXABLEND2_9" },
510    { R200_PP_TXCBLEND_10, "R200_PP_TXCBLEND_10" },
511    { R200_PP_TXCBLEND2_10, "R200_PP_TXCBLEND2_10" },
512    { R200_PP_TXABLEND_10, "R200_PP_TXABLEND_10" },
513    { R200_PP_TXABLEND2_10, "R200_PP_TXABLEND2_10" },
514    { R200_PP_TXCBLEND_11, "R200_PP_TXCBLEND_11" },
515    { R200_PP_TXCBLEND2_11, "R200_PP_TXCBLEND2_11" },
516    { R200_PP_TXABLEND_11, "R200_PP_TXABLEND_11" },
517    { R200_PP_TXABLEND2_11, "R200_PP_TXABLEND2_11" },
518    { R200_PP_TXCBLEND_12, "R200_PP_TXCBLEND_12" },
519    { R200_PP_TXCBLEND2_12, "R200_PP_TXCBLEND2_12" },
520    { R200_PP_TXABLEND_12, "R200_PP_TXABLEND_12" },
521    { R200_PP_TXABLEND2_12, "R200_PP_TXABLEND2_12" },
522    { R200_PP_TXCBLEND_13, "R200_PP_TXCBLEND_13" },
523    { R200_PP_TXCBLEND2_13, "R200_PP_TXCBLEND2_13" },
524    { R200_PP_TXABLEND_13, "R200_PP_TXABLEND_13" },
525    { R200_PP_TXABLEND2_13, "R200_PP_TXABLEND2_13" },
526    { R200_PP_TXCBLEND_14, "R200_PP_TXCBLEND_14" },
527    { R200_PP_TXCBLEND2_14, "R200_PP_TXCBLEND2_14" },
528    { R200_PP_TXABLEND_14, "R200_PP_TXABLEND_14" },
529    { R200_PP_TXABLEND2_14, "R200_PP_TXABLEND2_14" },
530    { R200_PP_TXCBLEND_15, "R200_PP_TXCBLEND_15" },
531    { R200_PP_TXCBLEND2_15, "R200_PP_TXCBLEND2_15" },
532    { R200_PP_TXABLEND_15, "R200_PP_TXABLEND_15" },
533    { R200_PP_TXABLEND2_15, "R200_PP_TXABLEND2_15" },
534    { R200_VAP_PVS_CNTL_1, "R200_VAP_PVS_CNTL_1" },
535    { R200_VAP_PVS_CNTL_2, "R200_VAP_PVS_CNTL_2" },
536 };
537 
538 static struct reg_names scalar_names[] = {
539    { R200_SS_LIGHT_DCD_ADDR, "R200_SS_LIGHT_DCD_ADDR" },
540    { R200_SS_LIGHT_DCM_ADDR, "R200_SS_LIGHT_DCM_ADDR" },
541    { R200_SS_LIGHT_SPOT_EXPONENT_ADDR, "R200_SS_LIGHT_SPOT_EXPONENT_ADDR" },
542    { R200_SS_LIGHT_SPOT_CUTOFF_ADDR, "R200_SS_LIGHT_SPOT_CUTOFF_ADDR" },
543    { R200_SS_LIGHT_SPECULAR_THRESH_ADDR, "R200_SS_LIGHT_SPECULAR_THRESH_ADDR" },
544    { R200_SS_LIGHT_RANGE_CUTOFF_SQRD, "R200_SS_LIGHT_RANGE_CUTOFF_SQRD" },
545    { R200_SS_LIGHT_RANGE_ATT_CONST, "R200_SS_LIGHT_RANGE_ATT_CONST" },
546    { R200_SS_VERT_GUARD_CLIP_ADJ_ADDR, "R200_SS_VERT_GUARD_CLIP_ADJ_ADDR" },
547    { R200_SS_VERT_GUARD_DISCARD_ADJ_ADDR, "R200_SS_VERT_GUARD_DISCARD_ADJ_ADDR" },
548    { R200_SS_HORZ_GUARD_CLIP_ADJ_ADDR, "R200_SS_HORZ_GUARD_CLIP_ADJ_ADDR" },
549    { R200_SS_HORZ_GUARD_DISCARD_ADJ_ADDR, "R200_SS_HORZ_GUARD_DISCARD_ADJ_ADDR" },
550    { R200_SS_MAT_0_SHININESS, "R200_SS_MAT_0_SHININESS" },
551    { R200_SS_MAT_1_SHININESS, "R200_SS_MAT_1_SHININESS" },
552    { 1000, "" },
553 };
554 
555 /* Puff these out to make them look like normal (dword) registers.
556  */
557 static struct reg_names vector_names[] = {
558    { 0, "start" },
559    { R200_VS_LIGHT_AMBIENT_ADDR, "R200_VS_LIGHT_AMBIENT_ADDR" },
560    { R200_VS_LIGHT_DIFFUSE_ADDR, "R200_VS_LIGHT_DIFFUSE_ADDR" },
561    { R200_VS_LIGHT_SPECULAR_ADDR, "R200_VS_LIGHT_SPECULAR_ADDR" },
562    { R200_VS_LIGHT_DIRPOS_ADDR, "R200_VS_LIGHT_DIRPOS_ADDR" },
563    { R200_VS_LIGHT_HWVSPOT_ADDR, "R200_VS_LIGHT_HWVSPOT_ADDR" },
564    { R200_VS_LIGHT_ATTENUATION_ADDR, "R200_VS_LIGHT_ATTENUATION_ADDR" },
565    { R200_VS_SPOT_DUAL_CONE, "R200_VS_SPOT_DUAL_CONE" },
566    { R200_VS_GLOBAL_AMBIENT_ADDR, "R200_VS_GLOBAL_AMBIENT_ADDR" },
567    { R200_VS_FOG_PARAM_ADDR, "R200_VS_FOG_PARAM_ADDR" },
568    { R200_VS_EYE_VECTOR_ADDR, "R200_VS_EYE_VECTOR_ADDR" },
569    { R200_VS_UCP_ADDR, "R200_VS_UCP_ADDR" },
570    { R200_VS_PNT_SPRITE_VPORT_SCALE, "R200_VS_PNT_SPRITE_VPORT_SCALE" },
571    { R200_VS_MATRIX_0_MV, "R200_VS_MATRIX_0_MV" },
572    { R200_VS_MATRIX_1_INV_MV, "R200_VS_MATRIX_1_INV_MV" },
573    { R200_VS_MATRIX_2_MVP, "R200_VS_MATRIX_2_MVP" },
574    { R200_VS_MATRIX_3_TEX0, "R200_VS_MATRIX_3_TEX0" },
575    { R200_VS_MATRIX_4_TEX1, "R200_VS_MATRIX_4_TEX1" },
576    { R200_VS_MATRIX_5_TEX2, "R200_VS_MATRIX_5_TEX2" },
577    { R200_VS_MATRIX_6_TEX3, "R200_VS_MATRIX_6_TEX3" },
578    { R200_VS_MATRIX_7_TEX4, "R200_VS_MATRIX_7_TEX4" },
579    { R200_VS_MATRIX_8_TEX5, "R200_VS_MATRIX_8_TEX5" },
580    { R200_VS_MAT_0_EMISS, "R200_VS_MAT_0_EMISS" },
581    { R200_VS_MAT_0_AMB, "R200_VS_MAT_0_AMB" },
582    { R200_VS_MAT_0_DIF, "R200_VS_MAT_0_DIF" },
583    { R200_VS_MAT_0_SPEC, "R200_VS_MAT_0_SPEC" },
584    { R200_VS_MAT_1_EMISS, "R200_VS_MAT_1_EMISS" },
585    { R200_VS_MAT_1_AMB, "R200_VS_MAT_1_AMB" },
586    { R200_VS_MAT_1_DIF, "R200_VS_MAT_1_DIF" },
587    { R200_VS_MAT_1_SPEC, "R200_VS_MAT_1_SPEC" },
588    { R200_VS_EYE2CLIP_MTX, "R200_VS_EYE2CLIP_MTX" },
589    { R200_VS_PNT_SPRITE_ATT_CONST, "R200_VS_PNT_SPRITE_ATT_CONST" },
590    { R200_VS_PNT_SPRITE_EYE_IN_MODEL, "R200_VS_PNT_SPRITE_EYE_IN_MODEL" },
591    { R200_VS_PNT_SPRITE_CLAMP, "R200_VS_PNT_SPRITE_CLAMP" },
592    { R200_VS_MAX, "R200_VS_MAX" },
593    { 1000, "" },
594 };
595 
596 #define ISVEC   1
597 #define ISFLOAT 2
598 #define TOUCHED 4
599 
600 struct reg {
601    int idx;
602    struct reg_names *closest;
603    int flags;
604    union fi current;
605    union fi *values;
606    int nvalues;
607    int nalloc;
608    float vmin, vmax;
609 };
610 
611 
612 static struct reg regs[ARRAY_SIZE(reg_names)+1];
613 static struct reg scalars[512+1];
614 static struct reg vectors[512*4+1];
615 
616 static int total, total_changed, bufs;
617 
init_regs(void)618 static void init_regs( void )
619 {
620    struct reg_names *tmp;
621    int i;
622 
623    for (i = 0 ; i < ARRAY_SIZE(reg_names) ; i++) {
624       regs[i].idx = reg_names[i].idx;
625       regs[i].closest = &reg_names[i];
626       regs[i].flags = 0;
627    }
628 
629    for (i = 0, tmp = scalar_names ; i < ARRAY_SIZE(scalars) ; i++) {
630       if (tmp[1].idx == i) tmp++;
631       scalars[i].idx = i;
632       scalars[i].closest = tmp;
633       scalars[i].flags = ISFLOAT;
634    }
635 
636    for (i = 0, tmp = vector_names ; i < ARRAY_SIZE(vectors) ; i++) {
637       if (tmp[1].idx*4 == i) tmp++;
638       vectors[i].idx = i;
639       vectors[i].closest = tmp;
640       vectors[i].flags = ISFLOAT|ISVEC;
641    }
642 
643    regs[ARRAY_SIZE(regs)-1].idx = -1;
644    scalars[ARRAY_SIZE(scalars)-1].idx = -1;
645    vectors[ARRAY_SIZE(vectors)-1].idx = -1;
646 }
647 
find_or_add_value(struct reg * reg,int val)648 static int find_or_add_value( struct reg *reg, int val )
649 {
650    int j;
651 
652    for ( j = 0 ; j < reg->nvalues ; j++)
653       if ( val == reg->values[j].i )
654 	 return 1;
655 
656    if (j == reg->nalloc) {
657       reg->nalloc += 5;
658       reg->nalloc *= 2;
659       reg->values = realloc( reg->values, reg->nalloc * sizeof(union fi) );
660    }
661 
662    reg->values[reg->nvalues++].i = val;
663    return 0;
664 }
665 
lookup_reg(struct reg * tab,int reg)666 static struct reg *lookup_reg( struct reg *tab, int reg )
667 {
668    int i;
669 
670    for (i = 0 ; tab[i].idx != -1 ; i++) {
671       if (tab[i].idx == reg)
672 	 return &tab[i];
673    }
674 
675    fprintf(stderr, "*** unknown reg 0x%x\n", reg);
676    return NULL;
677 }
678 
679 
get_reg_name(struct reg * reg)680 static const char *get_reg_name( struct reg *reg )
681 {
682    static char tmp[80];
683 
684    if (reg->idx == reg->closest->idx)
685       return reg->closest->name;
686 
687 
688    if (reg->flags & ISVEC) {
689       if (reg->idx/4 != reg->closest->idx)
690 	 sprintf(tmp, "%s+%d[%d]",
691 		 reg->closest->name,
692 		 (reg->idx/4) - reg->closest->idx,
693 		 reg->idx%4);
694       else
695 	 sprintf(tmp, "%s[%d]", reg->closest->name, reg->idx%4);
696    }
697    else {
698       if (reg->idx != reg->closest->idx)
699 	 sprintf(tmp, "%s+%d", reg->closest->name, reg->idx - reg->closest->idx);
700       else
701 	 sprintf(tmp, "%s", reg->closest->name);
702    }
703 
704    return tmp;
705 }
706 
print_int_reg_assignment(struct reg * reg,int data)707 static int print_int_reg_assignment( struct reg *reg, int data )
708 {
709    int changed = (reg->current.i != data);
710    int ever_seen = find_or_add_value( reg, data );
711 
712    if (VERBOSE || (NORMAL && (changed || !ever_seen)))
713        fprintf(stderr, "   %s <-- 0x%x", get_reg_name(reg), data);
714 
715    if (NORMAL) {
716       if (!ever_seen)
717 	 fprintf(stderr, " *** BRAND NEW VALUE");
718       else if (changed)
719 	 fprintf(stderr, " *** CHANGED");
720    }
721 
722    reg->current.i = data;
723 
724    if (VERBOSE || (NORMAL && (changed || !ever_seen)))
725       fprintf(stderr, "\n");
726 
727    return changed;
728 }
729 
730 
print_float_reg_assignment(struct reg * reg,float data)731 static int print_float_reg_assignment( struct reg *reg, float data )
732 {
733    int changed = (reg->current.f != data);
734    int newmin = (data < reg->vmin);
735    int newmax = (data > reg->vmax);
736 
737    if (VERBOSE || (NORMAL && (newmin || newmax || changed)))
738       fprintf(stderr, "   %s <-- %.3f", get_reg_name(reg), data);
739 
740    if (NORMAL) {
741       if (newmin) {
742 	 fprintf(stderr, " *** NEW MIN (prev %.3f)", reg->vmin);
743 	 reg->vmin = data;
744       }
745       else if (newmax) {
746 	 fprintf(stderr, " *** NEW MAX (prev %.3f)", reg->vmax);
747 	 reg->vmax = data;
748       }
749       else if (changed) {
750 	 fprintf(stderr, " *** CHANGED");
751       }
752    }
753 
754    reg->current.f = data;
755 
756    if (VERBOSE || (NORMAL && (newmin || newmax || changed)))
757       fprintf(stderr, "\n");
758 
759    return changed;
760 }
761 
print_reg_assignment(struct reg * reg,int data)762 static int print_reg_assignment( struct reg *reg, int data )
763 {
764    float_ui32_type datau;
765    datau.ui32 = data;
766    reg->flags |= TOUCHED;
767    if (reg->flags & ISFLOAT)
768       return print_float_reg_assignment( reg, datau.f );
769    else
770       return print_int_reg_assignment( reg, data );
771 }
772 
print_reg(struct reg * reg)773 static void print_reg( struct reg *reg )
774 {
775    if (reg->flags & TOUCHED) {
776       if (reg->flags & ISFLOAT) {
777 	 fprintf(stderr, "   %s == %f\n", get_reg_name(reg), reg->current.f);
778       } else {
779 	 fprintf(stderr, "   %s == 0x%x\n", get_reg_name(reg), reg->current.i);
780       }
781    }
782 }
783 
784 
dump_state(void)785 static void dump_state( void )
786 {
787    int i;
788 
789    for (i = 0 ; i < ARRAY_SIZE(regs) ; i++)
790       print_reg( &regs[i] );
791 
792    for (i = 0 ; i < ARRAY_SIZE(scalars) ; i++)
793       print_reg( &scalars[i] );
794 
795    for (i = 0 ; i < ARRAY_SIZE(vectors) ; i++)
796       print_reg( &vectors[i] );
797 }
798 
799 
800 
radeon_emit_packets(drm_radeon_cmd_header_t header,drm_radeon_cmd_buffer_t * cmdbuf)801 static int radeon_emit_packets(
802    drm_radeon_cmd_header_t header,
803    drm_radeon_cmd_buffer_t *cmdbuf )
804 {
805    int id = (int)header.packet.packet_id;
806    int sz = packet[id].len;
807    int *data = (int *)cmdbuf->buf;
808    int i;
809 
810    if (sz * sizeof(int) > cmdbuf->bufsz) {
811       fprintf(stderr, "Packet overflows cmdbuf\n");
812       return -EINVAL;
813    }
814 
815    if (!packet[id].name) {
816       fprintf(stderr, "*** Unknown packet 0 nr %d\n", id );
817       return -EINVAL;
818    }
819 
820 
821    if (VERBOSE)
822       fprintf(stderr, "Packet 0 reg %s nr %d\n", packet[id].name, sz );
823 
824    for ( i = 0 ; i < sz ; i++) {
825       struct reg *reg = lookup_reg( regs, packet[id].start + i*4 );
826       if (print_reg_assignment( reg, data[i] ))
827 	 total_changed++;
828       total++;
829    }
830 
831    cmdbuf->buf += sz * sizeof(int);
832    cmdbuf->bufsz -= sz * sizeof(int);
833    return 0;
834 }
835 
836 
radeon_emit_scalars(drm_radeon_cmd_header_t header,drm_radeon_cmd_buffer_t * cmdbuf)837 static int radeon_emit_scalars(
838    drm_radeon_cmd_header_t header,
839    drm_radeon_cmd_buffer_t *cmdbuf )
840 {
841    int sz = header.scalars.count;
842    int *data = (int *)cmdbuf->buf;
843    int start = header.scalars.offset;
844    int stride = header.scalars.stride;
845    int i;
846 
847    if (VERBOSE)
848       fprintf(stderr, "emit scalars, start %d stride %d nr %d (end %d)\n",
849 	      start, stride, sz, start + stride * sz);
850 
851 
852    for (i = 0 ; i < sz ; i++, start += stride) {
853       struct reg *reg = lookup_reg( scalars, start );
854       if (print_reg_assignment( reg, data[i] ))
855 	 total_changed++;
856       total++;
857    }
858 
859    cmdbuf->buf += sz * sizeof(int);
860    cmdbuf->bufsz -= sz * sizeof(int);
861    return 0;
862 }
863 
864 
radeon_emit_scalars2(drm_radeon_cmd_header_t header,drm_radeon_cmd_buffer_t * cmdbuf)865 static int radeon_emit_scalars2(
866    drm_radeon_cmd_header_t header,
867    drm_radeon_cmd_buffer_t *cmdbuf )
868 {
869    int sz = header.scalars.count;
870    int *data = (int *)cmdbuf->buf;
871    int start = header.scalars.offset + 0x100;
872    int stride = header.scalars.stride;
873    int i;
874 
875    if (VERBOSE)
876       fprintf(stderr, "emit scalars2, start %d stride %d nr %d (end %d)\n",
877 	      start, stride, sz, start + stride * sz);
878 
879    if (start + stride * sz > 258) {
880       fprintf(stderr, "emit scalars OVERFLOW %d/%d/%d\n", start, stride, sz);
881       return -1;
882    }
883 
884    for (i = 0 ; i < sz ; i++, start += stride) {
885       struct reg *reg = lookup_reg( scalars, start );
886       if (print_reg_assignment( reg, data[i] ))
887 	 total_changed++;
888       total++;
889    }
890 
891    cmdbuf->buf += sz * sizeof(int);
892    cmdbuf->bufsz -= sz * sizeof(int);
893    return 0;
894 }
895 
896 /* Check: inf/nan/extreme-size?
897  * Check: table start, end, nr, etc.
898  */
radeon_emit_vectors(drm_radeon_cmd_header_t header,drm_radeon_cmd_buffer_t * cmdbuf)899 static int radeon_emit_vectors(
900    drm_radeon_cmd_header_t header,
901    drm_radeon_cmd_buffer_t *cmdbuf )
902 {
903    int sz = header.vectors.count;
904    int *data = (int *)cmdbuf->buf;
905    int start = header.vectors.offset;
906    int stride = header.vectors.stride;
907    int i,j;
908 
909    if (VERBOSE)
910       fprintf(stderr, "emit vectors, start %d stride %d nr %d (end %d) (0x%x)\n",
911 	      start, stride, sz, start + stride * sz, header.i);
912 
913 /*    if (start + stride * (sz/4) > 128) { */
914 /*       fprintf(stderr, "emit vectors OVERFLOW %d/%d/%d\n", start, stride, sz); */
915 /*       return -1; */
916 /*    } */
917 
918    for (i = 0 ; i < sz ;  start += stride) {
919       int changed = 0;
920       for (j = 0 ; j < 4 ; i++,j++) {
921 	 struct reg *reg = lookup_reg( vectors, start*4+j );
922 	 if (print_reg_assignment( reg, data[i] ))
923 	    changed = 1;
924       }
925       if (changed)
926 	 total_changed += 4;
927       total += 4;
928    }
929 
930 
931    cmdbuf->buf += sz * sizeof(int);
932    cmdbuf->bufsz -= sz * sizeof(int);
933    return 0;
934 }
935 
radeon_emit_veclinear(drm_radeon_cmd_header_t header,drm_radeon_cmd_buffer_t * cmdbuf)936 static int radeon_emit_veclinear(
937    drm_radeon_cmd_header_t header,
938    drm_radeon_cmd_buffer_t *cmdbuf )
939 {
940    int sz = header.veclinear.count * 4;
941    int *data = (int *)cmdbuf->buf;
942    float *fdata =(float *)cmdbuf->buf;
943    int start = header.veclinear.addr_lo | (header.veclinear.addr_hi << 8);
944    int i;
945 
946    if (1||VERBOSE)
947       fprintf(stderr, "emit vectors linear, start %d nr %d (end %d) (0x%x)\n",
948 	      start, sz >> 2, start + (sz >> 2), header.i);
949 
950 
951    if (start < 0x60) {
952       for (i = 0 ; i < sz ;  i += 4) {
953 	 fprintf(stderr, "R200_VS_PARAM %d 0 %f\n", (i >> 2) + start, fdata[i]);
954 	 fprintf(stderr, "R200_VS_PARAM %d 1 %f\n", (i >> 2) + start, fdata[i+1]);
955 	 fprintf(stderr, "R200_VS_PARAM %d 2 %f\n", (i >> 2) + start, fdata[i+2]);
956 	 fprintf(stderr, "R200_VS_PARAM %d 3 %f\n", (i >> 2) + start, fdata[i+3]);
957       }
958    }
959    else if ((start >= 0x100) && (start < 0x160)) {
960       for (i = 0 ; i < sz ;  i += 4) {
961 	 fprintf(stderr, "R200_VS_PARAM %d 0 %f\n", (i >> 2) + start - 0x100 + 0x60, fdata[i]);
962 	 fprintf(stderr, "R200_VS_PARAM %d 1 %f\n", (i >> 2) + start - 0x100 + 0x60, fdata[i+1]);
963 	 fprintf(stderr, "R200_VS_PARAM %d 2 %f\n", (i >> 2) + start - 0x100 + 0x60, fdata[i+2]);
964 	 fprintf(stderr, "R200_VS_PARAM %d 3 %f\n", (i >> 2) + start - 0x100 + 0x60, fdata[i+3]);
965       }
966    }
967    else if ((start >= 0x80) && (start < 0xc0)) {
968       for (i = 0 ; i < sz ;  i += 4) {
969 	 fprintf(stderr, "R200_VS_PROG %d OPDST %08x\n", (i >> 2) + start - 0x80, data[i]);
970 	 fprintf(stderr, "R200_VS_PROG %d SRC1  %08x\n", (i >> 2) + start - 0x80, data[i+1]);
971 	 fprintf(stderr, "R200_VS_PROG %d SRC2  %08x\n", (i >> 2) + start - 0x80, data[i+2]);
972 	 fprintf(stderr, "R200_VS_PROG %d SRC3  %08x\n", (i >> 2) + start - 0x80, data[i+3]);
973       }
974    }
975    else if ((start >= 0x180) && (start < 0x1c0)) {
976       for (i = 0 ; i < sz ;  i += 4) {
977 	 fprintf(stderr, "R200_VS_PROG %d OPDST %08x\n", (i >> 2) + start - 0x180 + 0x40, data[i]);
978 	 fprintf(stderr, "R200_VS_PROG %d SRC1  %08x\n", (i >> 2) + start - 0x180 + 0x40, data[i+1]);
979 	 fprintf(stderr, "R200_VS_PROG %d SRC2  %08x\n", (i >> 2) + start - 0x180 + 0x40, data[i+2]);
980 	 fprintf(stderr, "R200_VS_PROG %d SRC3  %08x\n", (i >> 2) + start - 0x180 + 0x40, data[i+3]);
981       }
982    }
983    else {
984       fprintf(stderr, "write to unknown vector area\n");
985    }
986 
987    cmdbuf->buf += sz * sizeof(int);
988    cmdbuf->bufsz -= sz * sizeof(int);
989    return 0;
990 }
991 
992 #if 0
993 static int print_vertex_format( int vfmt )
994 {
995    if (NORMAL) {
996       fprintf(stderr, "   %s(%x): %s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s",
997 	      "vertex format",
998 	      vfmt,
999 	      "xy,",
1000 	      (vfmt & R200_VTX_Z0) ? "z," : "",
1001 	      (vfmt & R200_VTX_W0) ? "w0," : "",
1002 	      (vfmt & R200_VTX_FPCOLOR) ? "fpcolor," : "",
1003 	      (vfmt & R200_VTX_FPALPHA) ? "fpalpha," : "",
1004 	      (vfmt & R200_VTX_PKCOLOR) ? "pkcolor," : "",
1005 	      (vfmt & R200_VTX_FPSPEC) ? "fpspec," : "",
1006 	      (vfmt & R200_VTX_FPFOG) ? "fpfog," : "",
1007 	      (vfmt & R200_VTX_PKSPEC) ? "pkspec," : "",
1008 	      (vfmt & R200_VTX_ST0) ? "st0," : "",
1009 	      (vfmt & R200_VTX_ST1) ? "st1," : "",
1010 	      (vfmt & R200_VTX_Q1) ? "q1," : "",
1011 	      (vfmt & R200_VTX_ST2) ? "st2," : "",
1012 	      (vfmt & R200_VTX_Q2) ? "q2," : "",
1013 	      (vfmt & R200_VTX_ST3) ? "st3," : "",
1014 	      (vfmt & R200_VTX_Q3) ? "q3," : "",
1015 	      (vfmt & R200_VTX_Q0) ? "q0," : "",
1016 	      (vfmt & R200_VTX_N0) ? "n0," : "",
1017 	      (vfmt & R200_VTX_XY1) ? "xy1," : "",
1018 	      (vfmt & R200_VTX_Z1) ? "z1," : "",
1019 	      (vfmt & R200_VTX_W1) ? "w1," : "",
1020 	      (vfmt & R200_VTX_N1) ? "n1," : "");
1021 
1022 
1023       if (!find_or_add_value( &others[V_VTXFMT], vfmt ))
1024 	 fprintf(stderr, " *** NEW VALUE");
1025 
1026       fprintf(stderr, "\n");
1027    }
1028 
1029    return 0;
1030 }
1031 #endif
1032 
1033 static char *primname[0x10] = {
1034    "NONE",
1035    "POINTS",
1036    "LINES",
1037    "LINE_STRIP",
1038    "TRIANGLES",
1039    "TRIANGLE_FAN",
1040    "TRIANGLE_STRIP",
1041    "RECT_LIST",
1042    NULL,
1043    "3VRT_POINTS",
1044    "3VRT_LINES",
1045    "POINT_SPRITES",
1046    "LINE_LOOP",
1047    "QUADS",
1048    "QUAD_STRIP",
1049    "POLYGON",
1050 };
1051 
print_prim_and_flags(int prim)1052 static int print_prim_and_flags( int prim )
1053 {
1054    int numverts;
1055 
1056    if (NORMAL)
1057       fprintf(stderr, "   %s(%x): %s%s%s%s%s%s\n",
1058 	      "prim flags",
1059 	      prim,
1060 	      ((prim & 0x30) == R200_VF_PRIM_WALK_IND) ? "IND," : "",
1061 	      ((prim & 0x30) == R200_VF_PRIM_WALK_LIST) ? "LIST," : "",
1062 	      ((prim & 0x30) == R200_VF_PRIM_WALK_RING) ? "RING," : "",
1063 	      (prim & R200_VF_COLOR_ORDER_RGBA) ? "RGBA," : "BGRA, ",
1064 	      (prim & R200_VF_INDEX_SZ_4) ? "INDX-32," : "",
1065 	      (prim & R200_VF_TCL_OUTPUT_VTX_ENABLE) ? "TCL_OUT_VTX," : "");
1066 
1067    numverts = prim>>16;
1068 
1069    if (NORMAL)
1070       fprintf(stderr, "   prim: %s numverts %d\n", primname[prim&0xf], numverts);
1071 
1072    switch (prim & 0xf) {
1073    case R200_VF_PRIM_NONE:
1074    case R200_VF_PRIM_POINTS:
1075       if (numverts < 1) {
1076 	 fprintf(stderr, "Bad nr verts for line %d\n", numverts);
1077 	 return -1;
1078       }
1079       break;
1080    case R200_VF_PRIM_LINES:
1081    case R200_VF_PRIM_POINT_SPRITES:
1082       if ((numverts & 1) || numverts == 0) {
1083 	 fprintf(stderr, "Bad nr verts for line %d\n", numverts);
1084 	 return -1;
1085       }
1086       break;
1087    case R200_VF_PRIM_LINE_STRIP:
1088    case R200_VF_PRIM_LINE_LOOP:
1089       if (numverts < 2) {
1090 	 fprintf(stderr, "Bad nr verts for line_strip %d\n", numverts);
1091 	 return -1;
1092       }
1093       break;
1094    case R200_VF_PRIM_TRIANGLES:
1095    case R200_VF_PRIM_3VRT_POINTS:
1096    case R200_VF_PRIM_3VRT_LINES:
1097    case R200_VF_PRIM_RECT_LIST:
1098       if (numverts % 3 || numverts == 0) {
1099 	 fprintf(stderr, "Bad nr verts for tri %d\n", numverts);
1100 	 return -1;
1101       }
1102       break;
1103    case R200_VF_PRIM_TRIANGLE_FAN:
1104    case R200_VF_PRIM_TRIANGLE_STRIP:
1105    case R200_VF_PRIM_POLYGON:
1106       if (numverts < 3) {
1107 	 fprintf(stderr, "Bad nr verts for strip/fan %d\n", numverts);
1108 	 return -1;
1109       }
1110       break;
1111    case R200_VF_PRIM_QUADS:
1112       if (numverts % 4 || numverts == 0) {
1113 	 fprintf(stderr, "Bad nr verts for quad %d\n", numverts);
1114 	 return -1;
1115       }
1116       break;
1117    case R200_VF_PRIM_QUAD_STRIP:
1118       if (numverts % 2 || numverts < 4) {
1119 	 fprintf(stderr, "Bad nr verts for quadstrip %d\n", numverts);
1120 	 return -1;
1121       }
1122       break;
1123    default:
1124       fprintf(stderr, "Bad primitive\n");
1125       return -1;
1126    }
1127    return 0;
1128 }
1129 
1130 /* build in knowledge about each packet type
1131  */
radeon_emit_packet3(drm_radeon_cmd_buffer_t * cmdbuf)1132 static int radeon_emit_packet3( drm_radeon_cmd_buffer_t *cmdbuf )
1133 {
1134    int cmdsz;
1135    int *cmd = (int *)cmdbuf->buf;
1136    int *tmp;
1137    int i, stride, size, start;
1138 
1139    cmdsz = 2 + ((cmd[0] & RADEON_CP_PACKET_COUNT_MASK) >> 16);
1140 
1141    if ((cmd[0] & RADEON_CP_PACKET_MASK) != RADEON_CP_PACKET3 ||
1142        cmdsz * 4 > cmdbuf->bufsz ||
1143        cmdsz > RADEON_CP_PACKET_MAX_DWORDS) {
1144       fprintf(stderr, "Bad packet\n");
1145       return -EINVAL;
1146    }
1147 
1148    switch( cmd[0] & ~RADEON_CP_PACKET_COUNT_MASK ) {
1149    case R200_CP_CMD_NOP:
1150       if (NORMAL)
1151 	 fprintf(stderr, "PACKET3_NOP, %d dwords\n", cmdsz);
1152       break;
1153    case R200_CP_CMD_NEXT_CHAR:
1154       if (NORMAL)
1155 	 fprintf(stderr, "PACKET3_NEXT_CHAR, %d dwords\n", cmdsz);
1156       break;
1157    case R200_CP_CMD_PLY_NEXTSCAN:
1158       if (NORMAL)
1159 	 fprintf(stderr, "PACKET3_PLY_NEXTSCAN, %d dwords\n", cmdsz);
1160       break;
1161    case R200_CP_CMD_SET_SCISSORS:
1162       if (NORMAL)
1163 	 fprintf(stderr, "PACKET3_SET_SCISSORS, %d dwords\n", cmdsz);
1164       break;
1165    case R200_CP_CMD_LOAD_MICROCODE:
1166       if (NORMAL)
1167 	 fprintf(stderr, "PACKET3_LOAD_MICROCODE, %d dwords\n", cmdsz);
1168       break;
1169    case R200_CP_CMD_WAIT_FOR_IDLE:
1170       if (NORMAL)
1171 	 fprintf(stderr, "PACKET3_WAIT_FOR_IDLE, %d dwords\n", cmdsz);
1172       break;
1173 
1174    case R200_CP_CMD_3D_DRAW_VBUF:
1175       if (NORMAL)
1176 	 fprintf(stderr, "PACKET3_3D_DRAW_VBUF, %d dwords\n", cmdsz);
1177 /*       print_vertex_format(cmd[1]); */
1178       if (print_prim_and_flags(cmd[2]))
1179 	 return -EINVAL;
1180       break;
1181 
1182    case R200_CP_CMD_3D_DRAW_IMMD:
1183       if (NORMAL)
1184 	 fprintf(stderr, "PACKET3_3D_DRAW_IMMD, %d dwords\n", cmdsz);
1185       break;
1186    case R200_CP_CMD_3D_DRAW_INDX: {
1187       int neltdwords;
1188       if (NORMAL)
1189 	 fprintf(stderr, "PACKET3_3D_DRAW_INDX, %d dwords\n", cmdsz);
1190 /*       print_vertex_format(cmd[1]); */
1191       if (print_prim_and_flags(cmd[2]))
1192 	 return -EINVAL;
1193       neltdwords = cmd[2]>>16;
1194       neltdwords += neltdwords & 1;
1195       neltdwords /= 2;
1196       if (neltdwords + 3 != cmdsz)
1197 	 fprintf(stderr, "Mismatch in DRAW_INDX, %d vs cmdsz %d\n",
1198 		 neltdwords, cmdsz);
1199       break;
1200    }
1201    case R200_CP_CMD_LOAD_PALETTE:
1202       if (NORMAL)
1203 	 fprintf(stderr, "PACKET3_LOAD_PALETTE, %d dwords\n", cmdsz);
1204       break;
1205    case R200_CP_CMD_3D_LOAD_VBPNTR:
1206       if (NORMAL) {
1207 	 fprintf(stderr, "PACKET3_3D_LOAD_VBPNTR, %d dwords\n", cmdsz);
1208 	 fprintf(stderr, "   nr arrays: %d\n", cmd[1]);
1209       }
1210 
1211       if (((cmd[1]/2)*3) + ((cmd[1]%2)*2) != cmdsz - 2) {
1212 	 fprintf(stderr, "  ****** MISMATCH %d/%d *******\n",
1213 		 ((cmd[1]/2)*3) + ((cmd[1]%2)*2) + 2, cmdsz);
1214 	 return -EINVAL;
1215       }
1216 
1217       if (NORMAL) {
1218 	 tmp = cmd+2;
1219 	 for (i = 0 ; i < cmd[1] ; i++) {
1220 	    if (i & 1) {
1221 	       stride = (tmp[0]>>24) & 0xff;
1222 	       size = (tmp[0]>>16) & 0xff;
1223 	       start = tmp[2];
1224 	       tmp += 3;
1225 	    }
1226 	    else {
1227 	       stride = (tmp[0]>>8) & 0xff;
1228 	       size = (tmp[0]) & 0xff;
1229 	       start = tmp[1];
1230 	    }
1231 	    fprintf(stderr, "   array %d: start 0x%x vsize %d vstride %d\n",
1232 		    i, start, size, stride );
1233 	 }
1234       }
1235       break;
1236    case R200_CP_CMD_PAINT:
1237       if (NORMAL)
1238 	 fprintf(stderr, "PACKET3_CNTL_PAINT, %d dwords\n", cmdsz);
1239       break;
1240    case R200_CP_CMD_BITBLT:
1241       if (NORMAL)
1242 	 fprintf(stderr, "PACKET3_CNTL_BITBLT, %d dwords\n", cmdsz);
1243       break;
1244    case R200_CP_CMD_SMALLTEXT:
1245       if (NORMAL)
1246 	 fprintf(stderr, "PACKET3_CNTL_SMALLTEXT, %d dwords\n", cmdsz);
1247       break;
1248    case R200_CP_CMD_HOSTDATA_BLT:
1249       if (NORMAL)
1250 	 fprintf(stderr, "PACKET3_CNTL_HOSTDATA_BLT, %d dwords\n",
1251 	      cmdsz);
1252       break;
1253    case R200_CP_CMD_POLYLINE:
1254       if (NORMAL)
1255 	 fprintf(stderr, "PACKET3_CNTL_POLYLINE, %d dwords\n", cmdsz);
1256       break;
1257    case R200_CP_CMD_POLYSCANLINES:
1258       if (NORMAL)
1259 	 fprintf(stderr, "PACKET3_CNTL_POLYSCANLINES, %d dwords\n",
1260 	      cmdsz);
1261       break;
1262    case R200_CP_CMD_PAINT_MULTI:
1263       if (NORMAL)
1264 	 fprintf(stderr, "PACKET3_CNTL_PAINT_MULTI, %d dwords\n",
1265 	      cmdsz);
1266       break;
1267    case R200_CP_CMD_BITBLT_MULTI:
1268       if (NORMAL)
1269 	 fprintf(stderr, "PACKET3_CNTL_BITBLT_MULTI, %d dwords\n",
1270 	      cmdsz);
1271       break;
1272    case R200_CP_CMD_TRANS_BITBLT:
1273       if (NORMAL)
1274 	 fprintf(stderr, "PACKET3_CNTL_TRANS_BITBLT, %d dwords\n",
1275 	      cmdsz);
1276       break;
1277    case R200_CP_CMD_3D_DRAW_VBUF_2:
1278       if (NORMAL)
1279 	 fprintf(stderr, "R200_CP_CMD_3D_DRAW_VBUF_2, %d dwords\n",
1280 	      cmdsz);
1281       if (print_prim_and_flags(cmd[1]))
1282 	 return -EINVAL;
1283       break;
1284    case R200_CP_CMD_3D_DRAW_IMMD_2:
1285       if (NORMAL)
1286 	 fprintf(stderr, "R200_CP_CMD_3D_DRAW_IMMD_2, %d dwords\n",
1287 	      cmdsz);
1288       if (print_prim_and_flags(cmd[1]))
1289 	 return -EINVAL;
1290       break;
1291    case R200_CP_CMD_3D_DRAW_INDX_2:
1292       if (NORMAL)
1293 	 fprintf(stderr, "R200_CP_CMD_3D_DRAW_INDX_2, %d dwords\n",
1294 	      cmdsz);
1295       if (print_prim_and_flags(cmd[1]))
1296 	 return -EINVAL;
1297       break;
1298    default:
1299       fprintf(stderr, "UNKNOWN PACKET, %d dwords\n", cmdsz);
1300       break;
1301    }
1302 
1303    cmdbuf->buf += cmdsz * 4;
1304    cmdbuf->bufsz -= cmdsz * 4;
1305    return 0;
1306 }
1307 
1308 
1309 /* Check cliprects for bounds, then pass on to above:
1310  */
radeon_emit_packet3_cliprect(drm_radeon_cmd_buffer_t * cmdbuf)1311 static int radeon_emit_packet3_cliprect( drm_radeon_cmd_buffer_t *cmdbuf )
1312 {
1313    drm_clip_rect_t *boxes = (drm_clip_rect_t *)cmdbuf->boxes;
1314    int i = 0;
1315 
1316    if (VERBOSE && total_changed) {
1317       dump_state();
1318       total_changed = 0;
1319    }
1320 
1321    if (NORMAL) {
1322       do {
1323 	 if ( i < cmdbuf->nbox ) {
1324 	    fprintf(stderr, "Emit box %d/%d %d,%d %d,%d\n",
1325 		    i, cmdbuf->nbox,
1326 		    boxes[i].x1, boxes[i].y1, boxes[i].x2, boxes[i].y2);
1327 	 }
1328       } while ( ++i < cmdbuf->nbox );
1329    }
1330 
1331    if (cmdbuf->nbox == 1)
1332       cmdbuf->nbox = 0;
1333 
1334    return radeon_emit_packet3( cmdbuf );
1335 }
1336 
1337 
r200SanityCmdBuffer(r200ContextPtr rmesa,int nbox,drm_clip_rect_t * boxes)1338 int r200SanityCmdBuffer( r200ContextPtr rmesa,
1339 			   int nbox,
1340 			   drm_clip_rect_t *boxes )
1341 {
1342    int idx;
1343    drm_radeon_cmd_buffer_t cmdbuf;
1344    drm_radeon_cmd_header_t header;
1345    static int inited = 0;
1346 
1347    if (!inited) {
1348       init_regs();
1349       inited = 1;
1350    }
1351 
1352 
1353    cmdbuf.buf = rmesa->store.cmd_buf;
1354    cmdbuf.bufsz = rmesa->store.cmd_used;
1355    cmdbuf.boxes = (drm_clip_rect_t *)boxes;
1356    cmdbuf.nbox = nbox;
1357 
1358    while ( cmdbuf.bufsz >= sizeof(header) ) {
1359 
1360       header.i = *(int *)cmdbuf.buf;
1361       cmdbuf.buf += sizeof(header);
1362       cmdbuf.bufsz -= sizeof(header);
1363 
1364       switch (header.header.cmd_type) {
1365       case RADEON_CMD_PACKET:
1366 	 if (radeon_emit_packets( header, &cmdbuf )) {
1367 	    fprintf(stderr,"radeon_emit_packets failed\n");
1368 	    return -EINVAL;
1369 	 }
1370 	 break;
1371 
1372       case RADEON_CMD_SCALARS:
1373 	 if (radeon_emit_scalars( header, &cmdbuf )) {
1374 	    fprintf(stderr,"radeon_emit_scalars failed\n");
1375 	    return -EINVAL;
1376 	 }
1377 	 break;
1378 
1379       case RADEON_CMD_SCALARS2:
1380 	 if (radeon_emit_scalars2( header, &cmdbuf )) {
1381 	    fprintf(stderr,"radeon_emit_scalars failed\n");
1382 	    return -EINVAL;
1383 	 }
1384 	 break;
1385 
1386       case RADEON_CMD_VECTORS:
1387 	 if (radeon_emit_vectors( header, &cmdbuf )) {
1388 	    fprintf(stderr,"radeon_emit_vectors failed\n");
1389 	    return -EINVAL;
1390 	 }
1391 	 break;
1392 
1393       case RADEON_CMD_DMA_DISCARD:
1394 	 idx = header.dma.buf_idx;
1395 	 if (NORMAL)
1396 	    fprintf(stderr, "RADEON_CMD_DMA_DISCARD buf %d\n", idx);
1397 	 bufs++;
1398 	 break;
1399 
1400       case RADEON_CMD_PACKET3:
1401 	 if (radeon_emit_packet3( &cmdbuf )) {
1402 	    fprintf(stderr,"radeon_emit_packet3 failed\n");
1403 	    return -EINVAL;
1404 	 }
1405 	 break;
1406 
1407       case RADEON_CMD_PACKET3_CLIP:
1408 	 if (radeon_emit_packet3_cliprect( &cmdbuf )) {
1409 	    fprintf(stderr,"radeon_emit_packet3_clip failed\n");
1410 	    return -EINVAL;
1411 	 }
1412 	 break;
1413 
1414       case RADEON_CMD_WAIT:
1415 	 break;
1416 
1417       case RADEON_CMD_VECLINEAR:
1418 	 if (radeon_emit_veclinear( header, &cmdbuf )) {
1419 	    fprintf(stderr,"radeon_emit_veclinear failed\n");
1420 	    return -EINVAL;
1421 	 }
1422 	 break;
1423 
1424       default:
1425 	 fprintf(stderr,"bad cmd_type %d at %p\n",
1426 		   header.header.cmd_type,
1427 		   cmdbuf.buf - sizeof(header));
1428 	 return -EINVAL;
1429       }
1430    }
1431 
1432    if (0)
1433    {
1434       static int n = 0;
1435       n++;
1436       if (n == 10) {
1437 	 fprintf(stderr, "Bufs %d Total emitted %d real changes %d (%.2f%%)\n",
1438 		 bufs,
1439 		 total, total_changed,
1440 		 ((float)total_changed/(float)total*100.0));
1441 	 fprintf(stderr, "Total emitted per buf: %.2f\n",
1442 		 (float)total/(float)bufs);
1443 	 fprintf(stderr, "Real changes per buf: %.2f\n",
1444 		 (float)total_changed/(float)bufs);
1445 
1446 	 bufs = n = total = total_changed = 0;
1447       }
1448    }
1449 
1450    fprintf(stderr, "leaving %s\n\n\n", __func__);
1451 
1452    return 0;
1453 }
1454