NSMBW-Decomp
A decompilation of New Super Mario Bros. Wii
Loading...
Searching...
No Matches
GXHardwareXF.h
1#ifndef RVL_SDK_GX_HARDWARE_XF_H
2#define RVL_SDK_GX_HARDWARE_XF_H
3#include <revolution/GX/GXTypes.h>
4#include <types.h>
5#ifdef __cplusplus
6extern "C" {
7#endif
8
9/******************************************************************************
10 *
11 *
12 * GX Transform Unit (XF)
13 *
14 *
15 *****************************************************************************/
16
17/**
18 * XF registers
19 */
20typedef enum {
21 GX_XF_REG_ERROR = 0x1000,
22 GX_XF_REG_DIAGNOSTICS = 0x1001,
23 GX_XF_REG_STATE0 = 0x1002,
24 GX_XF_REG_STATE1 = 0x1003,
25 GX_XF_REG_CLOCK = 0x1004,
26 GX_XF_REG_CLIPDISABLE = 0x1005,
27 GX_XF_REG_PERF0 = 0x1006,
28 GX_XF_REG_PERF1 = 0x1007,
29 GX_XF_REG_INVERTEXSPEC = 0x1008,
30 GX_XF_REG_NUMCOLORS = 0x1009,
31 GX_XF_REG_AMBIENT0 = 0x100A,
32 GX_XF_REG_AMBIENT1 = 0x100B,
33 GX_XF_REG_MATERIAL0 = 0x100C,
34 GX_XF_REG_MATERIAL1 = 0x100D,
35 GX_XF_REG_COLOR0CNTRL = 0x100E,
36 GX_XF_REG_COLOR1CNTRL = 0x100F,
37 GX_XF_REG_ALPHA0CNTRL = 0x1010,
38 GX_XF_REG_ALPHA1CNTRL = 0x1011,
39 GX_XF_REG_DUALTEXTRAN = 0x1012,
40 GX_XF_REG_MATRIXINDEX0 = 0x1018,
41 GX_XF_REG_MATRIXINDEX1 = 0x1019,
42 GX_XF_REG_SCALEX = 0x101A,
43 GX_XF_REG_SCALEY = 0x101B,
44 GX_XF_REG_SCALEZ = 0x101C,
45 GX_XF_REG_OFFSETX = 0x101D,
46 GX_XF_REG_OFFSETY = 0x101E,
47 GX_XF_REG_OFFSETZ = 0x101F,
48 GX_XF_REG_PROJECTIONA = 0x1020,
49 GX_XF_REG_PROJECTIONB = 0x1021,
50 GX_XF_REG_PROJECTIONC = 0x1022,
51 GX_XF_REG_PROJECTIOND = 0x1023,
52 GX_XF_REG_PROJECTIONE = 0x1024,
53 GX_XF_REG_PROJECTIONF = 0x1025,
54 GX_XF_REG_PROJECTORTHO = 0x1026,
55 GX_XF_REG_NUMTEX = 0x103F,
56 GX_XF_REG_TEX0 = 0x1040,
57 GX_XF_REG_TEX1 = 0x1041,
58 GX_XF_REG_TEX2 = 0x1042,
59 GX_XF_REG_TEX3 = 0x1043,
60 GX_XF_REG_TEX4 = 0x1044,
61 GX_XF_REG_TEX5 = 0x1045,
62 GX_XF_REG_TEX6 = 0x1046,
63 GX_XF_REG_TEX7 = 0x1047,
64 GX_XF_REG_DUALTEX0 = 0x1050,
65 GX_XF_REG_DUALTEX1 = 0x1051,
66 GX_XF_REG_DUALTEX2 = 0x1052,
67 GX_XF_REG_DUALTEX3 = 0x1053,
68 GX_XF_REG_DUALTEX4 = 0x1054,
69 GX_XF_REG_DUALTEX5 = 0x1055,
70 GX_XF_REG_DUALTEX6 = 0x1056,
71 GX_XF_REG_DUALTEX7 = 0x1057,
72} GX_XF_REG;
73
74/******************************************************************************
75 * XF register 0x1005 - ClipDisable
76 *****************************************************************************/
77// DETECT [31:31] (1) - Disable clipping detection
78 /* start bit */ #define GX_XF_CLIPDISABLE_DETECT_B 31
79 /* end bit */ #define GX_XF_CLIPDISABLE_DETECT_E 31
80 /* bit size */ #define GX_XF_CLIPDISABLE_DETECT_SZ 1
81
82 /* raw mask */ #define GX_XF_CLIPDISABLE_DETECT_MASK (((1 << 1) - 1) << 31 - 31)
83 /* local mask */ #define GX_XF_CLIPDISABLE_DETECT_LMASK ((1 << 1) - 1)
84 /* bit shift */ #define GX_XF_CLIPDISABLE_DETECT_SHIFT 0
85
86 /* get value */ #define GX_XF_GET_CLIPDISABLE_DETECT(reg) GX_BITGET((reg), 31, 1)
87 /* set value */ #define GX_XF_SET_CLIPDISABLE_DETECT(reg, x) ((reg) = GX_BITSET((reg), 31, 1, x))
88
89// REJECT [30:30] (1) - Disable trivial rejection
90 /* start bit */ #define GX_XF_CLIPDISABLE_REJECT_B 30
91 /* end bit */ #define GX_XF_CLIPDISABLE_REJECT_E 30
92 /* bit size */ #define GX_XF_CLIPDISABLE_REJECT_SZ 1
93
94 /* raw mask */ #define GX_XF_CLIPDISABLE_REJECT_MASK (((1 << 1) - 1) << 31 - 30)
95 /* local mask */ #define GX_XF_CLIPDISABLE_REJECT_LMASK ((1 << 1) - 1)
96 /* bit shift */ #define GX_XF_CLIPDISABLE_REJECT_SHIFT 1
97
98 /* get value */ #define GX_XF_GET_CLIPDISABLE_REJECT(reg) GX_BITGET((reg), 30, 1)
99 /* set value */ #define GX_XF_SET_CLIPDISABLE_REJECT(reg, x) ((reg) = GX_BITSET((reg), 30, 1, x))
100
101// ACCEL [29:29] (1) - Disable cpoly clipping acceleration
102 /* start bit */ #define GX_XF_CLIPDISABLE_ACCEL_B 29
103 /* end bit */ #define GX_XF_CLIPDISABLE_ACCEL_E 29
104 /* bit size */ #define GX_XF_CLIPDISABLE_ACCEL_SZ 1
105
106 /* raw mask */ #define GX_XF_CLIPDISABLE_ACCEL_MASK (((1 << 1) - 1) << 31 - 29)
107 /* local mask */ #define GX_XF_CLIPDISABLE_ACCEL_LMASK ((1 << 1) - 1)
108 /* bit shift */ #define GX_XF_CLIPDISABLE_ACCEL_SHIFT 2
109
110 /* get value */ #define GX_XF_GET_CLIPDISABLE_ACCEL(reg) GX_BITGET((reg), 29, 1)
111 /* set value */ #define GX_XF_SET_CLIPDISABLE_ACCEL(reg, x) ((reg) = GX_BITSET((reg), 29, 1, x))
112
113
114/******************************************************************************
115 * XF register 0x1007 - Perf1
116 *****************************************************************************/
117// TARGET [25:31] (7) - Target performance (Cycles/vertex)
118 /* start bit */ #define GX_XF_PERF1_TARGET_B 25
119 /* end bit */ #define GX_XF_PERF1_TARGET_E 31
120 /* bit size */ #define GX_XF_PERF1_TARGET_SZ 7
121
122 /* raw mask */ #define GX_XF_PERF1_TARGET_MASK (((1 << 7) - 1) << 31 - 31)
123 /* local mask */ #define GX_XF_PERF1_TARGET_LMASK ((1 << 7) - 1)
124 /* bit shift */ #define GX_XF_PERF1_TARGET_SHIFT 0
125
126 /* get value */ #define GX_XF_GET_PERF1_TARGET(reg) GX_BITGET((reg), 25, 7)
127 /* set value */ #define GX_XF_SET_PERF1_TARGET(reg, x) ((reg) = GX_BITSET((reg), 25, 7, x))
128
129
130/******************************************************************************
131 * XF register 0x1008 - InVertexSpec
132 *****************************************************************************/
133// CLR [30:31] (2)
134 /* start bit */ #define GX_XF_INVERTEXSPEC_CLR_B 30
135 /* end bit */ #define GX_XF_INVERTEXSPEC_CLR_E 31
136 /* bit size */ #define GX_XF_INVERTEXSPEC_CLR_SZ 2
137
138 /* raw mask */ #define GX_XF_INVERTEXSPEC_CLR_MASK (((1 << 2) - 1) << 31 - 31)
139 /* local mask */ #define GX_XF_INVERTEXSPEC_CLR_LMASK ((1 << 2) - 1)
140 /* bit shift */ #define GX_XF_INVERTEXSPEC_CLR_SHIFT 0
141
142 /* get value */ #define GX_XF_GET_INVERTEXSPEC_CLR(reg) GX_BITGET((reg), 30, 2)
143 /* set value */ #define GX_XF_SET_INVERTEXSPEC_CLR(reg, x) ((reg) = GX_BITSET((reg), 30, 2, x))
144
145// NRM [28:29] (2)
146 /* start bit */ #define GX_XF_INVERTEXSPEC_NRM_B 28
147 /* end bit */ #define GX_XF_INVERTEXSPEC_NRM_E 29
148 /* bit size */ #define GX_XF_INVERTEXSPEC_NRM_SZ 2
149
150 /* raw mask */ #define GX_XF_INVERTEXSPEC_NRM_MASK (((1 << 2) - 1) << 31 - 29)
151 /* local mask */ #define GX_XF_INVERTEXSPEC_NRM_LMASK ((1 << 2) - 1)
152 /* bit shift */ #define GX_XF_INVERTEXSPEC_NRM_SHIFT 2
153
154 /* get value */ #define GX_XF_GET_INVERTEXSPEC_NRM(reg) GX_BITGET((reg), 28, 2)
155 /* set value */ #define GX_XF_SET_INVERTEXSPEC_NRM(reg, x) ((reg) = GX_BITSET((reg), 28, 2, x))
156
157// TXC [24:27] (4)
158 /* start bit */ #define GX_XF_INVERTEXSPEC_TXC_B 24
159 /* end bit */ #define GX_XF_INVERTEXSPEC_TXC_E 27
160 /* bit size */ #define GX_XF_INVERTEXSPEC_TXC_SZ 4
161
162 /* raw mask */ #define GX_XF_INVERTEXSPEC_TXC_MASK (((1 << 4) - 1) << 31 - 27)
163 /* local mask */ #define GX_XF_INVERTEXSPEC_TXC_LMASK ((1 << 4) - 1)
164 /* bit shift */ #define GX_XF_INVERTEXSPEC_TXC_SHIFT 4
165
166 /* get value */ #define GX_XF_GET_INVERTEXSPEC_TXC(reg) GX_BITGET((reg), 24, 4)
167 /* set value */ #define GX_XF_SET_INVERTEXSPEC_TXC(reg, x) ((reg) = GX_BITSET((reg), 24, 4, x))
168
169
170/******************************************************************************
171 * XF register 0x100E - Color0Cntrl
172 *****************************************************************************/
173// MATSRC [31:31] (1)
174 /* start bit */ #define GX_XF_COLOR0CNTRL_MATSRC_B 31
175 /* end bit */ #define GX_XF_COLOR0CNTRL_MATSRC_E 31
176 /* bit size */ #define GX_XF_COLOR0CNTRL_MATSRC_SZ 1
177
178 /* raw mask */ #define GX_XF_COLOR0CNTRL_MATSRC_MASK (((1 << 1) - 1) << 31 - 31)
179 /* local mask */ #define GX_XF_COLOR0CNTRL_MATSRC_LMASK ((1 << 1) - 1)
180 /* bit shift */ #define GX_XF_COLOR0CNTRL_MATSRC_SHIFT 0
181
182 /* get value */ #define GX_XF_GET_COLOR0CNTRL_MATSRC(reg) GX_BITGET((reg), 31, 1)
183 /* set value */ #define GX_XF_SET_COLOR0CNTRL_MATSRC(reg, x) ((reg) = GX_BITSET((reg), 31, 1, x))
184
185// LIGHT [30:30] (1)
186 /* start bit */ #define GX_XF_COLOR0CNTRL_LIGHT_B 30
187 /* end bit */ #define GX_XF_COLOR0CNTRL_LIGHT_E 30
188 /* bit size */ #define GX_XF_COLOR0CNTRL_LIGHT_SZ 1
189
190 /* raw mask */ #define GX_XF_COLOR0CNTRL_LIGHT_MASK (((1 << 1) - 1) << 31 - 30)
191 /* local mask */ #define GX_XF_COLOR0CNTRL_LIGHT_LMASK ((1 << 1) - 1)
192 /* bit shift */ #define GX_XF_COLOR0CNTRL_LIGHT_SHIFT 1
193
194 /* get value */ #define GX_XF_GET_COLOR0CNTRL_LIGHT(reg) GX_BITGET((reg), 30, 1)
195 /* set value */ #define GX_XF_SET_COLOR0CNTRL_LIGHT(reg, x) ((reg) = GX_BITSET((reg), 30, 1, x))
196
197// LMASKLO [26:29] (4)
198 /* start bit */ #define GX_XF_COLOR0CNTRL_LMASKLO_B 26
199 /* end bit */ #define GX_XF_COLOR0CNTRL_LMASKLO_E 29
200 /* bit size */ #define GX_XF_COLOR0CNTRL_LMASKLO_SZ 4
201
202 /* raw mask */ #define GX_XF_COLOR0CNTRL_LMASKLO_MASK (((1 << 4) - 1) << 31 - 29)
203 /* local mask */ #define GX_XF_COLOR0CNTRL_LMASKLO_LMASK ((1 << 4) - 1)
204 /* bit shift */ #define GX_XF_COLOR0CNTRL_LMASKLO_SHIFT 2
205
206 /* get value */ #define GX_XF_GET_COLOR0CNTRL_LMASKLO(reg) GX_BITGET((reg), 26, 4)
207 /* set value */ #define GX_XF_SET_COLOR0CNTRL_LMASKLO(reg, x) ((reg) = GX_BITSET((reg), 26, 4, x))
208
209// AMBSRC [25:25] (1)
210 /* start bit */ #define GX_XF_COLOR0CNTRL_AMBSRC_B 25
211 /* end bit */ #define GX_XF_COLOR0CNTRL_AMBSRC_E 25
212 /* bit size */ #define GX_XF_COLOR0CNTRL_AMBSRC_SZ 1
213
214 /* raw mask */ #define GX_XF_COLOR0CNTRL_AMBSRC_MASK (((1 << 1) - 1) << 31 - 25)
215 /* local mask */ #define GX_XF_COLOR0CNTRL_AMBSRC_LMASK ((1 << 1) - 1)
216 /* bit shift */ #define GX_XF_COLOR0CNTRL_AMBSRC_SHIFT 6
217
218 /* get value */ #define GX_XF_GET_COLOR0CNTRL_AMBSRC(reg) GX_BITGET((reg), 25, 1)
219 /* set value */ #define GX_XF_SET_COLOR0CNTRL_AMBSRC(reg, x) ((reg) = GX_BITSET((reg), 25, 1, x))
220
221// DIFFUSEATTN [23:24] (2)
222 /* start bit */ #define GX_XF_COLOR0CNTRL_DIFFUSEATTN_B 23
223 /* end bit */ #define GX_XF_COLOR0CNTRL_DIFFUSEATTN_E 24
224 /* bit size */ #define GX_XF_COLOR0CNTRL_DIFFUSEATTN_SZ 2
225
226 /* raw mask */ #define GX_XF_COLOR0CNTRL_DIFFUSEATTN_MASK (((1 << 2) - 1) << 31 - 24)
227 /* local mask */ #define GX_XF_COLOR0CNTRL_DIFFUSEATTN_LMASK ((1 << 2) - 1)
228 /* bit shift */ #define GX_XF_COLOR0CNTRL_DIFFUSEATTN_SHIFT 7
229
230 /* get value */ #define GX_XF_GET_COLOR0CNTRL_DIFFUSEATTN(reg) GX_BITGET((reg), 23, 2)
231 /* set value */ #define GX_XF_SET_COLOR0CNTRL_DIFFUSEATTN(reg, x) ((reg) = GX_BITSET((reg), 23, 2, x))
232
233// ATTNENABLE [22:22] (1)
234 /* start bit */ #define GX_XF_COLOR0CNTRL_ATTNENABLE_B 22
235 /* end bit */ #define GX_XF_COLOR0CNTRL_ATTNENABLE_E 22
236 /* bit size */ #define GX_XF_COLOR0CNTRL_ATTNENABLE_SZ 1
237
238 /* raw mask */ #define GX_XF_COLOR0CNTRL_ATTNENABLE_MASK (((1 << 1) - 1) << 31 - 22)
239 /* local mask */ #define GX_XF_COLOR0CNTRL_ATTNENABLE_LMASK ((1 << 1) - 1)
240 /* bit shift */ #define GX_XF_COLOR0CNTRL_ATTNENABLE_SHIFT 9
241
242 /* get value */ #define GX_XF_GET_COLOR0CNTRL_ATTNENABLE(reg) GX_BITGET((reg), 22, 1)
243 /* set value */ #define GX_XF_SET_COLOR0CNTRL_ATTNENABLE(reg, x) ((reg) = GX_BITSET((reg), 22, 1, x))
244
245// ATTNSELECT [21:21] (1)
246 /* start bit */ #define GX_XF_COLOR0CNTRL_ATTNSELECT_B 21
247 /* end bit */ #define GX_XF_COLOR0CNTRL_ATTNSELECT_E 21
248 /* bit size */ #define GX_XF_COLOR0CNTRL_ATTNSELECT_SZ 1
249
250 /* raw mask */ #define GX_XF_COLOR0CNTRL_ATTNSELECT_MASK (((1 << 1) - 1) << 31 - 21)
251 /* local mask */ #define GX_XF_COLOR0CNTRL_ATTNSELECT_LMASK ((1 << 1) - 1)
252 /* bit shift */ #define GX_XF_COLOR0CNTRL_ATTNSELECT_SHIFT 10
253
254 /* get value */ #define GX_XF_GET_COLOR0CNTRL_ATTNSELECT(reg) GX_BITGET((reg), 21, 1)
255 /* set value */ #define GX_XF_SET_COLOR0CNTRL_ATTNSELECT(reg, x) ((reg) = GX_BITSET((reg), 21, 1, x))
256
257// LMASKHI [17:20] (4)
258 /* start bit */ #define GX_XF_COLOR0CNTRL_LMASKHI_B 17
259 /* end bit */ #define GX_XF_COLOR0CNTRL_LMASKHI_E 20
260 /* bit size */ #define GX_XF_COLOR0CNTRL_LMASKHI_SZ 4
261
262 /* raw mask */ #define GX_XF_COLOR0CNTRL_LMASKHI_MASK (((1 << 4) - 1) << 31 - 20)
263 /* local mask */ #define GX_XF_COLOR0CNTRL_LMASKHI_LMASK ((1 << 4) - 1)
264 /* bit shift */ #define GX_XF_COLOR0CNTRL_LMASKHI_SHIFT 11
265
266 /* get value */ #define GX_XF_GET_COLOR0CNTRL_LMASKHI(reg) GX_BITGET((reg), 17, 4)
267 /* set value */ #define GX_XF_SET_COLOR0CNTRL_LMASKHI(reg, x) ((reg) = GX_BITSET((reg), 17, 4, x))
268
269
270/******************************************************************************
271 * XF register 0x1018 - MatrixIndex0
272 *****************************************************************************/
273// GEOM [26:31] (6)
274 /* start bit */ #define GX_XF_MATRIXINDEX0_GEOM_B 26
275 /* end bit */ #define GX_XF_MATRIXINDEX0_GEOM_E 31
276 /* bit size */ #define GX_XF_MATRIXINDEX0_GEOM_SZ 6
277
278 /* raw mask */ #define GX_XF_MATRIXINDEX0_GEOM_MASK (((1 << 6) - 1) << 31 - 31)
279 /* local mask */ #define GX_XF_MATRIXINDEX0_GEOM_LMASK ((1 << 6) - 1)
280 /* bit shift */ #define GX_XF_MATRIXINDEX0_GEOM_SHIFT 0
281
282 /* get value */ #define GX_XF_GET_MATRIXINDEX0_GEOM(reg) GX_BITGET((reg), 26, 6)
283 /* set value */ #define GX_XF_SET_MATRIXINDEX0_GEOM(reg, x) ((reg) = GX_BITSET((reg), 26, 6, x))
284
285// TEX0 [20:25] (6)
286 /* start bit */ #define GX_XF_MATRIXINDEX0_TEX0_B 20
287 /* end bit */ #define GX_XF_MATRIXINDEX0_TEX0_E 25
288 /* bit size */ #define GX_XF_MATRIXINDEX0_TEX0_SZ 6
289
290 /* raw mask */ #define GX_XF_MATRIXINDEX0_TEX0_MASK (((1 << 6) - 1) << 31 - 25)
291 /* local mask */ #define GX_XF_MATRIXINDEX0_TEX0_LMASK ((1 << 6) - 1)
292 /* bit shift */ #define GX_XF_MATRIXINDEX0_TEX0_SHIFT 6
293
294 /* get value */ #define GX_XF_GET_MATRIXINDEX0_TEX0(reg) GX_BITGET((reg), 20, 6)
295 /* set value */ #define GX_XF_SET_MATRIXINDEX0_TEX0(reg, x) ((reg) = GX_BITSET((reg), 20, 6, x))
296
297// TEX1 [14:19] (6)
298 /* start bit */ #define GX_XF_MATRIXINDEX0_TEX1_B 14
299 /* end bit */ #define GX_XF_MATRIXINDEX0_TEX1_E 19
300 /* bit size */ #define GX_XF_MATRIXINDEX0_TEX1_SZ 6
301
302 /* raw mask */ #define GX_XF_MATRIXINDEX0_TEX1_MASK (((1 << 6) - 1) << 31 - 19)
303 /* local mask */ #define GX_XF_MATRIXINDEX0_TEX1_LMASK ((1 << 6) - 1)
304 /* bit shift */ #define GX_XF_MATRIXINDEX0_TEX1_SHIFT 12
305
306 /* get value */ #define GX_XF_GET_MATRIXINDEX0_TEX1(reg) GX_BITGET((reg), 14, 6)
307 /* set value */ #define GX_XF_SET_MATRIXINDEX0_TEX1(reg, x) ((reg) = GX_BITSET((reg), 14, 6, x))
308
309// TEX2 [8:13] (6)
310 /* start bit */ #define GX_XF_MATRIXINDEX0_TEX2_B 8
311 /* end bit */ #define GX_XF_MATRIXINDEX0_TEX2_E 13
312 /* bit size */ #define GX_XF_MATRIXINDEX0_TEX2_SZ 6
313
314 /* raw mask */ #define GX_XF_MATRIXINDEX0_TEX2_MASK (((1 << 6) - 1) << 31 - 13)
315 /* local mask */ #define GX_XF_MATRIXINDEX0_TEX2_LMASK ((1 << 6) - 1)
316 /* bit shift */ #define GX_XF_MATRIXINDEX0_TEX2_SHIFT 18
317
318 /* get value */ #define GX_XF_GET_MATRIXINDEX0_TEX2(reg) GX_BITGET((reg), 8, 6)
319 /* set value */ #define GX_XF_SET_MATRIXINDEX0_TEX2(reg, x) ((reg) = GX_BITSET((reg), 8, 6, x))
320
321// TEX3 [2:7] (6)
322 /* start bit */ #define GX_XF_MATRIXINDEX0_TEX3_B 2
323 /* end bit */ #define GX_XF_MATRIXINDEX0_TEX3_E 7
324 /* bit size */ #define GX_XF_MATRIXINDEX0_TEX3_SZ 6
325
326 /* raw mask */ #define GX_XF_MATRIXINDEX0_TEX3_MASK (((1 << 6) - 1) << 31 - 7)
327 /* local mask */ #define GX_XF_MATRIXINDEX0_TEX3_LMASK ((1 << 6) - 1)
328 /* bit shift */ #define GX_XF_MATRIXINDEX0_TEX3_SHIFT 24
329
330 /* get value */ #define GX_XF_GET_MATRIXINDEX0_TEX3(reg) GX_BITGET((reg), 2, 6)
331 /* set value */ #define GX_XF_SET_MATRIXINDEX0_TEX3(reg, x) ((reg) = GX_BITSET((reg), 2, 6, x))
332
333
334/******************************************************************************
335 * XF register 0x1019 - MatrixIndex1
336 *****************************************************************************/
337// TEX4 [26:31] (6)
338 /* start bit */ #define GX_XF_MATRIXINDEX1_TEX4_B 26
339 /* end bit */ #define GX_XF_MATRIXINDEX1_TEX4_E 31
340 /* bit size */ #define GX_XF_MATRIXINDEX1_TEX4_SZ 6
341
342 /* raw mask */ #define GX_XF_MATRIXINDEX1_TEX4_MASK (((1 << 6) - 1) << 31 - 31)
343 /* local mask */ #define GX_XF_MATRIXINDEX1_TEX4_LMASK ((1 << 6) - 1)
344 /* bit shift */ #define GX_XF_MATRIXINDEX1_TEX4_SHIFT 0
345
346 /* get value */ #define GX_XF_GET_MATRIXINDEX1_TEX4(reg) GX_BITGET((reg), 26, 6)
347 /* set value */ #define GX_XF_SET_MATRIXINDEX1_TEX4(reg, x) ((reg) = GX_BITSET((reg), 26, 6, x))
348
349// TEX5 [20:25] (6)
350 /* start bit */ #define GX_XF_MATRIXINDEX1_TEX5_B 20
351 /* end bit */ #define GX_XF_MATRIXINDEX1_TEX5_E 25
352 /* bit size */ #define GX_XF_MATRIXINDEX1_TEX5_SZ 6
353
354 /* raw mask */ #define GX_XF_MATRIXINDEX1_TEX5_MASK (((1 << 6) - 1) << 31 - 25)
355 /* local mask */ #define GX_XF_MATRIXINDEX1_TEX5_LMASK ((1 << 6) - 1)
356 /* bit shift */ #define GX_XF_MATRIXINDEX1_TEX5_SHIFT 6
357
358 /* get value */ #define GX_XF_GET_MATRIXINDEX1_TEX5(reg) GX_BITGET((reg), 20, 6)
359 /* set value */ #define GX_XF_SET_MATRIXINDEX1_TEX5(reg, x) ((reg) = GX_BITSET((reg), 20, 6, x))
360
361// TEX6 [14:19] (6)
362 /* start bit */ #define GX_XF_MATRIXINDEX1_TEX6_B 14
363 /* end bit */ #define GX_XF_MATRIXINDEX1_TEX6_E 19
364 /* bit size */ #define GX_XF_MATRIXINDEX1_TEX6_SZ 6
365
366 /* raw mask */ #define GX_XF_MATRIXINDEX1_TEX6_MASK (((1 << 6) - 1) << 31 - 19)
367 /* local mask */ #define GX_XF_MATRIXINDEX1_TEX6_LMASK ((1 << 6) - 1)
368 /* bit shift */ #define GX_XF_MATRIXINDEX1_TEX6_SHIFT 12
369
370 /* get value */ #define GX_XF_GET_MATRIXINDEX1_TEX6(reg) GX_BITGET((reg), 14, 6)
371 /* set value */ #define GX_XF_SET_MATRIXINDEX1_TEX6(reg, x) ((reg) = GX_BITSET((reg), 14, 6, x))
372
373// TEX7 [8:13] (6)
374 /* start bit */ #define GX_XF_MATRIXINDEX1_TEX7_B 8
375 /* end bit */ #define GX_XF_MATRIXINDEX1_TEX7_E 13
376 /* bit size */ #define GX_XF_MATRIXINDEX1_TEX7_SZ 6
377
378 /* raw mask */ #define GX_XF_MATRIXINDEX1_TEX7_MASK (((1 << 6) - 1) << 31 - 13)
379 /* local mask */ #define GX_XF_MATRIXINDEX1_TEX7_LMASK ((1 << 6) - 1)
380 /* bit shift */ #define GX_XF_MATRIXINDEX1_TEX7_SHIFT 18
381
382 /* get value */ #define GX_XF_GET_MATRIXINDEX1_TEX7(reg) GX_BITGET((reg), 8, 6)
383 /* set value */ #define GX_XF_SET_MATRIXINDEX1_TEX7(reg, x) ((reg) = GX_BITSET((reg), 8, 6, x))
384
385
386/******************************************************************************
387 * XF structure - Tex
388 *****************************************************************************/
389// PROJTYPE [30:30] (1)
390 /* start bit */ #define GX_XF_TEX_PROJTYPE_B 30
391 /* end bit */ #define GX_XF_TEX_PROJTYPE_E 30
392 /* bit size */ #define GX_XF_TEX_PROJTYPE_SZ 1
393
394 /* raw mask */ #define GX_XF_TEX_PROJTYPE_MASK (((1 << 1) - 1) << 31 - 30)
395 /* local mask */ #define GX_XF_TEX_PROJTYPE_LMASK ((1 << 1) - 1)
396 /* bit shift */ #define GX_XF_TEX_PROJTYPE_SHIFT 1
397
398 /* get value */ #define GX_XF_GET_TEX_PROJTYPE(reg) GX_BITGET((reg), 30, 1)
399 /* set value */ #define GX_XF_SET_TEX_PROJTYPE(reg, x) ((reg) = GX_BITSET((reg), 30, 1, x))
400
401// INPUTFORM [29:29] (1)
402 /* start bit */ #define GX_XF_TEX_INPUTFORM_B 29
403 /* end bit */ #define GX_XF_TEX_INPUTFORM_E 29
404 /* bit size */ #define GX_XF_TEX_INPUTFORM_SZ 1
405
406 /* raw mask */ #define GX_XF_TEX_INPUTFORM_MASK (((1 << 1) - 1) << 31 - 29)
407 /* local mask */ #define GX_XF_TEX_INPUTFORM_LMASK ((1 << 1) - 1)
408 /* bit shift */ #define GX_XF_TEX_INPUTFORM_SHIFT 2
409
410 /* get value */ #define GX_XF_GET_TEX_INPUTFORM(reg) GX_BITGET((reg), 29, 1)
411 /* set value */ #define GX_XF_SET_TEX_INPUTFORM(reg, x) ((reg) = GX_BITSET((reg), 29, 1, x))
412
413// TEXGENTYPE [25:27] (3)
414 /* start bit */ #define GX_XF_TEX_TEXGENTYPE_B 25
415 /* end bit */ #define GX_XF_TEX_TEXGENTYPE_E 27
416 /* bit size */ #define GX_XF_TEX_TEXGENTYPE_SZ 3
417
418 /* raw mask */ #define GX_XF_TEX_TEXGENTYPE_MASK (((1 << 3) - 1) << 31 - 27)
419 /* local mask */ #define GX_XF_TEX_TEXGENTYPE_LMASK ((1 << 3) - 1)
420 /* bit shift */ #define GX_XF_TEX_TEXGENTYPE_SHIFT 4
421
422 /* get value */ #define GX_XF_GET_TEX_TEXGENTYPE(reg) GX_BITGET((reg), 25, 3)
423 /* set value */ #define GX_XF_SET_TEX_TEXGENTYPE(reg, x) ((reg) = GX_BITSET((reg), 25, 3, x))
424
425// SRCROW [20:24] (5)
426 /* start bit */ #define GX_XF_TEX_SRCROW_B 20
427 /* end bit */ #define GX_XF_TEX_SRCROW_E 24
428 /* bit size */ #define GX_XF_TEX_SRCROW_SZ 5
429
430 /* raw mask */ #define GX_XF_TEX_SRCROW_MASK (((1 << 5) - 1) << 31 - 24)
431 /* local mask */ #define GX_XF_TEX_SRCROW_LMASK ((1 << 5) - 1)
432 /* bit shift */ #define GX_XF_TEX_SRCROW_SHIFT 7
433
434 /* get value */ #define GX_XF_GET_TEX_SRCROW(reg) GX_BITGET((reg), 20, 5)
435 /* set value */ #define GX_XF_SET_TEX_SRCROW(reg, x) ((reg) = GX_BITSET((reg), 20, 5, x))
436
437// BUMPSRCTEX [17:19] (3)
438 /* start bit */ #define GX_XF_TEX_BUMPSRCTEX_B 17
439 /* end bit */ #define GX_XF_TEX_BUMPSRCTEX_E 19
440 /* bit size */ #define GX_XF_TEX_BUMPSRCTEX_SZ 3
441
442 /* raw mask */ #define GX_XF_TEX_BUMPSRCTEX_MASK (((1 << 3) - 1) << 31 - 19)
443 /* local mask */ #define GX_XF_TEX_BUMPSRCTEX_LMASK ((1 << 3) - 1)
444 /* bit shift */ #define GX_XF_TEX_BUMPSRCTEX_SHIFT 12
445
446 /* get value */ #define GX_XF_GET_TEX_BUMPSRCTEX(reg) GX_BITGET((reg), 17, 3)
447 /* set value */ #define GX_XF_SET_TEX_BUMPSRCTEX(reg, x) ((reg) = GX_BITSET((reg), 17, 3, x))
448
449// BUMPSRCLIGHT [14:16] (3)
450 /* start bit */ #define GX_XF_TEX_BUMPSRCLIGHT_B 14
451 /* end bit */ #define GX_XF_TEX_BUMPSRCLIGHT_E 16
452 /* bit size */ #define GX_XF_TEX_BUMPSRCLIGHT_SZ 3
453
454 /* raw mask */ #define GX_XF_TEX_BUMPSRCLIGHT_MASK (((1 << 3) - 1) << 31 - 16)
455 /* local mask */ #define GX_XF_TEX_BUMPSRCLIGHT_LMASK ((1 << 3) - 1)
456 /* bit shift */ #define GX_XF_TEX_BUMPSRCLIGHT_SHIFT 15
457
458 /* get value */ #define GX_XF_GET_TEX_BUMPSRCLIGHT(reg) GX_BITGET((reg), 14, 3)
459 /* set value */ #define GX_XF_SET_TEX_BUMPSRCLIGHT(reg, x) ((reg) = GX_BITSET((reg), 14, 3, x))
460
461
462/******************************************************************************
463 * XF structure - DualTex
464 *****************************************************************************/
465// BASEROW [26:31] (6) - Indicates which is the base row of the transform matrix
466 /* start bit */ #define GX_XF_DUALTEX_BASEROW_B 26
467 /* end bit */ #define GX_XF_DUALTEX_BASEROW_E 31
468 /* bit size */ #define GX_XF_DUALTEX_BASEROW_SZ 6
469
470 /* raw mask */ #define GX_XF_DUALTEX_BASEROW_MASK (((1 << 6) - 1) << 31 - 31)
471 /* local mask */ #define GX_XF_DUALTEX_BASEROW_LMASK ((1 << 6) - 1)
472 /* bit shift */ #define GX_XF_DUALTEX_BASEROW_SHIFT 0
473
474 /* get value */ #define GX_XF_GET_DUALTEX_BASEROW(reg) GX_BITGET((reg), 26, 6)
475 /* set value */ #define GX_XF_SET_DUALTEX_BASEROW(reg, x) ((reg) = GX_BITSET((reg), 26, 6, x))
476
477// NORMALIZE [23:23] (1) - Normalize texcoord before sending transform
478 /* start bit */ #define GX_XF_DUALTEX_NORMALIZE_B 23
479 /* end bit */ #define GX_XF_DUALTEX_NORMALIZE_E 23
480 /* bit size */ #define GX_XF_DUALTEX_NORMALIZE_SZ 1
481
482 /* raw mask */ #define GX_XF_DUALTEX_NORMALIZE_MASK (((1 << 1) - 1) << 31 - 23)
483 /* local mask */ #define GX_XF_DUALTEX_NORMALIZE_LMASK ((1 << 1) - 1)
484 /* bit shift */ #define GX_XF_DUALTEX_NORMALIZE_SHIFT 8
485
486 /* get value */ #define GX_XF_GET_DUALTEX_NORMALIZE(reg) GX_BITGET((reg), 23, 1)
487 /* set value */ #define GX_XF_SET_DUALTEX_NORMALIZE(reg, x) ((reg) = GX_BITSET((reg), 23, 1, x))
488
489
490
491#ifdef __cplusplus
492}
493#endif
494#endif