Commit | Line | Data |
---|---|---|
d7636e0b | 1 | #ifndef _XGIFB_MAIN |
2 | #define _XGIFB_MAIN | |
3 | ||
4 | ||
5 | /* ------------------- Constant Definitions ------------------------- */ | |
6 | ||
7 | ||
8 | #include "XGIfb.h" | |
9 | #include "vb_struct.h" | |
10 | #include "vb_def.h" | |
11 | ||
14e43851 | 12 | #define XGIFAIL(x) do { printk(x "\n"); return -EINVAL; } while (0) |
d7636e0b | 13 | |
d7636e0b | 14 | #ifndef PCI_VENDOR_ID_XG |
15 | #define PCI_VENDOR_ID_XG 0x18CA | |
16 | #endif | |
17 | ||
18 | #ifndef PCI_DEVICE_ID_XG_40 | |
19 | #define PCI_DEVICE_ID_XG_40 0x040 | |
20 | #endif | |
21 | #ifndef PCI_DEVICE_ID_XG_41 | |
22 | #define PCI_DEVICE_ID_XG_41 0x041 | |
23 | #endif | |
24 | #ifndef PCI_DEVICE_ID_XG_42 | |
25 | #define PCI_DEVICE_ID_XG_42 0x042 | |
26 | #endif | |
27 | #ifndef PCI_DEVICE_ID_XG_20 | |
28 | #define PCI_DEVICE_ID_XG_20 0x020 | |
29 | #endif | |
30 | #ifndef PCI_DEVICE_ID_XG_27 | |
31 | #define PCI_DEVICE_ID_XG_27 0x027 | |
32 | #endif | |
33 | ||
b6cdc405 | 34 | static DEFINE_PCI_DEVICE_TABLE(xgifb_pci_table) = { |
27d73f1a PH |
35 | {PCI_DEVICE(PCI_VENDOR_ID_XG, PCI_DEVICE_ID_XG_20)}, |
36 | {PCI_DEVICE(PCI_VENDOR_ID_XG, PCI_DEVICE_ID_XG_27)}, | |
37 | {PCI_DEVICE(PCI_VENDOR_ID_XG, PCI_DEVICE_ID_XG_40)}, | |
38 | {PCI_DEVICE(PCI_VENDOR_ID_XG, PCI_DEVICE_ID_XG_42)}, | |
14e43851 | 39 | {0} |
d7636e0b | 40 | }; |
41 | ||
42 | MODULE_DEVICE_TABLE(pci, xgifb_pci_table); | |
23aada9c | 43 | |
d7636e0b | 44 | /* To be included in fb.h */ |
d7636e0b | 45 | #ifndef FB_ACCEL_XGI_XABRE |
46 | #define FB_ACCEL_XGI_XABRE 41 /* XGI 330 ("Xabre") */ | |
47 | #endif | |
48 | ||
d7636e0b | 49 | #define SEQ_DATA 0x15 |
d7636e0b | 50 | |
f2df8c09 AK |
51 | #define XGISR (xgifb_info->dev_info.P3c4) |
52 | #define XGICR (xgifb_info->dev_info.P3d4) | |
53 | #define XGIDACA (xgifb_info->dev_info.P3c8) | |
54 | #define XGIDACD (xgifb_info->dev_info.P3c9) | |
55 | #define XGIPART1 (xgifb_info->dev_info.Part1Port) | |
56 | #define XGIPART2 (xgifb_info->dev_info.Part2Port) | |
57 | #define XGIPART3 (xgifb_info->dev_info.Part3Port) | |
58 | #define XGIPART4 (xgifb_info->dev_info.Part4Port) | |
59 | #define XGIPART5 (xgifb_info->dev_info.Part5Port) | |
d7636e0b | 60 | #define XGIDAC2A XGIPART5 |
61 | #define XGIDAC2D (XGIPART5 + 1) | |
d7636e0b | 62 | |
63 | #define IND_XGI_PASSWORD 0x05 /* SRs */ | |
d7636e0b | 64 | #define IND_XGI_RAMDAC_CONTROL 0x07 |
65 | #define IND_XGI_DRAM_SIZE 0x14 | |
d7636e0b | 66 | #define IND_XGI_MODULE_ENABLE 0x1E |
67 | #define IND_XGI_PCI_ADDRESS_SET 0x20 | |
d7636e0b | 68 | |
69 | #define IND_XGI_SCRATCH_REG_CR30 0x30 /* CRs */ | |
70 | #define IND_XGI_SCRATCH_REG_CR31 0x31 | |
71 | #define IND_XGI_SCRATCH_REG_CR32 0x32 | |
72 | #define IND_XGI_SCRATCH_REG_CR33 0x33 | |
73 | #define IND_XGI_LCD_PANEL 0x36 | |
74 | #define IND_XGI_SCRATCH_REG_CR37 0x37 | |
d7636e0b | 75 | |
d7636e0b | 76 | #define IND_XGI_CRT2_WRITE_ENABLE_315 0x2F |
77 | ||
78 | #define XGI_PASSWORD 0x86 /* SR05 */ | |
d7636e0b | 79 | |
80 | #define XGI_DRAM_SIZE_MASK 0xF0 /*SR14 */ | |
81 | #define XGI_DRAM_SIZE_1MB 0x00 | |
82 | #define XGI_DRAM_SIZE_2MB 0x01 | |
83 | #define XGI_DRAM_SIZE_4MB 0x02 | |
84 | #define XGI_DRAM_SIZE_8MB 0x03 | |
85 | #define XGI_DRAM_SIZE_16MB 0x04 | |
86 | #define XGI_DRAM_SIZE_32MB 0x05 | |
87 | #define XGI_DRAM_SIZE_64MB 0x06 | |
88 | #define XGI_DRAM_SIZE_128MB 0x07 | |
89 | #define XGI_DRAM_SIZE_256MB 0x08 | |
d7636e0b | 90 | |
91 | #define XGI_ENABLE_2D 0x40 /* SR1E */ | |
92 | ||
93 | #define XGI_MEM_MAP_IO_ENABLE 0x01 /* SR20 */ | |
94 | #define XGI_PCI_ADDR_ENABLE 0x80 | |
95 | ||
d7636e0b | 96 | #define XGI_SIMULTANEOUS_VIEW_ENABLE 0x01 /* CR30 */ |
d7636e0b | 97 | #define XGI_VB_OUTPUT_COMPOSITE 0x04 |
98 | #define XGI_VB_OUTPUT_SVIDEO 0x08 | |
99 | #define XGI_VB_OUTPUT_SCART 0x10 | |
100 | #define XGI_VB_OUTPUT_LCD 0x20 | |
101 | #define XGI_VB_OUTPUT_CRT2 0x40 | |
102 | #define XGI_VB_OUTPUT_HIVISION 0x80 | |
103 | ||
104 | #define XGI_VB_OUTPUT_DISABLE 0x20 /* CR31 */ | |
105 | #define XGI_DRIVER_MODE 0x40 | |
106 | ||
107 | #define XGI_VB_COMPOSITE 0x01 /* CR32 */ | |
108 | #define XGI_VB_SVIDEO 0x02 | |
109 | #define XGI_VB_SCART 0x04 | |
110 | #define XGI_VB_LCD 0x08 | |
111 | #define XGI_VB_CRT2 0x10 | |
112 | #define XGI_CRT1 0x20 | |
113 | #define XGI_VB_HIVISION 0x40 | |
14e43851 KT |
114 | #define XGI_VB_YPBPR 0x80 |
115 | #define XGI_VB_TV (XGI_VB_COMPOSITE | XGI_VB_SVIDEO | \ | |
116 | XGI_VB_SCART | XGI_VB_HIVISION|XGI_VB_YPBPR) | |
d7636e0b | 117 | |
14e43851 | 118 | #define XGI_EXTERNAL_CHIP_MASK 0x0E /* CR37 */ |
d7636e0b | 119 | #define XGI310_EXTERNAL_CHIP_LVDS 0x02 /* in CR37 << 1 ! */ |
120 | #define XGI310_EXTERNAL_CHIP_LVDS_CHRONTEL 0x03 /* in CR37 << 1 ! */ | |
121 | ||
d7636e0b | 122 | /* ------------------- Global Variables ----------------------------- */ |
123 | ||
d7636e0b | 124 | /* display status */ |
44c4ec78 | 125 | static int XGIfb_crt1off; |
d7636e0b | 126 | static int XGIfb_forcecrt1 = -1; |
44c4ec78 | 127 | static int XGIfb_userom ; |
d7636e0b | 128 | |
129 | /* global flags */ | |
44c4ec78 | 130 | static int XGIfb_tvmode; |
44c4ec78 | 131 | static int enable_dstn; |
d7636e0b | 132 | static int XGIfb_ypan = -1; |
133 | ||
14e43851 KT |
134 | /* TW: CRT2 type (for overriding autodetection) */ |
135 | static int XGIfb_crt2type = -1; | |
136 | /* PR: Tv plug type (for overriding autodetection) */ | |
137 | static int XGIfb_tvplug = -1; | |
d7636e0b | 138 | |
d7636e0b | 139 | /* TW: For ioctl XGIFB_GET_INFO */ |
140 | /* XGIfb_info XGIfbinfo; */ | |
141 | ||
d7636e0b | 142 | #define MD_XGI300 1 |
143 | #define MD_XGI315 2 | |
144 | ||
145 | /* mode table */ | |
7d2ab0c6 | 146 | static const struct _XGIbios_mode { |
d7636e0b | 147 | char name[15]; |
148 | u8 mode_no; | |
149 | u16 vesa_mode_no_1; /* "XGI defined" VESA mode number */ | |
150 | u16 vesa_mode_no_2; /* Real VESA mode numbers */ | |
151 | u16 xres; | |
152 | u16 yres; | |
153 | u16 bpp; | |
154 | u16 rate_idx; | |
155 | u16 cols; | |
156 | u16 rows; | |
157 | u8 chipset; | |
158 | } XGIbios_mode[] = { | |
14e43851 KT |
159 | {"320x240x16", 0x56, 0x0000, 0x0000, 320, 240, 16, 1, 40, 15, |
160 | MD_XGI315}, | |
161 | {"320x480x8", 0x5A, 0x0000, 0x0000, 320, 480, 8, 1, 40, 30, | |
162 | MD_XGI315}, /* TW: FSTN */ | |
163 | {"320x480x16", 0x5B, 0x0000, 0x0000, 320, 480, 16, 1, 40, 30, | |
164 | MD_XGI315}, /* TW: FSTN */ | |
165 | {"640x480x8", 0x2E, 0x0101, 0x0101, 640, 480, 8, 1, 80, 30, | |
166 | MD_XGI300|MD_XGI315}, | |
167 | {"640x480x16", 0x44, 0x0111, 0x0111, 640, 480, 16, 1, 80, 30, | |
168 | MD_XGI300|MD_XGI315}, | |
169 | {"640x480x24", 0x62, 0x013a, 0x0112, 640, 480, 32, 1, 80, 30, | |
170 | MD_XGI300|MD_XGI315}, /* TW: That's for people who mix up color- | |
171 | and fb depth */ | |
172 | {"640x480x32", 0x62, 0x013a, 0x0112, 640, 480, 32, 1, 80, 30, | |
173 | MD_XGI300|MD_XGI315}, | |
174 | {"720x480x8", 0x31, 0x0000, 0x0000, 720, 480, 8, 1, 90, 30, | |
175 | MD_XGI300|MD_XGI315}, | |
176 | {"720x480x16", 0x33, 0x0000, 0x0000, 720, 480, 16, 1, 90, 30, | |
177 | MD_XGI300|MD_XGI315}, | |
178 | {"720x480x24", 0x35, 0x0000, 0x0000, 720, 480, 32, 1, 90, 30, | |
179 | MD_XGI300|MD_XGI315}, | |
180 | {"720x480x32", 0x35, 0x0000, 0x0000, 720, 480, 32, 1, 90, 30, | |
181 | MD_XGI300|MD_XGI315}, | |
182 | {"720x576x8", 0x32, 0x0000, 0x0000, 720, 576, 8, 1, 90, 36, | |
183 | MD_XGI300|MD_XGI315}, | |
184 | {"720x576x16", 0x34, 0x0000, 0x0000, 720, 576, 16, 1, 90, 36, | |
185 | MD_XGI300|MD_XGI315}, | |
186 | {"720x576x24", 0x36, 0x0000, 0x0000, 720, 576, 32, 1, 90, 36, | |
187 | MD_XGI300|MD_XGI315}, | |
188 | {"720x576x32", 0x36, 0x0000, 0x0000, 720, 576, 32, 1, 90, 36, | |
189 | MD_XGI300|MD_XGI315}, | |
190 | {"800x480x8", 0x70, 0x0000, 0x0000, 800, 480, 8, 1, 100, 30, | |
191 | MD_XGI300|MD_XGI315}, | |
192 | {"800x480x16", 0x7a, 0x0000, 0x0000, 800, 480, 16, 1, 100, 30, | |
193 | MD_XGI300|MD_XGI315}, | |
194 | {"800x480x24", 0x76, 0x0000, 0x0000, 800, 480, 32, 1, 100, 30, | |
195 | MD_XGI300|MD_XGI315}, | |
196 | {"800x480x32", 0x76, 0x0000, 0x0000, 800, 480, 32, 1, 100, 30, | |
197 | MD_XGI300|MD_XGI315}, | |
14e43851 KT |
198 | {"800x600x8", 0x30, 0x0103, 0x0103, 800, 600, 8, 1, 100, 37, |
199 | MD_XGI300|MD_XGI315}, | |
c3228308 | 200 | #define DEFAULT_MODE 20 /* index for 800x600x16 */ |
14e43851 KT |
201 | {"800x600x16", 0x47, 0x0114, 0x0114, 800, 600, 16, 1, 100, 37, |
202 | MD_XGI300|MD_XGI315}, | |
203 | {"800x600x24", 0x63, 0x013b, 0x0115, 800, 600, 32, 1, 100, 37, | |
204 | MD_XGI300|MD_XGI315}, | |
205 | {"800x600x32", 0x63, 0x013b, 0x0115, 800, 600, 32, 1, 100, 37, | |
206 | MD_XGI300|MD_XGI315}, | |
207 | {"1024x576x8", 0x71, 0x0000, 0x0000, 1024, 576, 8, 1, 128, 36, | |
208 | MD_XGI300|MD_XGI315}, | |
209 | {"1024x576x16", 0x74, 0x0000, 0x0000, 1024, 576, 16, 1, 128, 36, | |
210 | MD_XGI300|MD_XGI315}, | |
211 | {"1024x576x24", 0x77, 0x0000, 0x0000, 1024, 576, 32, 1, 128, 36, | |
212 | MD_XGI300|MD_XGI315}, | |
213 | {"1024x576x32", 0x77, 0x0000, 0x0000, 1024, 576, 32, 1, 128, 36, | |
214 | MD_XGI300|MD_XGI315}, | |
215 | {"1024x600x8", 0x20, 0x0000, 0x0000, 1024, 600, 8, 1, 128, 37, | |
216 | MD_XGI300 }, /* TW: 300 series only */ | |
217 | {"1024x600x16", 0x21, 0x0000, 0x0000, 1024, 600, 16, 1, 128, 37, | |
218 | MD_XGI300 }, | |
219 | {"1024x600x24", 0x22, 0x0000, 0x0000, 1024, 600, 32, 1, 128, 37, | |
220 | MD_XGI300 }, | |
221 | {"1024x600x32", 0x22, 0x0000, 0x0000, 1024, 600, 32, 1, 128, 37, | |
222 | MD_XGI300 }, | |
223 | {"1024x768x8", 0x38, 0x0105, 0x0105, 1024, 768, 8, 1, 128, 48, | |
224 | MD_XGI300|MD_XGI315}, | |
225 | {"1024x768x16", 0x4A, 0x0117, 0x0117, 1024, 768, 16, 1, 128, 48, | |
226 | MD_XGI300|MD_XGI315}, | |
227 | {"1024x768x24", 0x64, 0x013c, 0x0118, 1024, 768, 32, 1, 128, 48, | |
228 | MD_XGI300|MD_XGI315}, | |
229 | {"1024x768x32", 0x64, 0x013c, 0x0118, 1024, 768, 32, 1, 128, 48, | |
230 | MD_XGI300|MD_XGI315}, | |
231 | {"1152x768x8", 0x23, 0x0000, 0x0000, 1152, 768, 8, 1, 144, 48, | |
232 | MD_XGI300 }, /* TW: 300 series only */ | |
233 | {"1152x768x16", 0x24, 0x0000, 0x0000, 1152, 768, 16, 1, 144, 48, | |
234 | MD_XGI300 }, | |
235 | {"1152x768x24", 0x25, 0x0000, 0x0000, 1152, 768, 32, 1, 144, 48, | |
236 | MD_XGI300 }, | |
237 | {"1152x768x32", 0x25, 0x0000, 0x0000, 1152, 768, 32, 1, 144, 48, | |
238 | MD_XGI300 }, | |
239 | {"1280x720x8", 0x79, 0x0000, 0x0000, 1280, 720, 8, 1, 160, 45, | |
240 | MD_XGI300|MD_XGI315}, | |
241 | {"1280x720x16", 0x75, 0x0000, 0x0000, 1280, 720, 16, 1, 160, 45, | |
242 | MD_XGI300|MD_XGI315}, | |
243 | {"1280x720x24", 0x78, 0x0000, 0x0000, 1280, 720, 32, 1, 160, 45, | |
244 | MD_XGI300|MD_XGI315}, | |
245 | {"1280x720x32", 0x78, 0x0000, 0x0000, 1280, 720, 32, 1, 160, 45, | |
246 | MD_XGI300|MD_XGI315}, | |
247 | {"1280x768x8", 0x23, 0x0000, 0x0000, 1280, 768, 8, 1, 160, 48, | |
248 | MD_XGI315}, /* TW: 310/325 series only */ | |
249 | {"1280x768x16", 0x24, 0x0000, 0x0000, 1280, 768, 16, 1, 160, 48, | |
250 | MD_XGI315}, | |
251 | {"1280x768x24", 0x25, 0x0000, 0x0000, 1280, 768, 32, 1, 160, 48, | |
252 | MD_XGI315}, | |
253 | {"1280x768x32", 0x25, 0x0000, 0x0000, 1280, 768, 32, 1, 160, 48, | |
254 | MD_XGI315}, | |
14e43851 | 255 | {"1280x960x8", 0x7C, 0x0000, 0x0000, 1280, 960, 8, 1, 160, 60, |
7d2ab0c6 | 256 | MD_XGI300|MD_XGI315}, |
14e43851 KT |
257 | {"1280x960x16", 0x7D, 0x0000, 0x0000, 1280, 960, 16, 1, 160, 60, |
258 | MD_XGI300|MD_XGI315}, | |
259 | {"1280x960x24", 0x7E, 0x0000, 0x0000, 1280, 960, 32, 1, 160, 60, | |
260 | MD_XGI300|MD_XGI315}, | |
261 | {"1280x960x32", 0x7E, 0x0000, 0x0000, 1280, 960, 32, 1, 160, 60, | |
262 | MD_XGI300|MD_XGI315}, | |
263 | {"1280x1024x8", 0x3A, 0x0107, 0x0107, 1280, 1024, 8, 1, 160, 64, | |
264 | MD_XGI300|MD_XGI315}, | |
265 | {"1280x1024x16", 0x4D, 0x011a, 0x011a, 1280, 1024, 16, 1, 160, 64, | |
266 | MD_XGI300|MD_XGI315}, | |
267 | {"1280x1024x24", 0x65, 0x013d, 0x011b, 1280, 1024, 32, 1, 160, 64, | |
268 | MD_XGI300|MD_XGI315}, | |
269 | {"1280x1024x32", 0x65, 0x013d, 0x011b, 1280, 1024, 32, 1, 160, 64, | |
270 | MD_XGI300|MD_XGI315}, | |
271 | {"1400x1050x8", 0x26, 0x0000, 0x0000, 1400, 1050, 8, 1, 175, 65, | |
272 | MD_XGI315}, /* TW: 310/325 series only */ | |
273 | {"1400x1050x16", 0x27, 0x0000, 0x0000, 1400, 1050, 16, 1, 175, 65, | |
274 | MD_XGI315}, | |
275 | {"1400x1050x24", 0x28, 0x0000, 0x0000, 1400, 1050, 32, 1, 175, 65, | |
276 | MD_XGI315}, | |
277 | {"1400x1050x32", 0x28, 0x0000, 0x0000, 1400, 1050, 32, 1, 175, 65, | |
278 | MD_XGI315}, | |
279 | {"1600x1200x8", 0x3C, 0x0130, 0x011c, 1600, 1200, 8, 1, 200, 75, | |
280 | MD_XGI300|MD_XGI315}, | |
281 | {"1600x1200x16", 0x3D, 0x0131, 0x011e, 1600, 1200, 16, 1, 200, 75, | |
282 | MD_XGI300|MD_XGI315}, | |
283 | {"1600x1200x24", 0x66, 0x013e, 0x011f, 1600, 1200, 32, 1, 200, 75, | |
284 | MD_XGI300|MD_XGI315}, | |
285 | {"1600x1200x32", 0x66, 0x013e, 0x011f, 1600, 1200, 32, 1, 200, 75, | |
286 | MD_XGI300|MD_XGI315}, | |
287 | {"1920x1440x8", 0x68, 0x013f, 0x0000, 1920, 1440, 8, 1, 240, 75, | |
288 | MD_XGI300|MD_XGI315}, | |
289 | {"1920x1440x16", 0x69, 0x0140, 0x0000, 1920, 1440, 16, 1, 240, 75, | |
290 | MD_XGI300|MD_XGI315}, | |
291 | {"1920x1440x24", 0x6B, 0x0141, 0x0000, 1920, 1440, 32, 1, 240, 75, | |
292 | MD_XGI300|MD_XGI315}, | |
293 | {"1920x1440x32", 0x6B, 0x0141, 0x0000, 1920, 1440, 32, 1, 240, 75, | |
294 | MD_XGI300|MD_XGI315}, | |
295 | {"2048x1536x8", 0x6c, 0x0000, 0x0000, 2048, 1536, 8, 1, 256, 96, | |
296 | MD_XGI315}, /* TW: 310/325 series only */ | |
297 | {"2048x1536x16", 0x6d, 0x0000, 0x0000, 2048, 1536, 16, 1, 256, 96, | |
298 | MD_XGI315}, | |
299 | {"2048x1536x24", 0x6e, 0x0000, 0x0000, 2048, 1536, 32, 1, 256, 96, | |
300 | MD_XGI315}, | |
301 | {"2048x1536x32", 0x6e, 0x0000, 0x0000, 2048, 1536, 32, 1, 256, 96, | |
302 | MD_XGI315}, | |
d7636e0b | 303 | {"\0", 0x00, 0, 0, 0, 0, 0, 0, 0} |
304 | }; | |
305 | ||
d7636e0b | 306 | /* TW: CR36 evaluation */ |
14e43851 KT |
307 | static const unsigned short XGI300paneltype[] = { |
308 | LCD_UNKNOWN, LCD_800x600, LCD_1024x768, LCD_1280x1024, | |
309 | LCD_1280x960, LCD_640x480, LCD_1024x600, LCD_1152x768, | |
310 | LCD_1024x768, LCD_1024x768, LCD_1024x768, | |
311 | LCD_1024x768, LCD_1024x768, LCD_1024x768, LCD_1024x768}; | |
312 | ||
313 | static const unsigned short XGI310paneltype[] = { | |
314 | LCD_UNKNOWN, LCD_800x600, LCD_1024x768, LCD_1280x1024, | |
315 | LCD_640x480, LCD_1024x600, LCD_1152x864, LCD_1280x960, | |
316 | LCD_1152x768, LCD_1400x1050, LCD_1280x768, LCD_1600x1200, | |
317 | LCD_1024x768, LCD_1024x768, LCD_1024x768}; | |
d7636e0b | 318 | |
319 | static const struct _XGI_crt2type { | |
320 | char name[10]; | |
321 | int type_no; | |
322 | int tvplug_no; | |
323 | } XGI_crt2type[] = { | |
14e43851 | 324 | {"NONE", 0, -1}, |
289ea524 AK |
325 | {"LCD", XGIFB_DISP_LCD, -1}, |
326 | {"TV", XGIFB_DISP_TV, -1}, | |
327 | {"VGA", XGIFB_DISP_CRT, -1}, | |
328 | {"SVIDEO", XGIFB_DISP_TV, TVPLUG_SVIDEO}, | |
329 | {"COMPOSITE", XGIFB_DISP_TV, TVPLUG_COMPOSITE}, | |
330 | {"SCART", XGIFB_DISP_TV, TVPLUG_SCART}, | |
14e43851 | 331 | {"none", 0, -1}, |
289ea524 AK |
332 | {"lcd", XGIFB_DISP_LCD, -1}, |
333 | {"tv", XGIFB_DISP_TV, -1}, | |
334 | {"vga", XGIFB_DISP_CRT, -1}, | |
335 | {"svideo", XGIFB_DISP_TV, TVPLUG_SVIDEO}, | |
336 | {"composite", XGIFB_DISP_TV, TVPLUG_COMPOSITE}, | |
337 | {"scart", XGIFB_DISP_TV, TVPLUG_SCART}, | |
14e43851 | 338 | {"\0", -1, -1} |
d7636e0b | 339 | }; |
340 | ||
d7636e0b | 341 | /* TV standard */ |
342 | static const struct _XGI_tvtype { | |
343 | char name[6]; | |
344 | int type_no; | |
345 | } XGI_tvtype[] = { | |
14e43851 KT |
346 | {"PAL", 1}, |
347 | {"NTSC", 2}, | |
348 | {"pal", 1}, | |
349 | {"ntsc", 2}, | |
350 | {"\0", -1} | |
d7636e0b | 351 | }; |
352 | ||
353 | static const struct _XGI_vrate { | |
354 | u16 idx; | |
355 | u16 xres; | |
356 | u16 yres; | |
357 | u16 refresh; | |
358 | } XGIfb_vrate[] = { | |
14e43851 KT |
359 | {1, 640, 480, 60}, {2, 640, 480, 72}, |
360 | {3, 640, 480, 75}, {4, 640, 480, 85}, | |
361 | ||
362 | {5, 640, 480, 100}, {6, 640, 480, 120}, | |
363 | {7, 640, 480, 160}, {8, 640, 480, 200}, | |
364 | ||
d7636e0b | 365 | {1, 720, 480, 60}, |
366 | {1, 720, 576, 58}, | |
367 | {1, 800, 480, 60}, {2, 800, 480, 75}, {3, 800, 480, 85}, | |
14e43851 KT |
368 | {1, 800, 600, 60}, {2, 800, 600, 72}, {3, 800, 600, 75}, |
369 | {4, 800, 600, 85}, {5, 800, 600, 100}, | |
370 | {6, 800, 600, 120}, {7, 800, 600, 160}, | |
371 | ||
d7636e0b | 372 | {1, 1024, 768, 60}, {2, 1024, 768, 70}, {3, 1024, 768, 75}, |
373 | {4, 1024, 768, 85}, {5, 1024, 768, 100}, {6, 1024, 768, 120}, | |
374 | {1, 1024, 576, 60}, {2, 1024, 576, 75}, {3, 1024, 576, 85}, | |
375 | {1, 1024, 600, 60}, | |
376 | {1, 1152, 768, 60}, | |
377 | {1, 1280, 720, 60}, {2, 1280, 720, 75}, {3, 1280, 720, 85}, | |
378 | {1, 1280, 768, 60}, | |
14e43851 | 379 | {1, 1280, 1024, 60}, {2, 1280, 1024, 75}, {3, 1280, 1024, 85}, |
d7636e0b | 380 | {1, 1280, 960, 70}, |
381 | {1, 1400, 1050, 60}, | |
14e43851 KT |
382 | {1, 1600, 1200, 60}, {2, 1600, 1200, 65}, |
383 | {3, 1600, 1200, 70}, {4, 1600, 1200, 75}, | |
384 | ||
385 | {5, 1600, 1200, 85}, {6, 1600, 1200, 100}, | |
386 | {7, 1600, 1200, 120}, | |
387 | ||
388 | {1, 1920, 1440, 60}, {2, 1920, 1440, 65}, | |
389 | {3, 1920, 1440, 70}, {4, 1920, 1440, 75}, | |
390 | ||
d7636e0b | 391 | {5, 1920, 1440, 85}, {6, 1920, 1440, 100}, |
14e43851 KT |
392 | {1, 2048, 1536, 60}, {2, 2048, 1536, 65}, |
393 | {3, 2048, 1536, 70}, {4, 2048, 1536, 75}, | |
394 | ||
d7636e0b | 395 | {5, 2048, 1536, 85}, |
396 | {0, 0, 0, 0} | |
397 | }; | |
398 | ||
399 | static const struct _chswtable { | |
14e43851 KT |
400 | int subsysVendor; |
401 | int subsysCard; | |
402 | char *vendorName; | |
403 | char *cardName; | |
d7636e0b | 404 | } mychswtable[] = { |
14e43851 | 405 | { 0x1631, 0x1002, "Mitachi", "0x1002" }, |
d7636e0b | 406 | { 0, 0, "" , "" } |
407 | }; | |
408 | ||
14e43851 | 409 | /* Eden Chen */ |
d7636e0b | 410 | static const struct _XGI_TV_filter { |
411 | u8 filter[9][4]; | |
412 | } XGI_TV_filter[] = { | |
14e43851 KT |
413 | { { {0x00, 0x00, 0x00, 0x40}, /* NTSCFilter_0 */ |
414 | {0x00, 0xE0, 0x10, 0x60}, | |
415 | {0x00, 0xEE, 0x10, 0x44}, | |
416 | {0x00, 0xF4, 0x10, 0x38}, | |
417 | {0xF8, 0xF4, 0x18, 0x38}, | |
418 | {0xFC, 0xFB, 0x14, 0x2A}, | |
419 | {0x00, 0x00, 0x10, 0x20}, | |
420 | {0x00, 0x04, 0x10, 0x18}, | |
421 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
422 | { { {0x00, 0x00, 0x00, 0x40}, /* NTSCFilter_1 */ | |
423 | {0x00, 0xE0, 0x10, 0x60}, | |
424 | {0x00, 0xEE, 0x10, 0x44}, | |
425 | {0x00, 0xF4, 0x10, 0x38}, | |
426 | {0xF8, 0xF4, 0x18, 0x38}, | |
427 | {0xFC, 0xFB, 0x14, 0x2A}, | |
428 | {0x00, 0x00, 0x10, 0x20}, | |
429 | {0x00, 0x04, 0x10, 0x18}, | |
430 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
431 | { { {0x00, 0x00, 0x00, 0x40}, /* NTSCFilter_2 */ | |
432 | {0xF5, 0xEE, 0x1B, 0x44}, | |
433 | {0xF8, 0xF4, 0x18, 0x38}, | |
434 | {0xEB, 0x04, 0x25, 0x18}, | |
435 | {0xF1, 0x05, 0x1F, 0x16}, | |
436 | {0xF6, 0x06, 0x1A, 0x14}, | |
437 | {0xFA, 0x06, 0x16, 0x14}, | |
438 | {0x00, 0x04, 0x10, 0x18}, | |
439 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
440 | { { {0x00, 0x00, 0x00, 0x40}, /* NTSCFilter_3 */ | |
441 | {0xF1, 0x04, 0x1F, 0x18}, | |
442 | {0xEE, 0x0D, 0x22, 0x06}, | |
443 | {0xF7, 0x06, 0x19, 0x14}, | |
444 | {0xF4, 0x0B, 0x1C, 0x0A}, | |
445 | {0xFA, 0x07, 0x16, 0x12}, | |
446 | {0xF9, 0x0A, 0x17, 0x0C}, | |
447 | {0x00, 0x07, 0x10, 0x12}, | |
448 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
449 | { { {0x00, 0x00, 0x00, 0x40}, /* NTSCFilter_4 */ | |
450 | {0x00, 0xE0, 0x10, 0x60}, | |
451 | {0x00, 0xEE, 0x10, 0x44}, | |
452 | {0x00, 0xF4, 0x10, 0x38}, | |
453 | {0xF8, 0xF4, 0x18, 0x38}, | |
454 | {0xFC, 0xFB, 0x14, 0x2A}, | |
455 | {0x00, 0x00, 0x10, 0x20}, | |
456 | {0x00, 0x04, 0x10, 0x18}, | |
457 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
458 | { { {0x00, 0x00, 0x00, 0x40}, /* NTSCFilter_5 */ | |
459 | {0xF5, 0xEE, 0x1B, 0x44}, | |
460 | {0xF8, 0xF4, 0x18, 0x38}, | |
461 | {0xEB, 0x04, 0x25, 0x18}, | |
462 | {0xF1, 0x05, 0x1F, 0x16}, | |
463 | {0xF6, 0x06, 0x1A, 0x14}, | |
464 | {0xFA, 0x06, 0x16, 0x14}, | |
465 | {0x00, 0x04, 0x10, 0x18}, | |
466 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
467 | { { {0x00, 0x00, 0x00, 0x40}, /* NTSCFilter_6 */ | |
468 | {0xEB, 0x04, 0x25, 0x18}, | |
469 | {0xE7, 0x0E, 0x29, 0x04}, | |
470 | {0xEE, 0x0C, 0x22, 0x08}, | |
471 | {0xF6, 0x0B, 0x1A, 0x0A}, | |
472 | {0xF9, 0x0A, 0x17, 0x0C}, | |
473 | {0xFC, 0x0A, 0x14, 0x0C}, | |
474 | {0x00, 0x08, 0x10, 0x10}, | |
475 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
476 | { { {0x00, 0x00, 0x00, 0x40}, /* NTSCFilter_7 */ | |
477 | {0xEC, 0x02, 0x24, 0x1C}, | |
478 | {0xF2, 0x04, 0x1E, 0x18}, | |
479 | {0xEB, 0x15, 0x25, 0xF6}, | |
480 | {0xF4, 0x10, 0x1C, 0x00}, | |
481 | {0xF8, 0x0F, 0x18, 0x02}, | |
482 | {0x00, 0x04, 0x10, 0x18}, | |
483 | {0x01, 0x06, 0x0F, 0x14}, | |
484 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
485 | { { {0x00, 0x00, 0x00, 0x40}, /* PALFilter_0 */ | |
486 | {0x00, 0xE0, 0x10, 0x60}, | |
487 | {0x00, 0xEE, 0x10, 0x44}, | |
488 | {0x00, 0xF4, 0x10, 0x38}, | |
489 | {0xF8, 0xF4, 0x18, 0x38}, | |
490 | {0xFC, 0xFB, 0x14, 0x2A}, | |
491 | {0x00, 0x00, 0x10, 0x20}, | |
492 | {0x00, 0x04, 0x10, 0x18}, | |
493 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
494 | { { {0x00, 0x00, 0x00, 0x40}, /* PALFilter_1 */ | |
495 | {0x00, 0xE0, 0x10, 0x60}, | |
496 | {0x00, 0xEE, 0x10, 0x44}, | |
497 | {0x00, 0xF4, 0x10, 0x38}, | |
498 | {0xF8, 0xF4, 0x18, 0x38}, | |
499 | {0xFC, 0xFB, 0x14, 0x2A}, | |
500 | {0x00, 0x00, 0x10, 0x20}, | |
501 | {0x00, 0x04, 0x10, 0x18}, | |
502 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
503 | { { {0x00, 0x00, 0x00, 0x40}, /* PALFilter_2 */ | |
504 | {0xF5, 0xEE, 0x1B, 0x44}, | |
505 | {0xF8, 0xF4, 0x18, 0x38}, | |
506 | {0xF1, 0xF7, 0x01, 0x32}, | |
507 | {0xF5, 0xFB, 0x1B, 0x2A}, | |
508 | {0xF9, 0xFF, 0x17, 0x22}, | |
509 | {0xFB, 0x01, 0x15, 0x1E}, | |
510 | {0x00, 0x04, 0x10, 0x18}, | |
511 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
512 | { { {0x00, 0x00, 0x00, 0x40}, /* PALFilter_3 */ | |
513 | {0xF5, 0xFB, 0x1B, 0x2A}, | |
514 | {0xEE, 0xFE, 0x22, 0x24}, | |
515 | {0xF3, 0x00, 0x1D, 0x20}, | |
516 | {0xF9, 0x03, 0x17, 0x1A}, | |
517 | {0xFB, 0x02, 0x14, 0x1E}, | |
518 | {0xFB, 0x04, 0x15, 0x18}, | |
519 | {0x00, 0x06, 0x10, 0x14}, | |
520 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
521 | { { {0x00, 0x00, 0x00, 0x40}, /* PALFilter_4 */ | |
522 | {0x00, 0xE0, 0x10, 0x60}, | |
523 | {0x00, 0xEE, 0x10, 0x44}, | |
524 | {0x00, 0xF4, 0x10, 0x38}, | |
525 | {0xF8, 0xF4, 0x18, 0x38}, | |
526 | {0xFC, 0xFB, 0x14, 0x2A}, | |
527 | {0x00, 0x00, 0x10, 0x20}, | |
528 | {0x00, 0x04, 0x10, 0x18}, | |
529 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
530 | { { {0x00, 0x00, 0x00, 0x40}, /* PALFilter_5 */ | |
531 | {0xF5, 0xEE, 0x1B, 0x44}, | |
532 | {0xF8, 0xF4, 0x18, 0x38}, | |
533 | {0xF1, 0xF7, 0x1F, 0x32}, | |
534 | {0xF5, 0xFB, 0x1B, 0x2A}, | |
535 | {0xF9, 0xFF, 0x17, 0x22}, | |
536 | {0xFB, 0x01, 0x15, 0x1E}, | |
537 | {0x00, 0x04, 0x10, 0x18}, | |
538 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
539 | { { {0x00, 0x00, 0x00, 0x40}, /* PALFilter_6 */ | |
540 | {0xF5, 0xEE, 0x1B, 0x2A}, | |
541 | {0xEE, 0xFE, 0x22, 0x24}, | |
542 | {0xF3, 0x00, 0x1D, 0x20}, | |
543 | {0xF9, 0x03, 0x17, 0x1A}, | |
544 | {0xFB, 0x02, 0x14, 0x1E}, | |
545 | {0xFB, 0x04, 0x15, 0x18}, | |
546 | {0x00, 0x06, 0x10, 0x14}, | |
547 | {0xFF, 0xFF, 0xFF, 0xFF} } }, | |
548 | { { {0x00, 0x00, 0x00, 0x40}, /* PALFilter_7 */ | |
549 | {0xF5, 0xEE, 0x1B, 0x44}, | |
550 | {0xF8, 0xF4, 0x18, 0x38}, | |
551 | {0xFC, 0xFB, 0x14, 0x2A}, | |
552 | {0xEB, 0x05, 0x25, 0x16}, | |
553 | {0xF1, 0x05, 0x1F, 0x16}, | |
554 | {0xFA, 0x07, 0x16, 0x12}, | |
555 | {0x00, 0x07, 0x10, 0x12}, | |
556 | {0xFF, 0xFF, 0xFF, 0xFF} } } | |
d7636e0b | 557 | }; |
558 | ||
559 | static int filter = -1; | |
d7636e0b | 560 | |
d7636e0b | 561 | #endif |