a439fd84ed5675404cc74b1ba68a9a27c025d673
[mesa.git] / src / mesa / drivers / dri / r200 / r200_sanity.c
1 /**************************************************************************
2
3 Copyright 2002 ATI Technologies Inc., Ontario, Canada, and
4 Tungsten Graphics Inc, Cedar Park, TX.
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, TUNGSTEN GRAPHICS 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 <keith@tungstengraphics.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 union fi { float f; int i; };
597
598 #define ISVEC 1
599 #define ISFLOAT 2
600 #define TOUCHED 4
601
602 struct reg {
603 int idx;
604 struct reg_names *closest;
605 int flags;
606 union fi current;
607 union fi *values;
608 int nvalues;
609 int nalloc;
610 float vmin, vmax;
611 };
612
613
614 static struct reg regs[Elements(reg_names)+1];
615 static struct reg scalars[512+1];
616 static struct reg vectors[512*4+1];
617
618 static int total, total_changed, bufs;
619
620 static void init_regs( void )
621 {
622 struct reg_names *tmp;
623 int i;
624
625 for (i = 0 ; i < Elements(regs) ; i++) {
626 regs[i].idx = reg_names[i].idx;
627 regs[i].closest = &reg_names[i];
628 regs[i].flags = 0;
629 }
630
631 for (i = 0, tmp = scalar_names ; i < Elements(scalars) ; i++) {
632 if (tmp[1].idx == i) tmp++;
633 scalars[i].idx = i;
634 scalars[i].closest = tmp;
635 scalars[i].flags = ISFLOAT;
636 }
637
638 for (i = 0, tmp = vector_names ; i < Elements(vectors) ; i++) {
639 if (tmp[1].idx*4 == i) tmp++;
640 vectors[i].idx = i;
641 vectors[i].closest = tmp;
642 vectors[i].flags = ISFLOAT|ISVEC;
643 }
644
645 regs[Elements(regs)-1].idx = -1;
646 scalars[Elements(scalars)-1].idx = -1;
647 vectors[Elements(vectors)-1].idx = -1;
648 }
649
650 static int find_or_add_value( struct reg *reg, int val )
651 {
652 int j;
653
654 for ( j = 0 ; j < reg->nvalues ; j++)
655 if ( val == reg->values[j].i )
656 return 1;
657
658 if (j == reg->nalloc) {
659 reg->nalloc += 5;
660 reg->nalloc *= 2;
661 reg->values = (union fi *) realloc( reg->values,
662 reg->nalloc * sizeof(union fi) );
663 }
664
665 reg->values[reg->nvalues++].i = val;
666 return 0;
667 }
668
669 static struct reg *lookup_reg( struct reg *tab, int reg )
670 {
671 int i;
672
673 for (i = 0 ; tab[i].idx != -1 ; i++) {
674 if (tab[i].idx == reg)
675 return &tab[i];
676 }
677
678 fprintf(stderr, "*** unknown reg 0x%x\n", reg);
679 return NULL;
680 }
681
682
683 static const char *get_reg_name( struct reg *reg )
684 {
685 static char tmp[80];
686
687 if (reg->idx == reg->closest->idx)
688 return reg->closest->name;
689
690
691 if (reg->flags & ISVEC) {
692 if (reg->idx/4 != reg->closest->idx)
693 sprintf(tmp, "%s+%d[%d]",
694 reg->closest->name,
695 (reg->idx/4) - reg->closest->idx,
696 reg->idx%4);
697 else
698 sprintf(tmp, "%s[%d]", reg->closest->name, reg->idx%4);
699 }
700 else {
701 if (reg->idx != reg->closest->idx)
702 sprintf(tmp, "%s+%d", reg->closest->name, reg->idx - reg->closest->idx);
703 else
704 sprintf(tmp, "%s", reg->closest->name);
705 }
706
707 return tmp;
708 }
709
710 static int print_int_reg_assignment( struct reg *reg, int data )
711 {
712 int changed = (reg->current.i != data);
713 int ever_seen = find_or_add_value( reg, data );
714
715 if (VERBOSE || (NORMAL && (changed || !ever_seen)))
716 fprintf(stderr, " %s <-- 0x%x", get_reg_name(reg), data);
717
718 if (NORMAL) {
719 if (!ever_seen)
720 fprintf(stderr, " *** BRAND NEW VALUE");
721 else if (changed)
722 fprintf(stderr, " *** CHANGED");
723 }
724
725 reg->current.i = data;
726
727 if (VERBOSE || (NORMAL && (changed || !ever_seen)))
728 fprintf(stderr, "\n");
729
730 return changed;
731 }
732
733
734 static int print_float_reg_assignment( struct reg *reg, float data )
735 {
736 int changed = (reg->current.f != data);
737 int newmin = (data < reg->vmin);
738 int newmax = (data > reg->vmax);
739
740 if (VERBOSE || (NORMAL && (newmin || newmax || changed)))
741 fprintf(stderr, " %s <-- %.3f", get_reg_name(reg), data);
742
743 if (NORMAL) {
744 if (newmin) {
745 fprintf(stderr, " *** NEW MIN (prev %.3f)", reg->vmin);
746 reg->vmin = data;
747 }
748 else if (newmax) {
749 fprintf(stderr, " *** NEW MAX (prev %.3f)", reg->vmax);
750 reg->vmax = data;
751 }
752 else if (changed) {
753 fprintf(stderr, " *** CHANGED");
754 }
755 }
756
757 reg->current.f = data;
758
759 if (VERBOSE || (NORMAL && (newmin || newmax || changed)))
760 fprintf(stderr, "\n");
761
762 return changed;
763 }
764
765 static int print_reg_assignment( struct reg *reg, int data )
766 {
767 float_ui32_type datau;
768 datau.ui32 = data;
769 reg->flags |= TOUCHED;
770 if (reg->flags & ISFLOAT)
771 return print_float_reg_assignment( reg, datau.f );
772 else
773 return print_int_reg_assignment( reg, data );
774 }
775
776 static void print_reg( struct reg *reg )
777 {
778 if (reg->flags & TOUCHED) {
779 if (reg->flags & ISFLOAT) {
780 fprintf(stderr, " %s == %f\n", get_reg_name(reg), reg->current.f);
781 } else {
782 fprintf(stderr, " %s == 0x%x\n", get_reg_name(reg), reg->current.i);
783 }
784 }
785 }
786
787
788 static void dump_state( void )
789 {
790 int i;
791
792 for (i = 0 ; i < Elements(regs) ; i++)
793 print_reg( &regs[i] );
794
795 for (i = 0 ; i < Elements(scalars) ; i++)
796 print_reg( &scalars[i] );
797
798 for (i = 0 ; i < Elements(vectors) ; i++)
799 print_reg( &vectors[i] );
800 }
801
802
803
804 static int radeon_emit_packets(
805 drm_radeon_cmd_header_t header,
806 drm_radeon_cmd_buffer_t *cmdbuf )
807 {
808 int id = (int)header.packet.packet_id;
809 int sz = packet[id].len;
810 int *data = (int *)cmdbuf->buf;
811 int i;
812
813 if (sz * sizeof(int) > cmdbuf->bufsz) {
814 fprintf(stderr, "Packet overflows cmdbuf\n");
815 return -EINVAL;
816 }
817
818 if (!packet[id].name) {
819 fprintf(stderr, "*** Unknown packet 0 nr %d\n", id );
820 return -EINVAL;
821 }
822
823
824 if (VERBOSE)
825 fprintf(stderr, "Packet 0 reg %s nr %d\n", packet[id].name, sz );
826
827 for ( i = 0 ; i < sz ; i++) {
828 struct reg *reg = lookup_reg( regs, packet[id].start + i*4 );
829 if (print_reg_assignment( reg, data[i] ))
830 total_changed++;
831 total++;
832 }
833
834 cmdbuf->buf += sz * sizeof(int);
835 cmdbuf->bufsz -= sz * sizeof(int);
836 return 0;
837 }
838
839
840 static int radeon_emit_scalars(
841 drm_radeon_cmd_header_t header,
842 drm_radeon_cmd_buffer_t *cmdbuf )
843 {
844 int sz = header.scalars.count;
845 int *data = (int *)cmdbuf->buf;
846 int start = header.scalars.offset;
847 int stride = header.scalars.stride;
848 int i;
849
850 if (VERBOSE)
851 fprintf(stderr, "emit scalars, start %d stride %d nr %d (end %d)\n",
852 start, stride, sz, start + stride * sz);
853
854
855 for (i = 0 ; i < sz ; i++, start += stride) {
856 struct reg *reg = lookup_reg( scalars, start );
857 if (print_reg_assignment( reg, data[i] ))
858 total_changed++;
859 total++;
860 }
861
862 cmdbuf->buf += sz * sizeof(int);
863 cmdbuf->bufsz -= sz * sizeof(int);
864 return 0;
865 }
866
867
868 static int radeon_emit_scalars2(
869 drm_radeon_cmd_header_t header,
870 drm_radeon_cmd_buffer_t *cmdbuf )
871 {
872 int sz = header.scalars.count;
873 int *data = (int *)cmdbuf->buf;
874 int start = header.scalars.offset + 0x100;
875 int stride = header.scalars.stride;
876 int i;
877
878 if (VERBOSE)
879 fprintf(stderr, "emit scalars2, start %d stride %d nr %d (end %d)\n",
880 start, stride, sz, start + stride * sz);
881
882 if (start + stride * sz > 258) {
883 fprintf(stderr, "emit scalars OVERFLOW %d/%d/%d\n", start, stride, sz);
884 return -1;
885 }
886
887 for (i = 0 ; i < sz ; i++, start += stride) {
888 struct reg *reg = lookup_reg( scalars, start );
889 if (print_reg_assignment( reg, data[i] ))
890 total_changed++;
891 total++;
892 }
893
894 cmdbuf->buf += sz * sizeof(int);
895 cmdbuf->bufsz -= sz * sizeof(int);
896 return 0;
897 }
898
899 /* Check: inf/nan/extreme-size?
900 * Check: table start, end, nr, etc.
901 */
902 static int radeon_emit_vectors(
903 drm_radeon_cmd_header_t header,
904 drm_radeon_cmd_buffer_t *cmdbuf )
905 {
906 int sz = header.vectors.count;
907 int *data = (int *)cmdbuf->buf;
908 int start = header.vectors.offset;
909 int stride = header.vectors.stride;
910 int i,j;
911
912 if (VERBOSE)
913 fprintf(stderr, "emit vectors, start %d stride %d nr %d (end %d) (0x%x)\n",
914 start, stride, sz, start + stride * sz, header.i);
915
916 /* if (start + stride * (sz/4) > 128) { */
917 /* fprintf(stderr, "emit vectors OVERFLOW %d/%d/%d\n", start, stride, sz); */
918 /* return -1; */
919 /* } */
920
921 for (i = 0 ; i < sz ; start += stride) {
922 int changed = 0;
923 for (j = 0 ; j < 4 ; i++,j++) {
924 struct reg *reg = lookup_reg( vectors, start*4+j );
925 if (print_reg_assignment( reg, data[i] ))
926 changed = 1;
927 }
928 if (changed)
929 total_changed += 4;
930 total += 4;
931 }
932
933
934 cmdbuf->buf += sz * sizeof(int);
935 cmdbuf->bufsz -= sz * sizeof(int);
936 return 0;
937 }
938
939 static int radeon_emit_veclinear(
940 drm_radeon_cmd_header_t header,
941 drm_radeon_cmd_buffer_t *cmdbuf )
942 {
943 int sz = header.veclinear.count * 4;
944 int *data = (int *)cmdbuf->buf;
945 float *fdata =(float *)cmdbuf->buf;
946 int start = header.veclinear.addr_lo | (header.veclinear.addr_hi << 8);
947 int i;
948
949 if (1||VERBOSE)
950 fprintf(stderr, "emit vectors linear, start %d nr %d (end %d) (0x%x)\n",
951 start, sz >> 2, start + (sz >> 2), header.i);
952
953
954 if (start < 0x60) {
955 for (i = 0 ; i < sz ; i += 4) {
956 fprintf(stderr, "R200_VS_PARAM %d 0 %f\n", (i >> 2) + start, fdata[i]);
957 fprintf(stderr, "R200_VS_PARAM %d 1 %f\n", (i >> 2) + start, fdata[i+1]);
958 fprintf(stderr, "R200_VS_PARAM %d 2 %f\n", (i >> 2) + start, fdata[i+2]);
959 fprintf(stderr, "R200_VS_PARAM %d 3 %f\n", (i >> 2) + start, fdata[i+3]);
960 }
961 }
962 else if ((start >= 0x100) && (start < 0x160)) {
963 for (i = 0 ; i < sz ; i += 4) {
964 fprintf(stderr, "R200_VS_PARAM %d 0 %f\n", (i >> 2) + start - 0x100 + 0x60, fdata[i]);
965 fprintf(stderr, "R200_VS_PARAM %d 1 %f\n", (i >> 2) + start - 0x100 + 0x60, fdata[i+1]);
966 fprintf(stderr, "R200_VS_PARAM %d 2 %f\n", (i >> 2) + start - 0x100 + 0x60, fdata[i+2]);
967 fprintf(stderr, "R200_VS_PARAM %d 3 %f\n", (i >> 2) + start - 0x100 + 0x60, fdata[i+3]);
968 }
969 }
970 else if ((start >= 0x80) && (start < 0xc0)) {
971 for (i = 0 ; i < sz ; i += 4) {
972 fprintf(stderr, "R200_VS_PROG %d OPDST %08x\n", (i >> 2) + start - 0x80, data[i]);
973 fprintf(stderr, "R200_VS_PROG %d SRC1 %08x\n", (i >> 2) + start - 0x80, data[i+1]);
974 fprintf(stderr, "R200_VS_PROG %d SRC2 %08x\n", (i >> 2) + start - 0x80, data[i+2]);
975 fprintf(stderr, "R200_VS_PROG %d SRC3 %08x\n", (i >> 2) + start - 0x80, data[i+3]);
976 }
977 }
978 else if ((start >= 0x180) && (start < 0x1c0)) {
979 for (i = 0 ; i < sz ; i += 4) {
980 fprintf(stderr, "R200_VS_PROG %d OPDST %08x\n", (i >> 2) + start - 0x180 + 0x40, data[i]);
981 fprintf(stderr, "R200_VS_PROG %d SRC1 %08x\n", (i >> 2) + start - 0x180 + 0x40, data[i+1]);
982 fprintf(stderr, "R200_VS_PROG %d SRC2 %08x\n", (i >> 2) + start - 0x180 + 0x40, data[i+2]);
983 fprintf(stderr, "R200_VS_PROG %d SRC3 %08x\n", (i >> 2) + start - 0x180 + 0x40, data[i+3]);
984 }
985 }
986 else {
987 fprintf(stderr, "write to unknown vector area\n");
988 }
989
990 cmdbuf->buf += sz * sizeof(int);
991 cmdbuf->bufsz -= sz * sizeof(int);
992 return 0;
993 }
994
995 #if 0
996 static int print_vertex_format( int vfmt )
997 {
998 if (NORMAL) {
999 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",
1000 "vertex format",
1001 vfmt,
1002 "xy,",
1003 (vfmt & R200_VTX_Z0) ? "z," : "",
1004 (vfmt & R200_VTX_W0) ? "w0," : "",
1005 (vfmt & R200_VTX_FPCOLOR) ? "fpcolor," : "",
1006 (vfmt & R200_VTX_FPALPHA) ? "fpalpha," : "",
1007 (vfmt & R200_VTX_PKCOLOR) ? "pkcolor," : "",
1008 (vfmt & R200_VTX_FPSPEC) ? "fpspec," : "",
1009 (vfmt & R200_VTX_FPFOG) ? "fpfog," : "",
1010 (vfmt & R200_VTX_PKSPEC) ? "pkspec," : "",
1011 (vfmt & R200_VTX_ST0) ? "st0," : "",
1012 (vfmt & R200_VTX_ST1) ? "st1," : "",
1013 (vfmt & R200_VTX_Q1) ? "q1," : "",
1014 (vfmt & R200_VTX_ST2) ? "st2," : "",
1015 (vfmt & R200_VTX_Q2) ? "q2," : "",
1016 (vfmt & R200_VTX_ST3) ? "st3," : "",
1017 (vfmt & R200_VTX_Q3) ? "q3," : "",
1018 (vfmt & R200_VTX_Q0) ? "q0," : "",
1019 (vfmt & R200_VTX_N0) ? "n0," : "",
1020 (vfmt & R200_VTX_XY1) ? "xy1," : "",
1021 (vfmt & R200_VTX_Z1) ? "z1," : "",
1022 (vfmt & R200_VTX_W1) ? "w1," : "",
1023 (vfmt & R200_VTX_N1) ? "n1," : "");
1024
1025
1026 if (!find_or_add_value( &others[V_VTXFMT], vfmt ))
1027 fprintf(stderr, " *** NEW VALUE");
1028
1029 fprintf(stderr, "\n");
1030 }
1031
1032 return 0;
1033 }
1034 #endif
1035
1036 static char *primname[0x10] = {
1037 "NONE",
1038 "POINTS",
1039 "LINES",
1040 "LINE_STRIP",
1041 "TRIANGLES",
1042 "TRIANGLE_FAN",
1043 "TRIANGLE_STRIP",
1044 "RECT_LIST",
1045 NULL,
1046 "3VRT_POINTS",
1047 "3VRT_LINES",
1048 "POINT_SPRITES",
1049 "LINE_LOOP",
1050 "QUADS",
1051 "QUAD_STRIP",
1052 "POLYGON",
1053 };
1054
1055 static int print_prim_and_flags( int prim )
1056 {
1057 int numverts;
1058
1059 if (NORMAL)
1060 fprintf(stderr, " %s(%x): %s%s%s%s%s%s\n",
1061 "prim flags",
1062 prim,
1063 ((prim & 0x30) == R200_VF_PRIM_WALK_IND) ? "IND," : "",
1064 ((prim & 0x30) == R200_VF_PRIM_WALK_LIST) ? "LIST," : "",
1065 ((prim & 0x30) == R200_VF_PRIM_WALK_RING) ? "RING," : "",
1066 (prim & R200_VF_COLOR_ORDER_RGBA) ? "RGBA," : "BGRA, ",
1067 (prim & R200_VF_INDEX_SZ_4) ? "INDX-32," : "",
1068 (prim & R200_VF_TCL_OUTPUT_VTX_ENABLE) ? "TCL_OUT_VTX," : "");
1069
1070 numverts = prim>>16;
1071
1072 if (NORMAL)
1073 fprintf(stderr, " prim: %s numverts %d\n", primname[prim&0xf], numverts);
1074
1075 switch (prim & 0xf) {
1076 case R200_VF_PRIM_NONE:
1077 case R200_VF_PRIM_POINTS:
1078 if (numverts < 1) {
1079 fprintf(stderr, "Bad nr verts for line %d\n", numverts);
1080 return -1;
1081 }
1082 break;
1083 case R200_VF_PRIM_LINES:
1084 case R200_VF_PRIM_POINT_SPRITES:
1085 if ((numverts & 1) || numverts == 0) {
1086 fprintf(stderr, "Bad nr verts for line %d\n", numverts);
1087 return -1;
1088 }
1089 break;
1090 case R200_VF_PRIM_LINE_STRIP:
1091 case R200_VF_PRIM_LINE_LOOP:
1092 if (numverts < 2) {
1093 fprintf(stderr, "Bad nr verts for line_strip %d\n", numverts);
1094 return -1;
1095 }
1096 break;
1097 case R200_VF_PRIM_TRIANGLES:
1098 case R200_VF_PRIM_3VRT_POINTS:
1099 case R200_VF_PRIM_3VRT_LINES:
1100 case R200_VF_PRIM_RECT_LIST:
1101 if (numverts % 3 || numverts == 0) {
1102 fprintf(stderr, "Bad nr verts for tri %d\n", numverts);
1103 return -1;
1104 }
1105 break;
1106 case R200_VF_PRIM_TRIANGLE_FAN:
1107 case R200_VF_PRIM_TRIANGLE_STRIP:
1108 case R200_VF_PRIM_POLYGON:
1109 if (numverts < 3) {
1110 fprintf(stderr, "Bad nr verts for strip/fan %d\n", numverts);
1111 return -1;
1112 }
1113 break;
1114 case R200_VF_PRIM_QUADS:
1115 if (numverts % 4 || numverts == 0) {
1116 fprintf(stderr, "Bad nr verts for quad %d\n", numverts);
1117 return -1;
1118 }
1119 break;
1120 case R200_VF_PRIM_QUAD_STRIP:
1121 if (numverts % 2 || numverts < 4) {
1122 fprintf(stderr, "Bad nr verts for quadstrip %d\n", numverts);
1123 return -1;
1124 }
1125 break;
1126 default:
1127 fprintf(stderr, "Bad primitive\n");
1128 return -1;
1129 }
1130 return 0;
1131 }
1132
1133 /* build in knowledge about each packet type
1134 */
1135 static int radeon_emit_packet3( drm_radeon_cmd_buffer_t *cmdbuf )
1136 {
1137 int cmdsz;
1138 int *cmd = (int *)cmdbuf->buf;
1139 int *tmp;
1140 int i, stride, size, start;
1141
1142 cmdsz = 2 + ((cmd[0] & RADEON_CP_PACKET_COUNT_MASK) >> 16);
1143
1144 if ((cmd[0] & RADEON_CP_PACKET_MASK) != RADEON_CP_PACKET3 ||
1145 cmdsz * 4 > cmdbuf->bufsz ||
1146 cmdsz > RADEON_CP_PACKET_MAX_DWORDS) {
1147 fprintf(stderr, "Bad packet\n");
1148 return -EINVAL;
1149 }
1150
1151 switch( cmd[0] & ~RADEON_CP_PACKET_COUNT_MASK ) {
1152 case R200_CP_CMD_NOP:
1153 if (NORMAL)
1154 fprintf(stderr, "PACKET3_NOP, %d dwords\n", cmdsz);
1155 break;
1156 case R200_CP_CMD_NEXT_CHAR:
1157 if (NORMAL)
1158 fprintf(stderr, "PACKET3_NEXT_CHAR, %d dwords\n", cmdsz);
1159 break;
1160 case R200_CP_CMD_PLY_NEXTSCAN:
1161 if (NORMAL)
1162 fprintf(stderr, "PACKET3_PLY_NEXTSCAN, %d dwords\n", cmdsz);
1163 break;
1164 case R200_CP_CMD_SET_SCISSORS:
1165 if (NORMAL)
1166 fprintf(stderr, "PACKET3_SET_SCISSORS, %d dwords\n", cmdsz);
1167 break;
1168 case R200_CP_CMD_LOAD_MICROCODE:
1169 if (NORMAL)
1170 fprintf(stderr, "PACKET3_LOAD_MICROCODE, %d dwords\n", cmdsz);
1171 break;
1172 case R200_CP_CMD_WAIT_FOR_IDLE:
1173 if (NORMAL)
1174 fprintf(stderr, "PACKET3_WAIT_FOR_IDLE, %d dwords\n", cmdsz);
1175 break;
1176
1177 case R200_CP_CMD_3D_DRAW_VBUF:
1178 if (NORMAL)
1179 fprintf(stderr, "PACKET3_3D_DRAW_VBUF, %d dwords\n", cmdsz);
1180 /* print_vertex_format(cmd[1]); */
1181 if (print_prim_and_flags(cmd[2]))
1182 return -EINVAL;
1183 break;
1184
1185 case R200_CP_CMD_3D_DRAW_IMMD:
1186 if (NORMAL)
1187 fprintf(stderr, "PACKET3_3D_DRAW_IMMD, %d dwords\n", cmdsz);
1188 break;
1189 case R200_CP_CMD_3D_DRAW_INDX: {
1190 int neltdwords;
1191 if (NORMAL)
1192 fprintf(stderr, "PACKET3_3D_DRAW_INDX, %d dwords\n", cmdsz);
1193 /* print_vertex_format(cmd[1]); */
1194 if (print_prim_and_flags(cmd[2]))
1195 return -EINVAL;
1196 neltdwords = cmd[2]>>16;
1197 neltdwords += neltdwords & 1;
1198 neltdwords /= 2;
1199 if (neltdwords + 3 != cmdsz)
1200 fprintf(stderr, "Mismatch in DRAW_INDX, %d vs cmdsz %d\n",
1201 neltdwords, cmdsz);
1202 break;
1203 }
1204 case R200_CP_CMD_LOAD_PALETTE:
1205 if (NORMAL)
1206 fprintf(stderr, "PACKET3_LOAD_PALETTE, %d dwords\n", cmdsz);
1207 break;
1208 case R200_CP_CMD_3D_LOAD_VBPNTR:
1209 if (NORMAL) {
1210 fprintf(stderr, "PACKET3_3D_LOAD_VBPNTR, %d dwords\n", cmdsz);
1211 fprintf(stderr, " nr arrays: %d\n", cmd[1]);
1212 }
1213
1214 if (((cmd[1]/2)*3) + ((cmd[1]%2)*2) != cmdsz - 2) {
1215 fprintf(stderr, " ****** MISMATCH %d/%d *******\n",
1216 ((cmd[1]/2)*3) + ((cmd[1]%2)*2) + 2, cmdsz);
1217 return -EINVAL;
1218 }
1219
1220 if (NORMAL) {
1221 tmp = cmd+2;
1222 for (i = 0 ; i < cmd[1] ; i++) {
1223 if (i & 1) {
1224 stride = (tmp[0]>>24) & 0xff;
1225 size = (tmp[0]>>16) & 0xff;
1226 start = tmp[2];
1227 tmp += 3;
1228 }
1229 else {
1230 stride = (tmp[0]>>8) & 0xff;
1231 size = (tmp[0]) & 0xff;
1232 start = tmp[1];
1233 }
1234 fprintf(stderr, " array %d: start 0x%x vsize %d vstride %d\n",
1235 i, start, size, stride );
1236 }
1237 }
1238 break;
1239 case R200_CP_CMD_PAINT:
1240 if (NORMAL)
1241 fprintf(stderr, "PACKET3_CNTL_PAINT, %d dwords\n", cmdsz);
1242 break;
1243 case R200_CP_CMD_BITBLT:
1244 if (NORMAL)
1245 fprintf(stderr, "PACKET3_CNTL_BITBLT, %d dwords\n", cmdsz);
1246 break;
1247 case R200_CP_CMD_SMALLTEXT:
1248 if (NORMAL)
1249 fprintf(stderr, "PACKET3_CNTL_SMALLTEXT, %d dwords\n", cmdsz);
1250 break;
1251 case R200_CP_CMD_HOSTDATA_BLT:
1252 if (NORMAL)
1253 fprintf(stderr, "PACKET3_CNTL_HOSTDATA_BLT, %d dwords\n",
1254 cmdsz);
1255 break;
1256 case R200_CP_CMD_POLYLINE:
1257 if (NORMAL)
1258 fprintf(stderr, "PACKET3_CNTL_POLYLINE, %d dwords\n", cmdsz);
1259 break;
1260 case R200_CP_CMD_POLYSCANLINES:
1261 if (NORMAL)
1262 fprintf(stderr, "PACKET3_CNTL_POLYSCANLINES, %d dwords\n",
1263 cmdsz);
1264 break;
1265 case R200_CP_CMD_PAINT_MULTI:
1266 if (NORMAL)
1267 fprintf(stderr, "PACKET3_CNTL_PAINT_MULTI, %d dwords\n",
1268 cmdsz);
1269 break;
1270 case R200_CP_CMD_BITBLT_MULTI:
1271 if (NORMAL)
1272 fprintf(stderr, "PACKET3_CNTL_BITBLT_MULTI, %d dwords\n",
1273 cmdsz);
1274 break;
1275 case R200_CP_CMD_TRANS_BITBLT:
1276 if (NORMAL)
1277 fprintf(stderr, "PACKET3_CNTL_TRANS_BITBLT, %d dwords\n",
1278 cmdsz);
1279 break;
1280 case R200_CP_CMD_3D_DRAW_VBUF_2:
1281 if (NORMAL)
1282 fprintf(stderr, "R200_CP_CMD_3D_DRAW_VBUF_2, %d dwords\n",
1283 cmdsz);
1284 if (print_prim_and_flags(cmd[1]))
1285 return -EINVAL;
1286 break;
1287 case R200_CP_CMD_3D_DRAW_IMMD_2:
1288 if (NORMAL)
1289 fprintf(stderr, "R200_CP_CMD_3D_DRAW_IMMD_2, %d dwords\n",
1290 cmdsz);
1291 if (print_prim_and_flags(cmd[1]))
1292 return -EINVAL;
1293 break;
1294 case R200_CP_CMD_3D_DRAW_INDX_2:
1295 if (NORMAL)
1296 fprintf(stderr, "R200_CP_CMD_3D_DRAW_INDX_2, %d dwords\n",
1297 cmdsz);
1298 if (print_prim_and_flags(cmd[1]))
1299 return -EINVAL;
1300 break;
1301 default:
1302 fprintf(stderr, "UNKNOWN PACKET, %d dwords\n", cmdsz);
1303 break;
1304 }
1305
1306 cmdbuf->buf += cmdsz * 4;
1307 cmdbuf->bufsz -= cmdsz * 4;
1308 return 0;
1309 }
1310
1311
1312 /* Check cliprects for bounds, then pass on to above:
1313 */
1314 static int radeon_emit_packet3_cliprect( drm_radeon_cmd_buffer_t *cmdbuf )
1315 {
1316 drm_clip_rect_t *boxes = (drm_clip_rect_t *)cmdbuf->boxes;
1317 int i = 0;
1318
1319 if (VERBOSE && total_changed) {
1320 dump_state();
1321 total_changed = 0;
1322 }
1323
1324 if (NORMAL) {
1325 do {
1326 if ( i < cmdbuf->nbox ) {
1327 fprintf(stderr, "Emit box %d/%d %d,%d %d,%d\n",
1328 i, cmdbuf->nbox,
1329 boxes[i].x1, boxes[i].y1, boxes[i].x2, boxes[i].y2);
1330 }
1331 } while ( ++i < cmdbuf->nbox );
1332 }
1333
1334 if (cmdbuf->nbox == 1)
1335 cmdbuf->nbox = 0;
1336
1337 return radeon_emit_packet3( cmdbuf );
1338 }
1339
1340
1341 int r200SanityCmdBuffer( r200ContextPtr rmesa,
1342 int nbox,
1343 drm_clip_rect_t *boxes )
1344 {
1345 int idx;
1346 drm_radeon_cmd_buffer_t cmdbuf;
1347 drm_radeon_cmd_header_t header;
1348 static int inited = 0;
1349
1350 if (!inited) {
1351 init_regs();
1352 inited = 1;
1353 }
1354
1355
1356 cmdbuf.buf = rmesa->store.cmd_buf;
1357 cmdbuf.bufsz = rmesa->store.cmd_used;
1358 cmdbuf.boxes = (drm_clip_rect_t *)boxes;
1359 cmdbuf.nbox = nbox;
1360
1361 while ( cmdbuf.bufsz >= sizeof(header) ) {
1362
1363 header.i = *(int *)cmdbuf.buf;
1364 cmdbuf.buf += sizeof(header);
1365 cmdbuf.bufsz -= sizeof(header);
1366
1367 switch (header.header.cmd_type) {
1368 case RADEON_CMD_PACKET:
1369 if (radeon_emit_packets( header, &cmdbuf )) {
1370 fprintf(stderr,"radeon_emit_packets failed\n");
1371 return -EINVAL;
1372 }
1373 break;
1374
1375 case RADEON_CMD_SCALARS:
1376 if (radeon_emit_scalars( header, &cmdbuf )) {
1377 fprintf(stderr,"radeon_emit_scalars failed\n");
1378 return -EINVAL;
1379 }
1380 break;
1381
1382 case RADEON_CMD_SCALARS2:
1383 if (radeon_emit_scalars2( header, &cmdbuf )) {
1384 fprintf(stderr,"radeon_emit_scalars failed\n");
1385 return -EINVAL;
1386 }
1387 break;
1388
1389 case RADEON_CMD_VECTORS:
1390 if (radeon_emit_vectors( header, &cmdbuf )) {
1391 fprintf(stderr,"radeon_emit_vectors failed\n");
1392 return -EINVAL;
1393 }
1394 break;
1395
1396 case RADEON_CMD_DMA_DISCARD:
1397 idx = header.dma.buf_idx;
1398 if (NORMAL)
1399 fprintf(stderr, "RADEON_CMD_DMA_DISCARD buf %d\n", idx);
1400 bufs++;
1401 break;
1402
1403 case RADEON_CMD_PACKET3:
1404 if (radeon_emit_packet3( &cmdbuf )) {
1405 fprintf(stderr,"radeon_emit_packet3 failed\n");
1406 return -EINVAL;
1407 }
1408 break;
1409
1410 case RADEON_CMD_PACKET3_CLIP:
1411 if (radeon_emit_packet3_cliprect( &cmdbuf )) {
1412 fprintf(stderr,"radeon_emit_packet3_clip failed\n");
1413 return -EINVAL;
1414 }
1415 break;
1416
1417 case RADEON_CMD_WAIT:
1418 break;
1419
1420 case RADEON_CMD_VECLINEAR:
1421 if (radeon_emit_veclinear( header, &cmdbuf )) {
1422 fprintf(stderr,"radeon_emit_veclinear failed\n");
1423 return -EINVAL;
1424 }
1425 break;
1426
1427 default:
1428 fprintf(stderr,"bad cmd_type %d at %p\n",
1429 header.header.cmd_type,
1430 cmdbuf.buf - sizeof(header));
1431 return -EINVAL;
1432 }
1433 }
1434
1435 if (0)
1436 {
1437 static int n = 0;
1438 n++;
1439 if (n == 10) {
1440 fprintf(stderr, "Bufs %d Total emitted %d real changes %d (%.2f%%)\n",
1441 bufs,
1442 total, total_changed,
1443 ((float)total_changed/(float)total*100.0));
1444 fprintf(stderr, "Total emitted per buf: %.2f\n",
1445 (float)total/(float)bufs);
1446 fprintf(stderr, "Real changes per buf: %.2f\n",
1447 (float)total_changed/(float)bufs);
1448
1449 bufs = n = total = total_changed = 0;
1450 }
1451 }
1452
1453 fprintf(stderr, "leaving %s\n\n\n", __FUNCTION__);
1454
1455 return 0;
1456 }