Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
riva_tbl.h
Go to the documentation of this file.
1  /***************************************************************************\
2 |* *|
3 |* Copyright 1993-1999 NVIDIA, Corporation. All rights reserved. *|
4 |* *|
5 |* NOTICE TO USER: The source code is copyrighted under U.S. and *|
6 |* international laws. Users and possessors of this source code are *|
7 |* hereby granted a nonexclusive, royalty-free copyright license to *|
8 |* use this code in individual and commercial software. *|
9 |* *|
10 |* Any use of this source code must include, in the user documenta- *|
11 |* tion and internal comments to the code, notices to the end user *|
12 |* as follows: *|
13 |* *|
14 |* Copyright 1993-1999 NVIDIA, Corporation. All rights reserved. *|
15 |* *|
16 |* NVIDIA, CORPORATION MAKES NO REPRESENTATION ABOUT THE SUITABILITY *|
17 |* OF THIS SOURCE CODE FOR ANY PURPOSE. IT IS PROVIDED "AS IS" *|
18 |* WITHOUT EXPRESS OR IMPLIED WARRANTY OF ANY KIND. NVIDIA, CORPOR- *|
19 |* ATION DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOURCE CODE, *|
20 |* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGE- *|
21 |* MENT, AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL *|
22 |* NVIDIA, CORPORATION BE LIABLE FOR ANY SPECIAL, INDIRECT, INCI- *|
23 |* DENTAL, OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RE- *|
24 |* SULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION *|
25 |* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF *|
26 |* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOURCE CODE. *|
27 |* *|
28 |* U.S. Government End Users. This source code is a "commercial *|
29 |* item," as that term is defined at 48 C.F.R. 2.101 (OCT 1995), *|
30 |* consisting of "commercial computer software" and "commercial *|
31 |* computer software documentation," as such terms are used in *|
32 |* 48 C.F.R. 12.212 (SEPT 1995) and is provided to the U.S. Govern- *|
33 |* ment only as a commercial end item. Consistent with 48 C.F.R. *|
34 |* 12.212 and 48 C.F.R. 227.7202-1 through 227.7202-4 (JUNE 1995), *|
35 |* all U.S. Government End Users acquire the source code with only *|
36 |* those rights set forth herein. *|
37 |* *|
38  \***************************************************************************/
39 
40 /*
41  * GPL licensing note -- nVidia is allowing a liberal interpretation of
42  * the documentation restriction above, to merely say that this nVidia's
43  * copyright and disclaimer should be included with all code derived
44  * from this source. -- Jeff Garzik <[email protected]>, 01/Nov/99
45  */
46 
47 /* $XFree86: xc/programs/Xserver/hw/xfree86/drivers/nv/riva_tbl.h,v 1.9 2002/01/30 01:35:03 mvojkovi Exp $ */
48 
49 
50 /*
51  * RIVA Fixed Functionality Init Tables.
52  */
53 static unsigned RivaTablePMC[][2] =
54 {
55  {0x00000050, 0x00000000},
56  {0x00000080, 0xFFFF00FF},
57  {0x00000080, 0xFFFFFFFF}
58 };
59 static unsigned RivaTablePTIMER[][2] =
60 {
61  {0x00000080, 0x00000008},
62  {0x00000084, 0x00000003},
63  {0x00000050, 0x00000000},
64  {0x00000040, 0xFFFFFFFF}
65 };
66 static unsigned RivaTableFIFO[][2] =
67 {
68  {0x00000000, 0x80000000},
69  {0x00000800, 0x80000001},
70  {0x00001000, 0x80000002},
71  {0x00001800, 0x80000010},
72  {0x00002000, 0x80000011},
73  {0x00002800, 0x80000012},
74  {0x00003000, 0x80000016},
75  {0x00003800, 0x80000013}
76 };
77 static unsigned nv3TablePFIFO[][2] =
78 {
79  {0x00000140, 0x00000000},
80  {0x00000480, 0x00000000},
81  {0x00000490, 0x00000000},
82  {0x00000494, 0x00000000},
83  {0x00000481, 0x00000000},
84  {0x00000084, 0x00000000},
85  {0x00000086, 0x00002000},
86  {0x00000085, 0x00002200},
87  {0x00000484, 0x00000000},
88  {0x0000049C, 0x00000000},
89  {0x00000104, 0x00000000},
90  {0x00000108, 0x00000000},
91  {0x00000100, 0x00000000},
92  {0x000004A0, 0x00000000},
93  {0x000004A4, 0x00000000},
94  {0x000004A8, 0x00000000},
95  {0x000004AC, 0x00000000},
96  {0x000004B0, 0x00000000},
97  {0x000004B4, 0x00000000},
98  {0x000004B8, 0x00000000},
99  {0x000004BC, 0x00000000},
100  {0x00000050, 0x00000000},
101  {0x00000040, 0xFFFFFFFF},
102  {0x00000480, 0x00000001},
103  {0x00000490, 0x00000001},
104  {0x00000140, 0x00000001}
105 };
106 static unsigned nv3TablePGRAPH[][2] =
107 {
108  {0x00000020, 0x1230001F},
109  {0x00000021, 0x10113000},
110  {0x00000022, 0x1131F101},
111  {0x00000023, 0x0100F531},
112  {0x00000060, 0x00000000},
113  {0x00000065, 0x00000000},
114  {0x00000068, 0x00000000},
115  {0x00000069, 0x00000000},
116  {0x0000006A, 0x00000000},
117  {0x0000006B, 0x00000000},
118  {0x0000006C, 0x00000000},
119  {0x0000006D, 0x00000000},
120  {0x0000006E, 0x00000000},
121  {0x0000006F, 0x00000000},
122  {0x000001A8, 0x00000000},
123  {0x00000440, 0xFFFFFFFF},
124  {0x00000480, 0x00000001},
125  {0x000001A0, 0x00000000},
126  {0x000001A2, 0x00000000},
127  {0x0000018A, 0xFFFFFFFF},
128  {0x00000190, 0x00000000},
129  {0x00000142, 0x00000000},
130  {0x00000154, 0x00000000},
131  {0x00000155, 0xFFFFFFFF},
132  {0x00000156, 0x00000000},
133  {0x00000157, 0xFFFFFFFF},
134  {0x00000064, 0x10010002},
135  {0x00000050, 0x00000000},
136  {0x00000051, 0x00000000},
137  {0x00000040, 0xFFFFFFFF},
138  {0x00000041, 0xFFFFFFFF},
139  {0x00000440, 0xFFFFFFFF},
140  {0x000001A9, 0x00000001}
141 };
142 static unsigned nv3TablePGRAPH_8BPP[][2] =
143 {
144  {0x000001AA, 0x00001111}
145 };
146 static unsigned nv3TablePGRAPH_15BPP[][2] =
147 {
148  {0x000001AA, 0x00002222}
149 };
150 static unsigned nv3TablePGRAPH_32BPP[][2] =
151 {
152  {0x000001AA, 0x00003333}
153 };
154 static unsigned nv3TablePRAMIN[][2] =
155 {
156  {0x00000500, 0x00010000},
157  {0x00000501, 0x007FFFFF},
158  {0x00000200, 0x80000000},
159  {0x00000201, 0x00C20341},
160  {0x00000204, 0x80000001},
161  {0x00000205, 0x00C50342},
162  {0x00000208, 0x80000002},
163  {0x00000209, 0x00C60343},
164  {0x0000020C, 0x80000003},
165  {0x0000020D, 0x00DC0348},
166  {0x00000210, 0x80000004},
167  {0x00000211, 0x00DC0349},
168  {0x00000214, 0x80000005},
169  {0x00000215, 0x00DC034A},
170  {0x00000218, 0x80000006},
171  {0x00000219, 0x00DC034B},
172  {0x00000240, 0x80000010},
173  {0x00000241, 0x00D10344},
174  {0x00000244, 0x80000011},
175  {0x00000245, 0x00D00345},
176  {0x00000248, 0x80000012},
177  {0x00000249, 0x00CC0346},
178  {0x0000024C, 0x80000013},
179  {0x0000024D, 0x00D70347},
180  {0x00000258, 0x80000016},
181  {0x00000259, 0x00CA034C},
182  {0x00000D05, 0x00000000},
183  {0x00000D06, 0x00000000},
184  {0x00000D07, 0x00000000},
185  {0x00000D09, 0x00000000},
186  {0x00000D0A, 0x00000000},
187  {0x00000D0B, 0x00000000},
188  {0x00000D0D, 0x00000000},
189  {0x00000D0E, 0x00000000},
190  {0x00000D0F, 0x00000000},
191  {0x00000D11, 0x00000000},
192  {0x00000D12, 0x00000000},
193  {0x00000D13, 0x00000000},
194  {0x00000D15, 0x00000000},
195  {0x00000D16, 0x00000000},
196  {0x00000D17, 0x00000000},
197  {0x00000D19, 0x00000000},
198  {0x00000D1A, 0x00000000},
199  {0x00000D1B, 0x00000000},
200  {0x00000D1D, 0x00000140},
201  {0x00000D1E, 0x00000000},
202  {0x00000D1F, 0x00000000},
203  {0x00000D20, 0x10100200},
204  {0x00000D21, 0x00000000},
205  {0x00000D22, 0x00000000},
206  {0x00000D23, 0x00000000},
207  {0x00000D24, 0x10210200},
208  {0x00000D25, 0x00000000},
209  {0x00000D26, 0x00000000},
210  {0x00000D27, 0x00000000},
211  {0x00000D28, 0x10420200},
212  {0x00000D29, 0x00000000},
213  {0x00000D2A, 0x00000000},
214  {0x00000D2B, 0x00000000},
215  {0x00000D2C, 0x10830200},
216  {0x00000D2D, 0x00000000},
217  {0x00000D2E, 0x00000000},
218  {0x00000D2F, 0x00000000},
219  {0x00000D31, 0x00000000},
220  {0x00000D32, 0x00000000},
221  {0x00000D33, 0x00000000}
222 };
223 static unsigned nv3TablePRAMIN_8BPP[][2] =
224 {
225  /* 0xXXXXX3XX For MSB mono format */
226  /* 0xXXXXX2XX For LSB mono format */
227  {0x00000D04, 0x10110203},
228  {0x00000D08, 0x10110203},
229  {0x00000D0C, 0x1011020B},
230  {0x00000D10, 0x10118203},
231  {0x00000D14, 0x10110203},
232  {0x00000D18, 0x10110203},
233  {0x00000D1C, 0x10419208},
234  {0x00000D30, 0x10118203}
235 };
236 static unsigned nv3TablePRAMIN_15BPP[][2] =
237 {
238  /* 0xXXXXX2XX For MSB mono format */
239  /* 0xXXXXX3XX For LSB mono format */
240  {0x00000D04, 0x10110200},
241  {0x00000D08, 0x10110200},
242  {0x00000D0C, 0x10110208},
243  {0x00000D10, 0x10118200},
244  {0x00000D14, 0x10110200},
245  {0x00000D18, 0x10110200},
246  {0x00000D1C, 0x10419208},
247  {0x00000D30, 0x10118200}
248 };
249 static unsigned nv3TablePRAMIN_32BPP[][2] =
250 {
251  /* 0xXXXXX3XX For MSB mono format */
252  /* 0xXXXXX2XX For LSB mono format */
253  {0x00000D04, 0x10110201},
254  {0x00000D08, 0x10110201},
255  {0x00000D0C, 0x10110209},
256  {0x00000D10, 0x10118201},
257  {0x00000D14, 0x10110201},
258  {0x00000D18, 0x10110201},
259  {0x00000D1C, 0x10419208},
260  {0x00000D30, 0x10118201}
261 };
262 static unsigned nv4TableFIFO[][2] =
263 {
264  {0x00003800, 0x80000014}
265 };
266 static unsigned nv4TablePFIFO[][2] =
267 {
268  {0x00000140, 0x00000000},
269  {0x00000480, 0x00000000},
270  {0x00000494, 0x00000000},
271  {0x00000481, 0x00000000},
272  {0x0000048B, 0x00000000},
273  {0x00000400, 0x00000000},
274  {0x00000414, 0x00000000},
275  {0x00000084, 0x03000100},
276  {0x00000085, 0x00000110},
277  {0x00000086, 0x00000112},
278  {0x00000143, 0x0000FFFF},
279  {0x00000496, 0x0000FFFF},
280  {0x00000050, 0x00000000},
281  {0x00000040, 0xFFFFFFFF},
282  {0x00000415, 0x00000001},
283  {0x00000480, 0x00000001},
284  {0x00000494, 0x00000001},
285  {0x00000495, 0x00000001},
286  {0x00000140, 0x00000001}
287 };
288 static unsigned nv4TablePGRAPH[][2] =
289 {
290  {0x00000020, 0x1231C001},
291  {0x00000021, 0x72111101},
292  {0x00000022, 0x11D5F071},
293  {0x00000023, 0x10D4FF31},
294  {0x00000060, 0x00000000},
295  {0x00000068, 0x00000000},
296  {0x00000070, 0x00000000},
297  {0x00000078, 0x00000000},
298  {0x00000061, 0x00000000},
299  {0x00000069, 0x00000000},
300  {0x00000071, 0x00000000},
301  {0x00000079, 0x00000000},
302  {0x00000062, 0x00000000},
303  {0x0000006A, 0x00000000},
304  {0x00000072, 0x00000000},
305  {0x0000007A, 0x00000000},
306  {0x00000063, 0x00000000},
307  {0x0000006B, 0x00000000},
308  {0x00000073, 0x00000000},
309  {0x0000007B, 0x00000000},
310  {0x00000064, 0x00000000},
311  {0x0000006C, 0x00000000},
312  {0x00000074, 0x00000000},
313  {0x0000007C, 0x00000000},
314  {0x00000065, 0x00000000},
315  {0x0000006D, 0x00000000},
316  {0x00000075, 0x00000000},
317  {0x0000007D, 0x00000000},
318  {0x00000066, 0x00000000},
319  {0x0000006E, 0x00000000},
320  {0x00000076, 0x00000000},
321  {0x0000007E, 0x00000000},
322  {0x00000067, 0x00000000},
323  {0x0000006F, 0x00000000},
324  {0x00000077, 0x00000000},
325  {0x0000007F, 0x00000000},
326  {0x00000058, 0x00000000},
327  {0x00000059, 0x00000000},
328  {0x0000005A, 0x00000000},
329  {0x0000005B, 0x00000000},
330  {0x00000196, 0x00000000},
331  {0x000001A1, 0x01FFFFFF},
332  {0x00000197, 0x00000000},
333  {0x000001A2, 0x01FFFFFF},
334  {0x00000198, 0x00000000},
335  {0x000001A3, 0x01FFFFFF},
336  {0x00000199, 0x00000000},
337  {0x000001A4, 0x01FFFFFF},
338  {0x00000050, 0x00000000},
339  {0x00000040, 0xFFFFFFFF},
340  {0x0000005C, 0x10010100},
341  {0x000001C4, 0xFFFFFFFF},
342  {0x000001C8, 0x00000001},
343  {0x00000204, 0x00000000},
344  {0x000001C3, 0x00000001}
345 };
346 static unsigned nv4TablePGRAPH_8BPP[][2] =
347 {
348  {0x000001C9, 0x00111111},
349  {0x00000186, 0x00001010},
350  {0x0000020C, 0x03020202}
351 };
352 static unsigned nv4TablePGRAPH_15BPP[][2] =
353 {
354  {0x000001C9, 0x00226222},
355  {0x00000186, 0x00002071},
356  {0x0000020C, 0x09080808}
357 };
358 static unsigned nv4TablePGRAPH_16BPP[][2] =
359 {
360  {0x000001C9, 0x00556555},
361  {0x00000186, 0x000050C2},
362  {0x0000020C, 0x0C0B0B0B}
363 };
364 static unsigned nv4TablePGRAPH_32BPP[][2] =
365 {
366  {0x000001C9, 0x0077D777},
367  {0x00000186, 0x000070E5},
368  {0x0000020C, 0x0E0D0D0D}
369 };
370 static unsigned nv4TablePRAMIN[][2] =
371 {
372  {0x00000000, 0x80000010},
373  {0x00000001, 0x80011145},
374  {0x00000002, 0x80000011},
375  {0x00000003, 0x80011146},
376  {0x00000004, 0x80000012},
377  {0x00000005, 0x80011147},
378  {0x00000006, 0x80000013},
379  {0x00000007, 0x80011148},
380  {0x00000008, 0x80000014},
381  {0x00000009, 0x80011149},
382  {0x0000000A, 0x80000015},
383  {0x0000000B, 0x8001114A},
384  {0x0000000C, 0x80000016},
385  {0x0000000D, 0x8001114F},
386  {0x00000020, 0x80000000},
387  {0x00000021, 0x80011142},
388  {0x00000022, 0x80000001},
389  {0x00000023, 0x80011143},
390  {0x00000024, 0x80000002},
391  {0x00000025, 0x80011144},
392  {0x00000026, 0x80000003},
393  {0x00000027, 0x8001114B},
394  {0x00000028, 0x80000004},
395  {0x00000029, 0x8001114C},
396  {0x0000002A, 0x80000005},
397  {0x0000002B, 0x8001114D},
398  {0x0000002C, 0x80000006},
399  {0x0000002D, 0x8001114E},
400  {0x00000500, 0x00003000},
401  {0x00000501, 0x01FFFFFF},
402  {0x00000502, 0x00000002},
403  {0x00000503, 0x00000002},
404  {0x00000508, 0x01008043},
405  {0x0000050A, 0x00000000},
406  {0x0000050B, 0x00000000},
407  {0x0000050C, 0x01008019},
408  {0x0000050E, 0x00000000},
409  {0x0000050F, 0x00000000},
410 #if 1
411  {0x00000510, 0x01008018},
412 #else
413  {0x00000510, 0x01008044},
414 #endif
415  {0x00000512, 0x00000000},
416  {0x00000513, 0x00000000},
417  {0x00000514, 0x01008021},
418  {0x00000516, 0x00000000},
419  {0x00000517, 0x00000000},
420  {0x00000518, 0x0100805F},
421  {0x0000051A, 0x00000000},
422  {0x0000051B, 0x00000000},
423 #if 1
424  {0x0000051C, 0x0100804B},
425 #else
426  {0x0000051C, 0x0100804A},
427 #endif
428  {0x0000051E, 0x00000000},
429  {0x0000051F, 0x00000000},
430  {0x00000520, 0x0100A048},
431  {0x00000521, 0x00000D01},
432  {0x00000522, 0x11401140},
433  {0x00000523, 0x00000000},
434  {0x00000524, 0x0300A054},
435  {0x00000525, 0x00000D01},
436  {0x00000526, 0x11401140},
437  {0x00000527, 0x00000000},
438  {0x00000528, 0x0300A055},
439  {0x00000529, 0x00000D01},
440  {0x0000052A, 0x11401140},
441  {0x0000052B, 0x00000000},
442  {0x0000052C, 0x00000058},
443  {0x0000052E, 0x11401140},
444  {0x0000052F, 0x00000000},
445  {0x00000530, 0x00000059},
446  {0x00000532, 0x11401140},
447  {0x00000533, 0x00000000},
448  {0x00000534, 0x0000005A},
449  {0x00000536, 0x11401140},
450  {0x00000537, 0x00000000},
451  {0x00000538, 0x0000005B},
452  {0x0000053A, 0x11401140},
453  {0x0000053B, 0x00000000},
454  {0x0000053C, 0x0300A01C},
455  {0x0000053E, 0x11401140},
456  {0x0000053F, 0x00000000}
457 };
458 static unsigned nv4TablePRAMIN_8BPP[][2] =
459 {
460  /* 0xXXXXXX01 For MSB mono format */
461  /* 0xXXXXXX02 For LSB mono format */
462  {0x00000509, 0x00000302},
463  {0x0000050D, 0x00000302},
464  {0x00000511, 0x00000202},
465  {0x00000515, 0x00000302},
466  {0x00000519, 0x00000302},
467  {0x0000051D, 0x00000302},
468  {0x0000052D, 0x00000302},
469  {0x0000052E, 0x00000302},
470  {0x00000535, 0x00000000},
471  {0x00000539, 0x00000000},
472  {0x0000053D, 0x00000302}
473 };
474 static unsigned nv4TablePRAMIN_15BPP[][2] =
475 {
476  /* 0xXXXXXX01 For MSB mono format */
477  /* 0xXXXXXX02 For LSB mono format */
478  {0x00000509, 0x00000902},
479  {0x0000050D, 0x00000902},
480  {0x00000511, 0x00000802},
481  {0x00000515, 0x00000902},
482  {0x00000519, 0x00000902},
483  {0x0000051D, 0x00000902},
484  {0x0000052D, 0x00000902},
485  {0x0000052E, 0x00000902},
486  {0x00000535, 0x00000702},
487  {0x00000539, 0x00000702},
488  {0x0000053D, 0x00000902}
489 };
490 static unsigned nv4TablePRAMIN_16BPP[][2] =
491 {
492  /* 0xXXXXXX01 For MSB mono format */
493  /* 0xXXXXXX02 For LSB mono format */
494  {0x00000509, 0x00000C02},
495  {0x0000050D, 0x00000C02},
496  {0x00000511, 0x00000B02},
497  {0x00000515, 0x00000C02},
498  {0x00000519, 0x00000C02},
499  {0x0000051D, 0x00000C02},
500  {0x0000052D, 0x00000C02},
501  {0x0000052E, 0x00000C02},
502  {0x00000535, 0x00000702},
503  {0x00000539, 0x00000702},
504  {0x0000053D, 0x00000C02}
505 };
506 static unsigned nv4TablePRAMIN_32BPP[][2] =
507 {
508  /* 0xXXXXXX01 For MSB mono format */
509  /* 0xXXXXXX02 For LSB mono format */
510  {0x00000509, 0x00000E02},
511  {0x0000050D, 0x00000E02},
512  {0x00000511, 0x00000D02},
513  {0x00000515, 0x00000E02},
514  {0x00000519, 0x00000E02},
515  {0x0000051D, 0x00000E02},
516  {0x0000052D, 0x00000E02},
517  {0x0000052E, 0x00000E02},
518  {0x00000535, 0x00000E02},
519  {0x00000539, 0x00000E02},
520  {0x0000053D, 0x00000E02}
521 };
522 static unsigned nv10TableFIFO[][2] =
523 {
524  {0x00003800, 0x80000014}
525 };
526 static unsigned nv10TablePFIFO[][2] =
527 {
528  {0x00000140, 0x00000000},
529  {0x00000480, 0x00000000},
530  {0x00000494, 0x00000000},
531  {0x00000481, 0x00000000},
532  {0x0000048B, 0x00000000},
533  {0x00000400, 0x00000000},
534  {0x00000414, 0x00000000},
535  {0x00000084, 0x03000100},
536  {0x00000085, 0x00000110},
537  {0x00000086, 0x00000112},
538  {0x00000143, 0x0000FFFF},
539  {0x00000496, 0x0000FFFF},
540  {0x00000050, 0x00000000},
541  {0x00000040, 0xFFFFFFFF},
542  {0x00000415, 0x00000001},
543  {0x00000480, 0x00000001},
544  {0x00000494, 0x00000001},
545  {0x00000495, 0x00000001},
546  {0x00000140, 0x00000001}
547 };
548 static unsigned nv10TablePGRAPH[][2] =
549 {
550  {0x00000020, 0x0003FFFF},
551  {0x00000021, 0x00118701},
552  {0x00000022, 0x24F82AD9},
553  {0x00000023, 0x55DE0030},
554  {0x00000020, 0x00000000},
555  {0x00000024, 0x00000000},
556  {0x00000058, 0x00000000},
557  {0x00000060, 0x00000000},
558  {0x00000068, 0x00000000},
559  {0x00000070, 0x00000000},
560  {0x00000078, 0x00000000},
561  {0x00000059, 0x00000000},
562  {0x00000061, 0x00000000},
563  {0x00000069, 0x00000000},
564  {0x00000071, 0x00000000},
565  {0x00000079, 0x00000000},
566  {0x0000005A, 0x00000000},
567  {0x00000062, 0x00000000},
568  {0x0000006A, 0x00000000},
569  {0x00000072, 0x00000000},
570  {0x0000007A, 0x00000000},
571  {0x0000005B, 0x00000000},
572  {0x00000063, 0x00000000},
573  {0x0000006B, 0x00000000},
574  {0x00000073, 0x00000000},
575  {0x0000007B, 0x00000000},
576  {0x0000005C, 0x00000000},
577  {0x00000064, 0x00000000},
578  {0x0000006C, 0x00000000},
579  {0x00000074, 0x00000000},
580  {0x0000007C, 0x00000000},
581  {0x0000005D, 0x00000000},
582  {0x00000065, 0x00000000},
583  {0x0000006D, 0x00000000},
584  {0x00000075, 0x00000000},
585  {0x0000007D, 0x00000000},
586  {0x0000005E, 0x00000000},
587  {0x00000066, 0x00000000},
588  {0x0000006E, 0x00000000},
589  {0x00000076, 0x00000000},
590  {0x0000007E, 0x00000000},
591  {0x0000005F, 0x00000000},
592  {0x00000067, 0x00000000},
593  {0x0000006F, 0x00000000},
594  {0x00000077, 0x00000000},
595  {0x0000007F, 0x00000000},
596  {0x00000053, 0x00000000},
597  {0x00000054, 0x00000000},
598  {0x00000055, 0x00000000},
599  {0x00000056, 0x00000000},
600  {0x00000057, 0x00000000},
601  {0x00000196, 0x00000000},
602  {0x000001A1, 0x01FFFFFF},
603  {0x00000197, 0x00000000},
604  {0x000001A2, 0x01FFFFFF},
605  {0x00000198, 0x00000000},
606  {0x000001A3, 0x01FFFFFF},
607  {0x00000199, 0x00000000},
608  {0x000001A4, 0x01FFFFFF},
609  {0x0000019A, 0x00000000},
610  {0x000001A5, 0x01FFFFFF},
611  {0x0000019B, 0x00000000},
612  {0x000001A6, 0x01FFFFFF},
613  {0x00000050, 0x01111111},
614  {0x00000040, 0xFFFFFFFF},
615  {0x00000051, 0x10010100},
616  {0x000001C5, 0xFFFFFFFF},
617  {0x000001C8, 0x00000001},
618  {0x00000204, 0x00000000},
619  {0x000001C4, 0x00000001}
620 };
621 static unsigned nv10TablePGRAPH_8BPP[][2] =
622 {
623  {0x000001C9, 0x00111111},
624  {0x00000186, 0x00001010},
625  {0x0000020C, 0x03020202}
626 };
627 static unsigned nv10TablePGRAPH_15BPP[][2] =
628 {
629  {0x000001C9, 0x00226222},
630  {0x00000186, 0x00002071},
631  {0x0000020C, 0x09080808}
632 };
633 static unsigned nv10TablePGRAPH_16BPP[][2] =
634 {
635  {0x000001C9, 0x00556555},
636  {0x00000186, 0x000050C2},
637  {0x0000020C, 0x000B0B0C}
638 };
639 static unsigned nv10TablePGRAPH_32BPP[][2] =
640 {
641  {0x000001C9, 0x0077D777},
642  {0x00000186, 0x000070E5},
643  {0x0000020C, 0x0E0D0D0D}
644 };
645 static unsigned nv10tri05TablePGRAPH[][2] =
646 {
647  {(0x00000E00/4), 0x00000000},
648  {(0x00000E04/4), 0x00000000},
649  {(0x00000E08/4), 0x00000000},
650  {(0x00000E0C/4), 0x00000000},
651  {(0x00000E10/4), 0x00001000},
652  {(0x00000E14/4), 0x00001000},
653  {(0x00000E18/4), 0x4003ff80},
654  {(0x00000E1C/4), 0x00000000},
655  {(0x00000E20/4), 0x00000000},
656  {(0x00000E24/4), 0x00000000},
657  {(0x00000E28/4), 0x00000000},
658  {(0x00000E2C/4), 0x00000000},
659  {(0x00000E30/4), 0x00080008},
660  {(0x00000E34/4), 0x00080008},
661  {(0x00000E38/4), 0x00000000},
662  {(0x00000E3C/4), 0x00000000},
663  {(0x00000E40/4), 0x00000000},
664  {(0x00000E44/4), 0x00000000},
665  {(0x00000E48/4), 0x00000000},
666  {(0x00000E4C/4), 0x00000000},
667  {(0x00000E50/4), 0x00000000},
668  {(0x00000E54/4), 0x00000000},
669  {(0x00000E58/4), 0x00000000},
670  {(0x00000E5C/4), 0x00000000},
671  {(0x00000E60/4), 0x00000000},
672  {(0x00000E64/4), 0x10000000},
673  {(0x00000E68/4), 0x00000000},
674  {(0x00000E6C/4), 0x00000000},
675  {(0x00000E70/4), 0x00000000},
676  {(0x00000E74/4), 0x00000000},
677  {(0x00000E78/4), 0x00000000},
678  {(0x00000E7C/4), 0x00000000},
679  {(0x00000E80/4), 0x00000000},
680  {(0x00000E84/4), 0x00000000},
681  {(0x00000E88/4), 0x08000000},
682  {(0x00000E8C/4), 0x00000000},
683  {(0x00000E90/4), 0x00000000},
684  {(0x00000E94/4), 0x00000000},
685  {(0x00000E98/4), 0x00000000},
686  {(0x00000E9C/4), 0x4B7FFFFF},
687  {(0x00000EA0/4), 0x00000000},
688  {(0x00000EA4/4), 0x00000000},
689  {(0x00000EA8/4), 0x00000000},
690  {(0x00000F00/4), 0x07FF0800},
691  {(0x00000F04/4), 0x07FF0800},
692  {(0x00000F08/4), 0x07FF0800},
693  {(0x00000F0C/4), 0x07FF0800},
694  {(0x00000F10/4), 0x07FF0800},
695  {(0x00000F14/4), 0x07FF0800},
696  {(0x00000F18/4), 0x07FF0800},
697  {(0x00000F1C/4), 0x07FF0800},
698  {(0x00000F20/4), 0x07FF0800},
699  {(0x00000F24/4), 0x07FF0800},
700  {(0x00000F28/4), 0x07FF0800},
701  {(0x00000F2C/4), 0x07FF0800},
702  {(0x00000F30/4), 0x07FF0800},
703  {(0x00000F34/4), 0x07FF0800},
704  {(0x00000F38/4), 0x07FF0800},
705  {(0x00000F3C/4), 0x07FF0800},
706  {(0x00000F40/4), 0x10000000},
707  {(0x00000F44/4), 0x00000000},
708  {(0x00000F50/4), 0x00006740},
709  {(0x00000F54/4), 0x00000000},
710  {(0x00000F54/4), 0x00000000},
711  {(0x00000F54/4), 0x00000000},
712  {(0x00000F54/4), 0x3F800000},
713  {(0x00000F50/4), 0x00006750},
714  {(0x00000F54/4), 0x40000000},
715  {(0x00000F54/4), 0x40000000},
716  {(0x00000F54/4), 0x40000000},
717  {(0x00000F54/4), 0x40000000},
718  {(0x00000F50/4), 0x00006760},
719  {(0x00000F54/4), 0x00000000},
720  {(0x00000F54/4), 0x00000000},
721  {(0x00000F54/4), 0x3F800000},
722  {(0x00000F54/4), 0x00000000},
723  {(0x00000F50/4), 0x00006770},
724  {(0x00000F54/4), 0xC5000000},
725  {(0x00000F54/4), 0xC5000000},
726  {(0x00000F54/4), 0x00000000},
727  {(0x00000F54/4), 0x00000000},
728  {(0x00000F50/4), 0x00006780},
729  {(0x00000F54/4), 0x00000000},
730  {(0x00000F54/4), 0x00000000},
731  {(0x00000F54/4), 0x3F800000},
732  {(0x00000F54/4), 0x00000000},
733  {(0x00000F50/4), 0x000067A0},
734  {(0x00000F54/4), 0x3F800000},
735  {(0x00000F54/4), 0x3F800000},
736  {(0x00000F54/4), 0x3F800000},
737  {(0x00000F54/4), 0x3F800000},
738  {(0x00000F50/4), 0x00006AB0},
739  {(0x00000F54/4), 0x3F800000},
740  {(0x00000F54/4), 0x3F800000},
741  {(0x00000F54/4), 0x3F800000},
742  {(0x00000F50/4), 0x00006AC0},
743  {(0x00000F54/4), 0x00000000},
744  {(0x00000F54/4), 0x00000000},
745  {(0x00000F54/4), 0x00000000},
746  {(0x00000F50/4), 0x00006C10},
747  {(0x00000F54/4), 0xBF800000},
748  {(0x00000F50/4), 0x00007030},
749  {(0x00000F54/4), 0x7149F2CA},
750  {(0x00000F50/4), 0x00007040},
751  {(0x00000F54/4), 0x7149F2CA},
752  {(0x00000F50/4), 0x00007050},
753  {(0x00000F54/4), 0x7149F2CA},
754  {(0x00000F50/4), 0x00007060},
755  {(0x00000F54/4), 0x7149F2CA},
756  {(0x00000F50/4), 0x00007070},
757  {(0x00000F54/4), 0x7149F2CA},
758  {(0x00000F50/4), 0x00007080},
759  {(0x00000F54/4), 0x7149F2CA},
760  {(0x00000F50/4), 0x00007090},
761  {(0x00000F54/4), 0x7149F2CA},
762  {(0x00000F50/4), 0x000070A0},
763  {(0x00000F54/4), 0x7149F2CA},
764  {(0x00000F50/4), 0x00006A80},
765  {(0x00000F54/4), 0x00000000},
766  {(0x00000F54/4), 0x00000000},
767  {(0x00000F54/4), 0x3F800000},
768  {(0x00000F50/4), 0x00006AA0},
769  {(0x00000F54/4), 0x00000000},
770  {(0x00000F54/4), 0x00000000},
771  {(0x00000F54/4), 0x00000000},
772  {(0x00000F50/4), 0x00000040},
773  {(0x00000F54/4), 0x00000005},
774  {(0x00000F50/4), 0x00006400},
775  {(0x00000F54/4), 0x3F800000},
776  {(0x00000F54/4), 0x3F800000},
777  {(0x00000F54/4), 0x4B7FFFFF},
778  {(0x00000F54/4), 0x00000000},
779  {(0x00000F50/4), 0x00006410},
780  {(0x00000F54/4), 0xC5000000},
781  {(0x00000F54/4), 0xC5000000},
782  {(0x00000F54/4), 0x00000000},
783  {(0x00000F54/4), 0x00000000},
784  {(0x00000F50/4), 0x00006420},
785  {(0x00000F54/4), 0x00000000},
786  {(0x00000F54/4), 0x00000000},
787  {(0x00000F54/4), 0x00000000},
788  {(0x00000F54/4), 0x00000000},
789  {(0x00000F50/4), 0x00006430},
790  {(0x00000F54/4), 0x00000000},
791  {(0x00000F54/4), 0x00000000},
792  {(0x00000F54/4), 0x00000000},
793  {(0x00000F54/4), 0x00000000},
794  {(0x00000F50/4), 0x000064C0},
795  {(0x00000F54/4), 0x3F800000},
796  {(0x00000F54/4), 0x3F800000},
797  {(0x00000F54/4), 0x477FFFFF},
798  {(0x00000F54/4), 0x3F800000},
799  {(0x00000F50/4), 0x000064D0},
800  {(0x00000F54/4), 0xC5000000},
801  {(0x00000F54/4), 0xC5000000},
802  {(0x00000F54/4), 0x00000000},
803  {(0x00000F54/4), 0x00000000},
804  {(0x00000F50/4), 0x000064E0},
805  {(0x00000F54/4), 0xC4FFF000},
806  {(0x00000F54/4), 0xC4FFF000},
807  {(0x00000F54/4), 0x00000000},
808  {(0x00000F54/4), 0x00000000},
809  {(0x00000F50/4), 0x000064F0},
810  {(0x00000F54/4), 0x00000000},
811  {(0x00000F54/4), 0x00000000},
812  {(0x00000F54/4), 0x00000000},
813  {(0x00000F54/4), 0x00000000},
814  {(0x00000F40/4), 0x30000000},
815  {(0x00000F44/4), 0x00000004},
816  {(0x00000F48/4), 0x10000000},
817  {(0x00000F4C/4), 0x00000000}
818 };
819 static unsigned nv10TablePRAMIN[][2] =
820 {
821  {0x00000000, 0x80000010},
822  {0x00000001, 0x80011145},
823  {0x00000002, 0x80000011},
824  {0x00000003, 0x80011146},
825  {0x00000004, 0x80000012},
826  {0x00000005, 0x80011147},
827  {0x00000006, 0x80000013},
828  {0x00000007, 0x80011148},
829  {0x00000008, 0x80000014},
830  {0x00000009, 0x80011149},
831  {0x0000000A, 0x80000015},
832  {0x0000000B, 0x8001114A},
833  {0x0000000C, 0x80000016},
834  {0x0000000D, 0x80011150},
835  {0x00000020, 0x80000000},
836  {0x00000021, 0x80011142},
837  {0x00000022, 0x80000001},
838  {0x00000023, 0x80011143},
839  {0x00000024, 0x80000002},
840  {0x00000025, 0x80011144},
841  {0x00000026, 0x80000003},
842  {0x00000027, 0x8001114B},
843  {0x00000028, 0x80000004},
844  {0x00000029, 0x8001114C},
845  {0x0000002A, 0x80000005},
846  {0x0000002B, 0x8001114D},
847  {0x0000002C, 0x80000006},
848  {0x0000002D, 0x8001114E},
849  {0x0000002E, 0x80000007},
850  {0x0000002F, 0x8001114F},
851  {0x00000500, 0x00003000},
852  {0x00000501, 0x01FFFFFF},
853  {0x00000502, 0x00000002},
854  {0x00000503, 0x00000002},
855 #ifdef __BIG_ENDIAN
856  {0x00000508, 0x01088043},
857 #else
858  {0x00000508, 0x01008043},
859 #endif
860  {0x0000050A, 0x00000000},
861  {0x0000050B, 0x00000000},
862 #ifdef __BIG_ENDIAN
863  {0x0000050C, 0x01088019},
864 #else
865  {0x0000050C, 0x01008019},
866 #endif
867  {0x0000050E, 0x00000000},
868  {0x0000050F, 0x00000000},
869 #ifdef __BIG_ENDIAN
870  {0x00000510, 0x01088018},
871 #else
872  {0x00000510, 0x01008018},
873 #endif
874  {0x00000512, 0x00000000},
875  {0x00000513, 0x00000000},
876 #ifdef __BIG_ENDIAN
877  {0x00000514, 0x01088021},
878 #else
879  {0x00000514, 0x01008021},
880 #endif
881  {0x00000516, 0x00000000},
882  {0x00000517, 0x00000000},
883 #ifdef __BIG_ENDIAN
884  {0x00000518, 0x0108805F},
885 #else
886  {0x00000518, 0x0100805F},
887 #endif
888  {0x0000051A, 0x00000000},
889  {0x0000051B, 0x00000000},
890 #ifdef __BIG_ENDIAN
891  {0x0000051C, 0x0108804B},
892 #else
893  {0x0000051C, 0x0100804B},
894 #endif
895  {0x0000051E, 0x00000000},
896  {0x0000051F, 0x00000000},
897  {0x00000520, 0x0100A048},
898  {0x00000521, 0x00000D01},
899  {0x00000522, 0x11401140},
900  {0x00000523, 0x00000000},
901  {0x00000524, 0x0300A094},
902  {0x00000525, 0x00000D01},
903  {0x00000526, 0x11401140},
904  {0x00000527, 0x00000000},
905  {0x00000528, 0x0300A095},
906  {0x00000529, 0x00000D01},
907  {0x0000052A, 0x11401140},
908  {0x0000052B, 0x00000000},
909 #ifdef __BIG_ENDIAN
910  {0x0000052C, 0x00080058},
911 #else
912  {0x0000052C, 0x00000058},
913 #endif
914  {0x0000052E, 0x11401140},
915  {0x0000052F, 0x00000000},
916 #ifdef __BIG_ENDIAN
917  {0x00000530, 0x00080059},
918 #else
919  {0x00000530, 0x00000059},
920 #endif
921  {0x00000532, 0x11401140},
922  {0x00000533, 0x00000000},
923  {0x00000534, 0x0000005A},
924  {0x00000536, 0x11401140},
925  {0x00000537, 0x00000000},
926  {0x00000538, 0x0000005B},
927  {0x0000053A, 0x11401140},
928  {0x0000053B, 0x00000000},
929  {0x0000053C, 0x00000093},
930  {0x0000053E, 0x11401140},
931  {0x0000053F, 0x00000000},
932 #ifdef __BIG_ENDIAN
933  {0x00000540, 0x0308A01C},
934 #else
935  {0x00000540, 0x0300A01C},
936 #endif
937  {0x00000542, 0x11401140},
938  {0x00000543, 0x00000000}
939 };
940 static unsigned nv10TablePRAMIN_8BPP[][2] =
941 {
942  /* 0xXXXXXX01 For MSB mono format */
943  /* 0xXXXXXX02 For LSB mono format */
944  {0x00000509, 0x00000302},
945  {0x0000050D, 0x00000302},
946  {0x00000511, 0x00000202},
947  {0x00000515, 0x00000302},
948  {0x00000519, 0x00000302},
949  {0x0000051D, 0x00000302},
950  {0x0000052D, 0x00000302},
951  {0x0000052E, 0x00000302},
952  {0x00000535, 0x00000000},
953  {0x00000539, 0x00000000},
954  {0x0000053D, 0x00000000},
955  {0x00000541, 0x00000302}
956 };
957 static unsigned nv10TablePRAMIN_15BPP[][2] =
958 {
959  /* 0xXXXXXX01 For MSB mono format */
960  /* 0xXXXXXX02 For LSB mono format */
961  {0x00000509, 0x00000902},
962  {0x0000050D, 0x00000902},
963  {0x00000511, 0x00000802},
964  {0x00000515, 0x00000902},
965  {0x00000519, 0x00000902},
966  {0x0000051D, 0x00000902},
967  {0x0000052D, 0x00000902},
968  {0x0000052E, 0x00000902},
969  {0x00000535, 0x00000902},
970  {0x00000539, 0x00000902},
971  {0x0000053D, 0x00000902},
972  {0x00000541, 0x00000902}
973 };
974 static unsigned nv10TablePRAMIN_16BPP[][2] =
975 {
976  /* 0xXXXXXX01 For MSB mono format */
977  /* 0xXXXXXX02 For LSB mono format */
978  {0x00000509, 0x00000C02},
979  {0x0000050D, 0x00000C02},
980  {0x00000511, 0x00000B02},
981  {0x00000515, 0x00000C02},
982  {0x00000519, 0x00000C02},
983  {0x0000051D, 0x00000C02},
984  {0x0000052D, 0x00000C02},
985  {0x0000052E, 0x00000C02},
986  {0x00000535, 0x00000C02},
987  {0x00000539, 0x00000C02},
988  {0x0000053D, 0x00000C02},
989  {0x00000541, 0x00000C02}
990 };
991 static unsigned nv10TablePRAMIN_32BPP[][2] =
992 {
993  /* 0xXXXXXX01 For MSB mono format */
994  /* 0xXXXXXX02 For LSB mono format */
995  {0x00000509, 0x00000E02},
996  {0x0000050D, 0x00000E02},
997  {0x00000511, 0x00000D02},
998  {0x00000515, 0x00000E02},
999  {0x00000519, 0x00000E02},
1000  {0x0000051D, 0x00000E02},
1001  {0x0000052D, 0x00000E02},
1002  {0x0000052E, 0x00000E02},
1003  {0x00000535, 0x00000E02},
1004  {0x00000539, 0x00000E02},
1005  {0x0000053D, 0x00000E02},
1006  {0x00000541, 0x00000E02}
1007 };
1008