4 * General structure definitions for universal mode switching modules
6 * Copyright (C) 2001-2005 by Thomas Winischhofer, Vienna, Austria
8 * If distributed as part of the Linux kernel, the following license terms
11 * * This program is free software; you can redistribute it and/or modify
12 * * it under the terms of the GNU General Public License as published by
13 * * the Free Software Foundation; either version 2 of the named License,
14 * * or any later version.
16 * * This program is distributed in the hope that it will be useful,
17 * * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * * GNU General Public License for more details.
21 * * You should have received a copy of the GNU General Public License
22 * * along with this program; if not, write to the Free Software
23 * * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA
25 * Otherwise, the following license terms apply:
27 * * Redistribution and use in source and binary forms, with or without
28 * * modification, are permitted provided that the following conditions
30 * * 1) Redistributions of source code must retain the above copyright
31 * * notice, this list of conditions and the following disclaimer.
32 * * 2) Redistributions in binary form must reproduce the above copyright
33 * * notice, this list of conditions and the following disclaimer in the
34 * * documentation and/or other materials provided with the distribution.
35 * * 3) The name of the author may not be used to endorse or promote products
36 * * derived from this software without specific prior written permission.
38 * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
39 * * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
40 * * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
41 * * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
42 * * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
43 * * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
44 * * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
45 * * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
46 * * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
47 * * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
49 * Author: Thomas Winischhofer <thomas@winischhofer.net>
56 struct SiS_PanelDelayTbl
{
57 unsigned char timer
[2];
61 unsigned short RVBHCMAX
;
62 unsigned short RVBHCFACT
;
70 unsigned short RVBHCMAX
;
71 unsigned short RVBHCFACT
;
76 unsigned short RVBHRS
;
77 unsigned char FlickerMode
;
78 unsigned short HALFRVBHRS
;
79 unsigned short RVBHRS2
;
94 unsigned short LCDHDES
;
95 unsigned short LCDVDES
;
98 struct SiS_LVDSCRT1Data
{
102 struct SiS_CHTVRegData
{
103 unsigned char Reg
[16];
107 unsigned char St_ModeID
;
108 unsigned short St_ModeFlag
;
109 unsigned char St_StTableIndex
;
110 unsigned char St_CRT2CRTC
;
111 unsigned char St_ResInfo
;
112 unsigned char VB_StTVFlickerIndex
;
113 unsigned char VB_StTVEdgeIndex
;
114 unsigned char VB_StTVYFilterIndex
;
115 unsigned char St_PDC
;
119 unsigned char ModeID
;
120 unsigned char VB_TVDelayIndex
;
121 unsigned char VB_TVFlickerIndex
;
122 unsigned char VB_TVPhaseIndex
;
123 unsigned char VB_TVYFilterIndex
;
124 unsigned char VB_LCDDelayIndex
;
125 unsigned char _VB_LCDHIndex
;
126 unsigned char _VB_LCDVIndex
;
129 struct SiS_StandTable_S
{
130 unsigned char CRT_COLS
;
132 unsigned char CHAR_HEIGHT
;
133 unsigned short CRT_LEN
;
136 unsigned char CRTC
[0x19];
137 unsigned char ATTR
[0x14];
138 unsigned char GRC
[9];
142 unsigned char Ext_ModeID
;
143 unsigned short Ext_ModeFlag
;
144 unsigned short Ext_VESAID
;
145 unsigned char Ext_RESINFO
;
146 unsigned char VB_ExtTVFlickerIndex
;
147 unsigned char VB_ExtTVEdgeIndex
;
148 unsigned char VB_ExtTVYFilterIndex
;
149 unsigned char VB_ExtTVYFilterIndexROM661
;
150 unsigned char REFindex
;
155 unsigned short Ext_InfoFlag
;
156 unsigned char Ext_CRT1CRTC
;
157 unsigned char Ext_CRTVCLK
;
158 unsigned char Ext_CRT2CRTC
;
159 unsigned char Ext_CRT2CRTC_NS
;
160 unsigned char ModeID
;
163 unsigned char Ext_PDC
;
164 unsigned char Ext_FakeCRT2CRTC
;
165 unsigned char Ext_FakeCRT2Clk
;
166 unsigned char Ext_CRT1CRTC_NORM
;
167 unsigned char Ext_CRTVCLK_NORM
;
168 unsigned char Ext_CRT1CRTC_WIDE
;
169 unsigned char Ext_CRTVCLK_WIDE
;
172 struct SiS_Part2PortTbl
{
173 unsigned char CR
[12];
176 struct SiS_CRT1Table
{
177 unsigned char CR
[17];
180 struct SiS_MCLKData
{
181 unsigned char SR28
,SR29
,SR2A
;
182 unsigned short CLOCK
;
185 struct SiS_VCLKData
{
186 unsigned char SR2B
,SR2C
;
187 unsigned short CLOCK
;
190 struct SiS_VBVCLKData
{
191 unsigned char Part4_A
,Part4_B
;
192 unsigned short CLOCK
;
195 struct SiS_StResInfo_S
{
196 unsigned short HTotal
;
197 unsigned short VTotal
;
200 struct SiS_ModeResInfo_S
{
201 unsigned short HTotal
;
202 unsigned short VTotal
;
207 /* Defines for SiS_CustomT */
208 /* Never change these for sisfb compatibility */
210 #define CUT_FORCENONE 1
211 #define CUT_BARCO1366 2
212 #define CUT_BARCO1024 3
213 #define CUT_COMPAQ1280 4
214 #define CUT_COMPAQ12802 5
215 #define CUT_PANEL848 6
216 #define CUT_CLEVO1024 7
217 #define CUT_CLEVO10242 8
218 #define CUT_CLEVO1400 9
219 #define CUT_CLEVO14002 10
220 #define CUT_UNIWILL1024 11
221 #define CUT_ASUSL3000D 12
222 #define CUT_UNIWILL10242 13
223 #define CUT_ACER1280 14
224 #define CUT_COMPAL1400_1 15
225 #define CUT_COMPAL1400_2 16
226 #define CUT_ASUSA2H_1 17
227 #define CUT_ASUSA2H_2 18
228 #define CUT_UNKNOWNLCD 19
229 #define CUT_AOP8060 20
230 #define CUT_PANEL856 21
234 unsigned char ChipType
;
235 unsigned char ChipRevision
;
239 #ifdef SIS_LINUX_KERNEL
242 unsigned char *VirtualRomBase
;
244 #ifdef SIS_LINUX_KERNEL
245 unsigned char SISIOMEMTYPE
*VideoMemoryAddress
;
246 unsigned int VideoMemorySize
;
248 SISIOADDRESS IOAddress
;
249 SISIOADDRESS IOAddress2
; /* For dual chip XGI volari */
251 #ifdef SIS_LINUX_KERNEL
254 SISIOADDRESS SiS_P3c4
;
255 SISIOADDRESS SiS_P3d4
;
256 SISIOADDRESS SiS_P3c0
;
257 SISIOADDRESS SiS_P3ce
;
258 SISIOADDRESS SiS_P3c2
;
259 SISIOADDRESS SiS_P3ca
;
260 SISIOADDRESS SiS_P3c6
;
261 SISIOADDRESS SiS_P3c7
;
262 SISIOADDRESS SiS_P3c8
;
263 SISIOADDRESS SiS_P3c9
;
264 SISIOADDRESS SiS_P3cb
;
265 SISIOADDRESS SiS_P3cc
;
266 SISIOADDRESS SiS_P3cd
;
267 SISIOADDRESS SiS_P3da
;
268 SISIOADDRESS SiS_Part1Port
;
269 SISIOADDRESS SiS_Part2Port
;
270 SISIOADDRESS SiS_Part3Port
;
271 SISIOADDRESS SiS_Part4Port
;
272 SISIOADDRESS SiS_Part5Port
;
273 SISIOADDRESS SiS_VidCapt
;
274 SISIOADDRESS SiS_VidPlay
;
275 unsigned short SiS_IF_DEF_LVDS
;
276 unsigned short SiS_IF_DEF_CH70xx
;
277 unsigned short SiS_IF_DEF_CONEX
;
278 unsigned short SiS_IF_DEF_TRUMPION
;
279 unsigned short SiS_IF_DEF_DSTN
;
280 unsigned short SiS_IF_DEF_FSTN
;
281 unsigned short SiS_SysFlags
;
282 unsigned char SiS_VGAINFO
;
284 unsigned short SiS_CP1
, SiS_CP2
, SiS_CP3
, SiS_CP4
;
289 bool SiS_NeedRomModeData
;
290 bool PanelSelfDetected
;
293 bool SiS_CHSOverScan
;
297 unsigned int SiS_CustomT
;
298 int SiS_UseWide
, SiS_UseWideCRT2
;
300 unsigned short SiS_Backup70xx
;
304 unsigned char EMI_30
,EMI_31
,EMI_32
,EMI_33
;
305 unsigned short SiS_EMIOffset
;
306 unsigned short SiS_PWDOffset
;
308 unsigned char SiS_MyCR63
;
309 unsigned short SiS_CRT1Mode
;
310 unsigned short SiS_flag_clearbuffer
;
312 unsigned char SiS_ChannelAB
;
313 unsigned char SiS_DataBusWidth
;
314 unsigned short SiS_ModeType
;
315 unsigned short SiS_VBInfo
;
316 unsigned short SiS_TVMode
;
317 unsigned short SiS_LCDResInfo
;
318 unsigned short SiS_LCDTypeInfo
;
319 unsigned short SiS_LCDInfo
;
320 unsigned short SiS_LCDInfo661
;
321 unsigned short SiS_VBType
;
322 unsigned short SiS_VBExtInfo
;
323 unsigned short SiS_YPbPr
;
324 unsigned short SiS_SelectCRT2Rate
;
325 unsigned short SiS_SetFlag
;
326 unsigned short SiS_RVBHCFACT
;
327 unsigned short SiS_RVBHCMAX
;
328 unsigned short SiS_RVBHRS
;
329 unsigned short SiS_RVBHRS2
;
330 unsigned short SiS_VGAVT
;
331 unsigned short SiS_VGAHT
;
332 unsigned short SiS_VT
;
333 unsigned short SiS_HT
;
334 unsigned short SiS_VGAVDE
;
335 unsigned short SiS_VGAHDE
;
336 unsigned short SiS_VDE
;
337 unsigned short SiS_HDE
;
338 unsigned short SiS_NewFlickerMode
;
339 unsigned short SiS_RY1COE
;
340 unsigned short SiS_RY2COE
;
341 unsigned short SiS_RY3COE
;
342 unsigned short SiS_RY4COE
;
343 unsigned short SiS_LCDHDES
;
344 unsigned short SiS_LCDVDES
;
345 SISIOADDRESS SiS_DDC_Port
;
346 unsigned short SiS_DDC_Index
;
347 unsigned short SiS_DDC_Data
;
348 unsigned short SiS_DDC_NData
;
349 unsigned short SiS_DDC_Clk
;
350 unsigned short SiS_DDC_NClk
;
351 unsigned short SiS_DDC_DeviceAddr
;
352 unsigned short SiS_DDC_ReadAddr
;
353 unsigned short SiS_DDC_SecAddr
;
354 unsigned short SiS_ChrontelInit
;
355 bool SiS_SensibleSR11
;
356 unsigned short SiS661LCD2TableSize
;
358 unsigned short SiS_PanelMinLVDS
;
359 unsigned short SiS_PanelMin301
;
361 const struct SiS_St
*SiS_SModeIDTable
;
362 const struct SiS_StandTable_S
*SiS_StandTable
;
363 const struct SiS_Ext
*SiS_EModeIDTable
;
364 const struct SiS_Ext2
*SiS_RefIndex
;
365 const struct SiS_VBMode
*SiS_VBModeIDTable
;
366 const struct SiS_CRT1Table
*SiS_CRT1Table
;
367 const struct SiS_MCLKData
*SiS_MCLKData_0
;
368 const struct SiS_MCLKData
*SiS_MCLKData_1
;
369 struct SiS_VCLKData
*SiS_VCLKData
;
370 struct SiS_VBVCLKData
*SiS_VBVCLKData
;
371 const struct SiS_StResInfo_S
*SiS_StResInfo
;
372 const struct SiS_ModeResInfo_S
*SiS_ModeResInfo
;
374 const unsigned char *pSiS_OutputSelect
;
375 const unsigned char *pSiS_SoftSetting
;
377 const unsigned char *SiS_SR15
;
379 const struct SiS_PanelDelayTbl
*SiS_PanelDelayTbl
;
380 const struct SiS_PanelDelayTbl
*SiS_PanelDelayTblLVDS
;
384 const struct SiS_LCDData
*SiS_ExtLCD1024x768Data
;
385 const struct SiS_LCDData
*SiS_St2LCD1024x768Data
;
386 const struct SiS_LCDData
*SiS_LCD1280x720Data
;
387 const struct SiS_LCDData
*SiS_StLCD1280x768_2Data
;
388 const struct SiS_LCDData
*SiS_ExtLCD1280x768_2Data
;
389 const struct SiS_LCDData
*SiS_LCD1280x800Data
;
390 const struct SiS_LCDData
*SiS_LCD1280x800_2Data
;
391 const struct SiS_LCDData
*SiS_LCD1280x854Data
;
392 const struct SiS_LCDData
*SiS_LCD1280x960Data
;
393 const struct SiS_LCDData
*SiS_ExtLCD1280x1024Data
;
394 const struct SiS_LCDData
*SiS_St2LCD1280x1024Data
;
395 const struct SiS_LCDData
*SiS_StLCD1400x1050Data
;
396 const struct SiS_LCDData
*SiS_ExtLCD1400x1050Data
;
397 const struct SiS_LCDData
*SiS_StLCD1600x1200Data
;
398 const struct SiS_LCDData
*SiS_ExtLCD1600x1200Data
;
399 const struct SiS_LCDData
*SiS_LCD1680x1050Data
;
400 const struct SiS_LCDData
*SiS_NoScaleData
;
401 const struct SiS_TVData
*SiS_StPALData
;
402 const struct SiS_TVData
*SiS_ExtPALData
;
403 const struct SiS_TVData
*SiS_StNTSCData
;
404 const struct SiS_TVData
*SiS_ExtNTSCData
;
405 const struct SiS_TVData
*SiS_St1HiTVData
;
406 const struct SiS_TVData
*SiS_St2HiTVData
;
407 const struct SiS_TVData
*SiS_ExtHiTVData
;
408 const struct SiS_TVData
*SiS_St525iData
;
409 const struct SiS_TVData
*SiS_St525pData
;
410 const struct SiS_TVData
*SiS_St750pData
;
411 const struct SiS_TVData
*SiS_Ext525iData
;
412 const struct SiS_TVData
*SiS_Ext525pData
;
413 const struct SiS_TVData
*SiS_Ext750pData
;
414 const unsigned char *SiS_NTSCTiming
;
415 const unsigned char *SiS_PALTiming
;
416 const unsigned char *SiS_HiTVExtTiming
;
417 const unsigned char *SiS_HiTVSt1Timing
;
418 const unsigned char *SiS_HiTVSt2Timing
;
419 const unsigned char *SiS_HiTVGroup3Data
;
420 const unsigned char *SiS_HiTVGroup3Simu
;
422 const unsigned char *SiS_HiTVTextTiming
;
423 const unsigned char *SiS_HiTVGroup3Text
;
426 const struct SiS_Part2PortTbl
*SiS_CRT2Part2_1024x768_1
;
427 const struct SiS_Part2PortTbl
*SiS_CRT2Part2_1024x768_2
;
428 const struct SiS_Part2PortTbl
*SiS_CRT2Part2_1024x768_3
;
432 const struct SiS_LVDSData
*SiS_LVDS320x240Data_1
;
433 const struct SiS_LVDSData
*SiS_LVDS320x240Data_2
;
434 const struct SiS_LVDSData
*SiS_LVDS640x480Data_1
;
435 const struct SiS_LVDSData
*SiS_LVDS800x600Data_1
;
436 const struct SiS_LVDSData
*SiS_LVDS1024x600Data_1
;
437 const struct SiS_LVDSData
*SiS_LVDS1024x768Data_1
;
438 const struct SiS_LVDSData
*SiS_LVDSBARCO1366Data_1
;
439 const struct SiS_LVDSData
*SiS_LVDSBARCO1366Data_2
;
440 const struct SiS_LVDSData
*SiS_LVDSBARCO1024Data_1
;
441 const struct SiS_LVDSData
*SiS_LVDS848x480Data_1
;
442 const struct SiS_LVDSData
*SiS_LVDS848x480Data_2
;
443 const struct SiS_LVDSData
*SiS_CHTVUNTSCData
;
444 const struct SiS_LVDSData
*SiS_CHTVONTSCData
;
445 const struct SiS_LVDSData
*SiS_CHTVUPALData
;
446 const struct SiS_LVDSData
*SiS_CHTVOPALData
;
447 const struct SiS_LVDSData
*SiS_CHTVUPALMData
;
448 const struct SiS_LVDSData
*SiS_CHTVOPALMData
;
449 const struct SiS_LVDSData
*SiS_CHTVUPALNData
;
450 const struct SiS_LVDSData
*SiS_CHTVOPALNData
;
451 const struct SiS_LVDSData
*SiS_CHTVSOPALData
;
453 const struct SiS_LVDSDes
*SiS_PanelType04_1a
;
454 const struct SiS_LVDSDes
*SiS_PanelType04_2a
;
455 const struct SiS_LVDSDes
*SiS_PanelType04_1b
;
456 const struct SiS_LVDSDes
*SiS_PanelType04_2b
;
458 const struct SiS_LVDSCRT1Data
*SiS_LVDSCRT1320x240_1
;
459 const struct SiS_LVDSCRT1Data
*SiS_LVDSCRT1320x240_2
;
460 const struct SiS_LVDSCRT1Data
*SiS_LVDSCRT1320x240_2_H
;
461 const struct SiS_LVDSCRT1Data
*SiS_LVDSCRT1320x240_3
;
462 const struct SiS_LVDSCRT1Data
*SiS_LVDSCRT1320x240_3_H
;
463 const struct SiS_LVDSCRT1Data
*SiS_LVDSCRT1640x480_1
;
464 const struct SiS_LVDSCRT1Data
*SiS_LVDSCRT1640x480_1_H
;
465 const struct SiS_LVDSCRT1Data
*SiS_CHTVCRT1UNTSC
;
466 const struct SiS_LVDSCRT1Data
*SiS_CHTVCRT1ONTSC
;
467 const struct SiS_LVDSCRT1Data
*SiS_CHTVCRT1UPAL
;
468 const struct SiS_LVDSCRT1Data
*SiS_CHTVCRT1OPAL
;
469 const struct SiS_LVDSCRT1Data
*SiS_CHTVCRT1SOPAL
;
471 const struct SiS_CHTVRegData
*SiS_CHTVReg_UNTSC
;
472 const struct SiS_CHTVRegData
*SiS_CHTVReg_ONTSC
;
473 const struct SiS_CHTVRegData
*SiS_CHTVReg_UPAL
;
474 const struct SiS_CHTVRegData
*SiS_CHTVReg_OPAL
;
475 const struct SiS_CHTVRegData
*SiS_CHTVReg_UPALM
;
476 const struct SiS_CHTVRegData
*SiS_CHTVReg_OPALM
;
477 const struct SiS_CHTVRegData
*SiS_CHTVReg_UPALN
;
478 const struct SiS_CHTVRegData
*SiS_CHTVReg_OPALN
;
479 const struct SiS_CHTVRegData
*SiS_CHTVReg_SOPAL
;
481 const unsigned char *SiS_CHTVVCLKUNTSC
;
482 const unsigned char *SiS_CHTVVCLKONTSC
;
483 const unsigned char *SiS_CHTVVCLKUPAL
;
484 const unsigned char *SiS_CHTVVCLKOPAL
;
485 const unsigned char *SiS_CHTVVCLKUPALM
;
486 const unsigned char *SiS_CHTVVCLKOPALM
;
487 const unsigned char *SiS_CHTVVCLKUPALN
;
488 const unsigned char *SiS_CHTVVCLKOPALN
;
489 const unsigned char *SiS_CHTVVCLKSOPAL
;
491 unsigned short PanelXRes
, PanelHT
;
492 unsigned short PanelYRes
, PanelVT
;
493 unsigned short PanelHRS
, PanelHRE
;
494 unsigned short PanelVRS
, PanelVRE
;
495 unsigned short PanelVCLKIdx300
;
496 unsigned short PanelVCLKIdx315
;
497 bool Alternate1600x1200
;
500 bool CRT1UsesCustomMode
;
501 unsigned short CHDisplay
;
502 unsigned short CHSyncStart
;
503 unsigned short CHSyncEnd
;
504 unsigned short CHTotal
;
505 unsigned short CHBlankStart
;
506 unsigned short CHBlankEnd
;
507 unsigned short CVDisplay
;
508 unsigned short CVSyncStart
;
509 unsigned short CVSyncEnd
;
510 unsigned short CVTotal
;
511 unsigned short CVBlankStart
;
512 unsigned short CVBlankEnd
;
513 unsigned int CDClock
;
515 unsigned char CCRT1CRTC
[17];
518 unsigned short CSRClock
;
519 unsigned short CSRClock_CRT1
;
520 unsigned short CModeFlag
;
521 unsigned short CModeFlag_CRT1
;
522 unsigned short CInfoFlag
;
527 unsigned char Backup_Mode
;
528 unsigned char Backup_14
;
529 unsigned char Backup_15
;
530 unsigned char Backup_16
;
531 unsigned char Backup_17
;
532 unsigned char Backup_18
;
533 unsigned char Backup_19
;
534 unsigned char Backup_1a
;
535 unsigned char Backup_1b
;
536 unsigned char Backup_1c
;
537 unsigned char Backup_1d
;
539 unsigned char Init_P4_0E
;
544 unsigned short CP_Vendor
, CP_Product
;
545 bool CP_HaveCustomData
;
546 int CP_PreferredX
, CP_PreferredY
, CP_PreferredIndex
;
547 int CP_MaxX
, CP_MaxY
, CP_MaxClock
;
548 unsigned char CP_PrefSR2B
, CP_PrefSR2C
;
549 unsigned short CP_PrefClock
;
550 bool CP_Supports64048075
;
551 int CP_HDisplay
[7], CP_VDisplay
[7]; /* For Custom LCD panel dimensions */
552 int CP_HTotal
[7], CP_VTotal
[7];
553 int CP_HSyncStart
[7], CP_VSyncStart
[7];
554 int CP_HSyncEnd
[7], CP_VSyncEnd
[7];
555 int CP_HBlankStart
[7], CP_VBlankStart
[7];
556 int CP_HBlankEnd
[7], CP_VBlankEnd
[7];
558 bool CP_DataValid
[7];
559 bool CP_HSync_P
[7], CP_VSync_P
[7], CP_SyncValid
[7];