162306a36Sopenharmony_ci/* $XFree86$ */ 262306a36Sopenharmony_ci/* $XdotOrg$ */ 362306a36Sopenharmony_ci/* 462306a36Sopenharmony_ci * Global definitions for init.c and init301.c 562306a36Sopenharmony_ci * 662306a36Sopenharmony_ci * Copyright (C) 2001-2005 by Thomas Winischhofer, Vienna, Austria 762306a36Sopenharmony_ci * 862306a36Sopenharmony_ci * If distributed as part of the Linux kernel, the following license terms 962306a36Sopenharmony_ci * apply: 1062306a36Sopenharmony_ci * 1162306a36Sopenharmony_ci * * This program is free software; you can redistribute it and/or modify 1262306a36Sopenharmony_ci * * it under the terms of the GNU General Public License as published by 1362306a36Sopenharmony_ci * * the Free Software Foundation; either version 2 of the named License, 1462306a36Sopenharmony_ci * * or any later version. 1562306a36Sopenharmony_ci * * 1662306a36Sopenharmony_ci * * This program is distributed in the hope that it will be useful, 1762306a36Sopenharmony_ci * * but WITHOUT ANY WARRANTY; without even the implied warranty of 1862306a36Sopenharmony_ci * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1962306a36Sopenharmony_ci * * GNU General Public License for more details. 2062306a36Sopenharmony_ci * * 2162306a36Sopenharmony_ci * * You should have received a copy of the GNU General Public License 2262306a36Sopenharmony_ci * * along with this program; if not, write to the Free Software 2362306a36Sopenharmony_ci * * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA 2462306a36Sopenharmony_ci * 2562306a36Sopenharmony_ci * Otherwise, the following license terms apply: 2662306a36Sopenharmony_ci * 2762306a36Sopenharmony_ci * * Redistribution and use in source and binary forms, with or without 2862306a36Sopenharmony_ci * * modification, are permitted provided that the following conditions 2962306a36Sopenharmony_ci * * are met: 3062306a36Sopenharmony_ci * * 1) Redistributions of source code must retain the above copyright 3162306a36Sopenharmony_ci * * notice, this list of conditions and the following disclaimer. 3262306a36Sopenharmony_ci * * 2) Redistributions in binary form must reproduce the above copyright 3362306a36Sopenharmony_ci * * notice, this list of conditions and the following disclaimer in the 3462306a36Sopenharmony_ci * * documentation and/or other materials provided with the distribution. 3562306a36Sopenharmony_ci * * 3) The name of the author may not be used to endorse or promote products 3662306a36Sopenharmony_ci * * derived from this software without specific prior written permission. 3762306a36Sopenharmony_ci * * 3862306a36Sopenharmony_ci * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 3962306a36Sopenharmony_ci * * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 4062306a36Sopenharmony_ci * * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 4162306a36Sopenharmony_ci * * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 4262306a36Sopenharmony_ci * * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 4362306a36Sopenharmony_ci * * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 4462306a36Sopenharmony_ci * * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 4562306a36Sopenharmony_ci * * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 4662306a36Sopenharmony_ci * * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 4762306a36Sopenharmony_ci * * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 4862306a36Sopenharmony_ci * 4962306a36Sopenharmony_ci * Author: Thomas Winischhofer <thomas@winischhofer.net> 5062306a36Sopenharmony_ci * 5162306a36Sopenharmony_ci */ 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci#ifndef _INITDEF_ 5462306a36Sopenharmony_ci#define _INITDEF_ 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci#define IS_SIS330 (SiS_Pr->ChipType == SIS_330) 5762306a36Sopenharmony_ci#define IS_SIS550 (SiS_Pr->ChipType == SIS_550) 5862306a36Sopenharmony_ci#define IS_SIS650 (SiS_Pr->ChipType == SIS_650) /* All versions, incl 651, M65x */ 5962306a36Sopenharmony_ci#define IS_SIS740 (SiS_Pr->ChipType == SIS_740) 6062306a36Sopenharmony_ci#define IS_SIS651 (SiS_Pr->SiS_SysFlags & (SF_Is651 | SF_Is652)) 6162306a36Sopenharmony_ci#define IS_SISM650 (SiS_Pr->SiS_SysFlags & (SF_IsM650 | SF_IsM652 | SF_IsM653)) 6262306a36Sopenharmony_ci#define IS_SIS65x (IS_SIS651 || IS_SISM650) /* Only special versions of 65x */ 6362306a36Sopenharmony_ci#define IS_SIS661 (SiS_Pr->ChipType == SIS_661) 6462306a36Sopenharmony_ci#define IS_SIS741 (SiS_Pr->ChipType == SIS_741) 6562306a36Sopenharmony_ci#define IS_SIS660 (SiS_Pr->ChipType == SIS_660) 6662306a36Sopenharmony_ci#define IS_SIS760 (SiS_Pr->ChipType == SIS_760) 6762306a36Sopenharmony_ci#define IS_SIS761 (SiS_Pr->ChipType == SIS_761) 6862306a36Sopenharmony_ci#define IS_SIS661741660760 (IS_SIS661 || IS_SIS741 || IS_SIS660 || IS_SIS760 || IS_SIS761) 6962306a36Sopenharmony_ci#define IS_SIS650740 ((SiS_Pr->ChipType >= SIS_650) && (SiS_Pr->ChipType < SIS_330)) 7062306a36Sopenharmony_ci#define IS_SIS550650740 (IS_SIS550 || IS_SIS650740) 7162306a36Sopenharmony_ci#define IS_SIS650740660 (IS_SIS650 || IS_SIS740 || IS_SIS661741660760) 7262306a36Sopenharmony_ci#define IS_SIS550650740660 (IS_SIS550 || IS_SIS650740660) 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci#define SISGETROMW(x) (ROMAddr[(x)] | (ROMAddr[(x)+1] << 8)) 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_ci/* SiS_VBType */ 7762306a36Sopenharmony_ci#define VB_SIS301 0x0001 7862306a36Sopenharmony_ci#define VB_SIS301B 0x0002 7962306a36Sopenharmony_ci#define VB_SIS302B 0x0004 8062306a36Sopenharmony_ci#define VB_SIS301LV 0x0008 8162306a36Sopenharmony_ci#define VB_SIS302LV 0x0010 8262306a36Sopenharmony_ci#define VB_SIS302ELV 0x0020 8362306a36Sopenharmony_ci#define VB_SIS301C 0x0040 8462306a36Sopenharmony_ci#define VB_SIS307T 0x0080 8562306a36Sopenharmony_ci#define VB_SIS307LV 0x0100 8662306a36Sopenharmony_ci#define VB_UMC 0x4000 8762306a36Sopenharmony_ci#define VB_NoLCD 0x8000 8862306a36Sopenharmony_ci#define VB_SIS30xB (VB_SIS301B | VB_SIS301C | VB_SIS302B | VB_SIS307T) 8962306a36Sopenharmony_ci#define VB_SIS30xC (VB_SIS301C | VB_SIS307T) 9062306a36Sopenharmony_ci#define VB_SISTMDS (VB_SIS301 | VB_SIS301B | VB_SIS301C | VB_SIS302B | VB_SIS307T) 9162306a36Sopenharmony_ci#define VB_SISLVDS (VB_SIS301LV | VB_SIS302LV | VB_SIS302ELV | VB_SIS307LV) 9262306a36Sopenharmony_ci#define VB_SIS30xBLV (VB_SIS30xB | VB_SISLVDS) 9362306a36Sopenharmony_ci#define VB_SIS30xCLV (VB_SIS30xC | VB_SIS302ELV | VB_SIS307LV) 9462306a36Sopenharmony_ci#define VB_SISVB (VB_SIS301 | VB_SIS30xBLV) 9562306a36Sopenharmony_ci#define VB_SISLCDA (VB_SIS302B | VB_SIS301C | VB_SIS307T | VB_SISLVDS) 9662306a36Sopenharmony_ci#define VB_SISTMDSLCDA (VB_SIS301C | VB_SIS307T) 9762306a36Sopenharmony_ci#define VB_SISPART4SCALER (VB_SIS301C | VB_SIS307T | VB_SIS302ELV | VB_SIS307LV) 9862306a36Sopenharmony_ci#define VB_SISHIVISION (VB_SIS301 | VB_SIS301B | VB_SIS302B) 9962306a36Sopenharmony_ci#define VB_SISYPBPR (VB_SIS301C | VB_SIS307T | VB_SIS301LV | VB_SIS302LV | VB_SIS302ELV | VB_SIS307LV) 10062306a36Sopenharmony_ci#define VB_SISTAP4SCALER (VB_SIS301C | VB_SIS307T | VB_SIS302ELV | VB_SIS307LV) 10162306a36Sopenharmony_ci#define VB_SISPART4OVERFLOW (VB_SIS301C | VB_SIS307T | VB_SIS302LV | VB_SIS302ELV | VB_SIS307LV) 10262306a36Sopenharmony_ci#define VB_SISPWD (VB_SIS301C | VB_SIS307T | VB_SISLVDS) 10362306a36Sopenharmony_ci#define VB_SISEMI (VB_SIS302LV | VB_SIS302ELV | VB_SIS307LV) 10462306a36Sopenharmony_ci#define VB_SISPOWER (VB_SIS301C | VB_SIS307T | VB_SIS302LV | VB_SIS302ELV | VB_SIS307LV) 10562306a36Sopenharmony_ci#define VB_SISDUALLINK (VB_SIS302LV | VB_SIS302ELV | VB_SIS307T | VB_SIS307LV) 10662306a36Sopenharmony_ci#define VB_SISVGA2 VB_SISTMDS 10762306a36Sopenharmony_ci#define VB_SISRAMDAC202 (VB_SIS301C | VB_SIS307T) 10862306a36Sopenharmony_ci 10962306a36Sopenharmony_ci/* VBInfo */ 11062306a36Sopenharmony_ci#define SetSimuScanMode 0x0001 /* CR 30 */ 11162306a36Sopenharmony_ci#define SwitchCRT2 0x0002 11262306a36Sopenharmony_ci#define SetCRT2ToAVIDEO 0x0004 11362306a36Sopenharmony_ci#define SetCRT2ToSVIDEO 0x0008 11462306a36Sopenharmony_ci#define SetCRT2ToSCART 0x0010 11562306a36Sopenharmony_ci#define SetCRT2ToLCD 0x0020 11662306a36Sopenharmony_ci#define SetCRT2ToRAMDAC 0x0040 11762306a36Sopenharmony_ci#define SetCRT2ToHiVision 0x0080 /* for SiS bridge */ 11862306a36Sopenharmony_ci#define SetCRT2ToCHYPbPr SetCRT2ToHiVision /* for Chrontel */ 11962306a36Sopenharmony_ci#define SetNTSCTV 0x0000 /* CR 31 */ 12062306a36Sopenharmony_ci#define SetPALTV 0x0100 /* Deprecated here, now in TVMode */ 12162306a36Sopenharmony_ci#define SetInSlaveMode 0x0200 12262306a36Sopenharmony_ci#define SetNotSimuMode 0x0400 12362306a36Sopenharmony_ci#define SetNotSimuTVMode SetNotSimuMode 12462306a36Sopenharmony_ci#define SetDispDevSwitch 0x0800 12562306a36Sopenharmony_ci#define SetCRT2ToYPbPr525750 0x0800 12662306a36Sopenharmony_ci#define LoadDACFlag 0x1000 12762306a36Sopenharmony_ci#define DisableCRT2Display 0x2000 12862306a36Sopenharmony_ci#define DriverMode 0x4000 12962306a36Sopenharmony_ci#define HotKeySwitch 0x8000 13062306a36Sopenharmony_ci#define SetCRT2ToLCDA 0x8000 13162306a36Sopenharmony_ci 13262306a36Sopenharmony_ci/* v-- Needs change in sis_vga.c if changed (GPIO) --v */ 13362306a36Sopenharmony_ci#define SetCRT2ToTV (SetCRT2ToYPbPr525750|SetCRT2ToHiVision|SetCRT2ToSCART|SetCRT2ToSVIDEO|SetCRT2ToAVIDEO) 13462306a36Sopenharmony_ci#define SetCRT2ToTVNoYPbPrHiVision (SetCRT2ToSCART | SetCRT2ToSVIDEO | SetCRT2ToAVIDEO) 13562306a36Sopenharmony_ci#define SetCRT2ToTVNoHiVision (SetCRT2ToYPbPr525750 | SetCRT2ToSCART | SetCRT2ToSVIDEO | SetCRT2ToAVIDEO) 13662306a36Sopenharmony_ci 13762306a36Sopenharmony_ci/* SiS_ModeType */ 13862306a36Sopenharmony_ci#define ModeText 0x00 13962306a36Sopenharmony_ci#define ModeCGA 0x01 14062306a36Sopenharmony_ci#define ModeEGA 0x02 14162306a36Sopenharmony_ci#define ModeVGA 0x03 14262306a36Sopenharmony_ci#define Mode15Bpp 0x04 14362306a36Sopenharmony_ci#define Mode16Bpp 0x05 14462306a36Sopenharmony_ci#define Mode24Bpp 0x06 14562306a36Sopenharmony_ci#define Mode32Bpp 0x07 14662306a36Sopenharmony_ci 14762306a36Sopenharmony_ci#define ModeTypeMask 0x07 14862306a36Sopenharmony_ci#define IsTextMode 0x07 14962306a36Sopenharmony_ci 15062306a36Sopenharmony_ci#define DACInfoFlag 0x0018 15162306a36Sopenharmony_ci#define MemoryInfoFlag 0x01E0 15262306a36Sopenharmony_ci#define MemorySizeShift 5 15362306a36Sopenharmony_ci 15462306a36Sopenharmony_ci/* modeflag */ 15562306a36Sopenharmony_ci#define Charx8Dot 0x0200 15662306a36Sopenharmony_ci#define LineCompareOff 0x0400 15762306a36Sopenharmony_ci#define CRT2Mode 0x0800 15862306a36Sopenharmony_ci#define HalfDCLK 0x1000 15962306a36Sopenharmony_ci#define NoSupportSimuTV 0x2000 16062306a36Sopenharmony_ci#define NoSupportLCDScale 0x4000 /* SiS bridge: No scaling possible (no matter what panel) */ 16162306a36Sopenharmony_ci#define DoubleScanMode 0x8000 16262306a36Sopenharmony_ci 16362306a36Sopenharmony_ci/* Infoflag */ 16462306a36Sopenharmony_ci#define SupportTV 0x0008 16562306a36Sopenharmony_ci#define SupportTV1024 0x0800 16662306a36Sopenharmony_ci#define SupportCHTV 0x0800 16762306a36Sopenharmony_ci#define Support64048060Hz 0x0800 /* Special for 640x480 LCD */ 16862306a36Sopenharmony_ci#define SupportHiVision 0x0010 16962306a36Sopenharmony_ci#define SupportYPbPr750p 0x1000 17062306a36Sopenharmony_ci#define SupportLCD 0x0020 17162306a36Sopenharmony_ci#define SupportRAMDAC2 0x0040 /* All (<= 100Mhz) */ 17262306a36Sopenharmony_ci#define SupportRAMDAC2_135 0x0100 /* All except DH (<= 135Mhz) */ 17362306a36Sopenharmony_ci#define SupportRAMDAC2_162 0x0200 /* B, C (<= 162Mhz) */ 17462306a36Sopenharmony_ci#define SupportRAMDAC2_202 0x0400 /* C (<= 202Mhz) */ 17562306a36Sopenharmony_ci#define InterlaceMode 0x0080 17662306a36Sopenharmony_ci#define SyncPP 0x0000 17762306a36Sopenharmony_ci#define HaveWideTiming 0x2000 /* Have specific wide- and non-wide timing */ 17862306a36Sopenharmony_ci#define SyncPN 0x4000 17962306a36Sopenharmony_ci#define SyncNP 0x8000 18062306a36Sopenharmony_ci#define SyncNN 0xc000 18162306a36Sopenharmony_ci 18262306a36Sopenharmony_ci/* SetFlag */ 18362306a36Sopenharmony_ci#define ProgrammingCRT2 0x0001 18462306a36Sopenharmony_ci#define LowModeTests 0x0002 18562306a36Sopenharmony_ci/* #define TVSimuMode 0x0002 - deprecated */ 18662306a36Sopenharmony_ci/* #define RPLLDIV2XO 0x0004 - deprecated */ 18762306a36Sopenharmony_ci#define LCDVESATiming 0x0008 18862306a36Sopenharmony_ci#define EnableLVDSDDA 0x0010 18962306a36Sopenharmony_ci#define SetDispDevSwitchFlag 0x0020 19062306a36Sopenharmony_ci#define CheckWinDos 0x0040 19162306a36Sopenharmony_ci#define SetDOSMode 0x0080 19262306a36Sopenharmony_ci 19362306a36Sopenharmony_ci/* TVMode flag */ 19462306a36Sopenharmony_ci#define TVSetPAL 0x0001 19562306a36Sopenharmony_ci#define TVSetNTSCJ 0x0002 19662306a36Sopenharmony_ci#define TVSetPALM 0x0004 19762306a36Sopenharmony_ci#define TVSetPALN 0x0008 19862306a36Sopenharmony_ci#define TVSetCHOverScan 0x0010 19962306a36Sopenharmony_ci#define TVSetYPbPr525i 0x0020 /* new 0x10 */ 20062306a36Sopenharmony_ci#define TVSetYPbPr525p 0x0040 /* new 0x20 */ 20162306a36Sopenharmony_ci#define TVSetYPbPr750p 0x0080 /* new 0x40 */ 20262306a36Sopenharmony_ci#define TVSetHiVision 0x0100 /* new 0x80; = 1080i, software-wise identical */ 20362306a36Sopenharmony_ci#define TVSetTVSimuMode 0x0200 /* new 0x200, prev. 0x800 */ 20462306a36Sopenharmony_ci#define TVRPLLDIV2XO 0x0400 /* prev 0x1000 */ 20562306a36Sopenharmony_ci#define TVSetNTSC1024 0x0800 /* new 0x100, prev. 0x2000 */ 20662306a36Sopenharmony_ci#define TVSet525p1024 0x1000 /* TW */ 20762306a36Sopenharmony_ci#define TVAspect43 0x2000 20862306a36Sopenharmony_ci#define TVAspect169 0x4000 20962306a36Sopenharmony_ci#define TVAspect43LB 0x8000 21062306a36Sopenharmony_ci 21162306a36Sopenharmony_ci/* YPbPr flag (>=315, <661; converted to TVMode) */ 21262306a36Sopenharmony_ci#define YPbPr525p 0x0001 21362306a36Sopenharmony_ci#define YPbPr750p 0x0002 21462306a36Sopenharmony_ci#define YPbPr525i 0x0004 21562306a36Sopenharmony_ci#define YPbPrHiVision 0x0008 21662306a36Sopenharmony_ci#define YPbPrModeMask (YPbPr750p | YPbPr525p | YPbPr525i | YPbPrHiVision) 21762306a36Sopenharmony_ci 21862306a36Sopenharmony_ci/* SysFlags (to identify special versions) */ 21962306a36Sopenharmony_ci#define SF_Is651 0x0001 22062306a36Sopenharmony_ci#define SF_IsM650 0x0002 22162306a36Sopenharmony_ci#define SF_Is652 0x0004 22262306a36Sopenharmony_ci#define SF_IsM652 0x0008 22362306a36Sopenharmony_ci#define SF_IsM653 0x0010 22462306a36Sopenharmony_ci#define SF_IsM661 0x0020 22562306a36Sopenharmony_ci#define SF_IsM741 0x0040 22662306a36Sopenharmony_ci#define SF_IsM760 0x0080 22762306a36Sopenharmony_ci#define SF_760UMA 0x4000 /* 76x: We have UMA */ 22862306a36Sopenharmony_ci#define SF_760LFB 0x8000 /* 76x: We have LFB */ 22962306a36Sopenharmony_ci 23062306a36Sopenharmony_ci/* CR32 (Newer 630, and 315 series) 23162306a36Sopenharmony_ci 23262306a36Sopenharmony_ci [0] VB connected with CVBS 23362306a36Sopenharmony_ci [1] VB connected with SVHS 23462306a36Sopenharmony_ci [2] VB connected with SCART 23562306a36Sopenharmony_ci [3] VB connected with LCD 23662306a36Sopenharmony_ci [4] VB connected with CRT2 (secondary VGA) 23762306a36Sopenharmony_ci [5] CRT1 monitor is connected 23862306a36Sopenharmony_ci [6] VB connected with Hi-Vision TV 23962306a36Sopenharmony_ci [7] <= 330: VB connected with DVI combo connector 24062306a36Sopenharmony_ci >= 661: VB connected to YPbPr 24162306a36Sopenharmony_ci*/ 24262306a36Sopenharmony_ci 24362306a36Sopenharmony_ci/* CR35 (300 series only) */ 24462306a36Sopenharmony_ci#define TVOverScan 0x10 24562306a36Sopenharmony_ci#define TVOverScanShift 4 24662306a36Sopenharmony_ci 24762306a36Sopenharmony_ci/* CR35 (661 series only) 24862306a36Sopenharmony_ci [0] 1 = PAL, 0 = NTSC 24962306a36Sopenharmony_ci [1] 1 = NTSC-J (if D0 = 0) 25062306a36Sopenharmony_ci [2] 1 = PALM (if D0 = 1) 25162306a36Sopenharmony_ci [3] 1 = PALN (if D0 = 1) 25262306a36Sopenharmony_ci [4] 1 = Overscan (Chrontel only) 25362306a36Sopenharmony_ci [7:5] (only if D2 in CR38 is set) 25462306a36Sopenharmony_ci 000 525i 25562306a36Sopenharmony_ci 001 525p 25662306a36Sopenharmony_ci 010 750p 25762306a36Sopenharmony_ci 011 1080i (or HiVision on 301, 301B) 25862306a36Sopenharmony_ci*/ 25962306a36Sopenharmony_ci 26062306a36Sopenharmony_ci/* CR37 26162306a36Sopenharmony_ci [0] Set 24/18 bit (0/1) RGB to LVDS/TMDS transmitter (set by BIOS) 26262306a36Sopenharmony_ci [3:1] External chip 26362306a36Sopenharmony_ci 300 series: 26462306a36Sopenharmony_ci 001 SiS301 (never seen) 26562306a36Sopenharmony_ci 010 LVDS 26662306a36Sopenharmony_ci 011 LVDS + Tumpion Zurac 26762306a36Sopenharmony_ci 100 LVDS + Chrontel 7005 26862306a36Sopenharmony_ci 110 Chrontel 7005 26962306a36Sopenharmony_ci 315/330 series 27062306a36Sopenharmony_ci 001 SiS30x (never seen) 27162306a36Sopenharmony_ci 010 LVDS 27262306a36Sopenharmony_ci 011 LVDS + Chrontel 7019 27362306a36Sopenharmony_ci 660 series [2:1] only: 27462306a36Sopenharmony_ci reserved (chip type now in CR38) 27562306a36Sopenharmony_ci All other combinations reserved 27662306a36Sopenharmony_ci [3] 661 only: Pass 1:1 data 27762306a36Sopenharmony_ci [4] LVDS: 0: Panel Link expands / 1: Panel Link does not expand 27862306a36Sopenharmony_ci 30x: 0: Bridge scales / 1: Bridge does not scale = Panel scales (if possible) 27962306a36Sopenharmony_ci [5] LCD polarity select 28062306a36Sopenharmony_ci 0: VESA DMT Standard 28162306a36Sopenharmony_ci 1: EDID 2.x defined 28262306a36Sopenharmony_ci [6] LCD horizontal polarity select 28362306a36Sopenharmony_ci 0: High active 28462306a36Sopenharmony_ci 1: Low active 28562306a36Sopenharmony_ci [7] LCD vertical polarity select 28662306a36Sopenharmony_ci 0: High active 28762306a36Sopenharmony_ci 1: Low active 28862306a36Sopenharmony_ci*/ 28962306a36Sopenharmony_ci 29062306a36Sopenharmony_ci/* CR37: LCDInfo */ 29162306a36Sopenharmony_ci#define LCDRGB18Bit 0x0001 29262306a36Sopenharmony_ci#define LCDNonExpanding 0x0010 29362306a36Sopenharmony_ci#define LCDSync 0x0020 29462306a36Sopenharmony_ci#define LCDPass11 0x0100 /* 0: center screen, 1: Pass 1:1 data */ 29562306a36Sopenharmony_ci#define LCDDualLink 0x0200 29662306a36Sopenharmony_ci 29762306a36Sopenharmony_ci#define DontExpandLCD LCDNonExpanding 29862306a36Sopenharmony_ci#define LCDNonExpandingShift 4 29962306a36Sopenharmony_ci#define DontExpandLCDShift LCDNonExpandingShift 30062306a36Sopenharmony_ci#define LCDSyncBit 0x00e0 30162306a36Sopenharmony_ci#define LCDSyncShift 6 30262306a36Sopenharmony_ci 30362306a36Sopenharmony_ci/* CR38 (315 series) */ 30462306a36Sopenharmony_ci#define EnableDualEdge 0x01 30562306a36Sopenharmony_ci#define SetToLCDA 0x02 /* LCD channel A (301C/302B/30x(E)LV and 650+LVDS only) */ 30662306a36Sopenharmony_ci#define EnableCHScart 0x04 /* Scart on Ch7019 (unofficial definition - TW) */ 30762306a36Sopenharmony_ci#define EnableCHYPbPr 0x08 /* YPbPr on Ch7019 (480i HDTV); only on 650/Ch7019 systems */ 30862306a36Sopenharmony_ci#define EnableSiSYPbPr 0x08 /* Enable YPbPr mode (30xLV/301C only) */ 30962306a36Sopenharmony_ci#define EnableYPbPr525i 0x00 /* Enable 525i YPbPr mode (30xLV/301C only) (mask 0x30) */ 31062306a36Sopenharmony_ci#define EnableYPbPr525p 0x10 /* Enable 525p YPbPr mode (30xLV/301C only) (mask 0x30) */ 31162306a36Sopenharmony_ci#define EnableYPbPr750p 0x20 /* Enable 750p YPbPr mode (30xLV/301C only) (mask 0x30) */ 31262306a36Sopenharmony_ci#define EnableYPbPr1080i 0x30 /* Enable 1080i YPbPr mode (30xLV/301C only) (mask 0x30) */ 31362306a36Sopenharmony_ci#define EnablePALM 0x40 /* 1 = Set PALM */ 31462306a36Sopenharmony_ci#define EnablePALN 0x80 /* 1 = Set PALN */ 31562306a36Sopenharmony_ci#define EnableNTSCJ EnablePALM /* Not BIOS */ 31662306a36Sopenharmony_ci 31762306a36Sopenharmony_ci/* CR38 (661 and later) 31862306a36Sopenharmony_ci D[7:5] 000 No VB 31962306a36Sopenharmony_ci 001 301 series VB 32062306a36Sopenharmony_ci 010 LVDS 32162306a36Sopenharmony_ci 011 Chrontel 7019 32262306a36Sopenharmony_ci 100 Conexant 32362306a36Sopenharmony_ci D2 Enable YPbPr output (see CR35) 32462306a36Sopenharmony_ci D[1:0] LCDA (like before) 32562306a36Sopenharmony_ci*/ 32662306a36Sopenharmony_ci 32762306a36Sopenharmony_ci#define EnablePALMN 0x40 /* Romflag: 1 = Allow PALM/PALN */ 32862306a36Sopenharmony_ci 32962306a36Sopenharmony_ci/* CR39 (650 only) */ 33062306a36Sopenharmony_ci#define LCDPass1_1 0x01 /* 0: center screen, 1: pass 1:1 data output */ 33162306a36Sopenharmony_ci#define Enable302LV_DualLink 0x04 /* 302LV only; enable dual link */ 33262306a36Sopenharmony_ci 33362306a36Sopenharmony_ci/* CR39 (661 and later) 33462306a36Sopenharmony_ci D[7] LVDS (SiS or third party) 33562306a36Sopenharmony_ci D[1:0] YPbPr Aspect Ratio 33662306a36Sopenharmony_ci 00 4:3 letterbox 33762306a36Sopenharmony_ci 01 4:3 33862306a36Sopenharmony_ci 10 16:9 33962306a36Sopenharmony_ci 11 4:3 34062306a36Sopenharmony_ci*/ 34162306a36Sopenharmony_ci 34262306a36Sopenharmony_ci/* CR3B (651+301C) 34362306a36Sopenharmony_ci D[1:0] YPbPr Aspect Ratio 34462306a36Sopenharmony_ci ? 34562306a36Sopenharmony_ci*/ 34662306a36Sopenharmony_ci 34762306a36Sopenharmony_ci/* CR79 (315/330 series only; not 661 and later) 34862306a36Sopenharmony_ci [3-0] Notify driver 34962306a36Sopenharmony_ci 0001 Mode Switch event (set by BIOS) 35062306a36Sopenharmony_ci 0010 Epansion On/Off event 35162306a36Sopenharmony_ci 0011 TV UnderScan/OverScan event 35262306a36Sopenharmony_ci 0100 Set Brightness event 35362306a36Sopenharmony_ci 0101 Set Contrast event 35462306a36Sopenharmony_ci 0110 Set Mute event 35562306a36Sopenharmony_ci 0111 Set Volume Up/Down event 35662306a36Sopenharmony_ci [4] Enable Backlight Control by BIOS/driver 35762306a36Sopenharmony_ci (set by driver; set means that the BIOS should 35862306a36Sopenharmony_ci not touch the backlight registers because eg. 35962306a36Sopenharmony_ci the driver already switched off the backlight) 36062306a36Sopenharmony_ci [5] PAL/NTSC (set by BIOS) 36162306a36Sopenharmony_ci [6] Expansion On/Off (set by BIOS; copied to CR32[4]) 36262306a36Sopenharmony_ci [7] TV UnderScan/OverScan (set by BIOS) 36362306a36Sopenharmony_ci*/ 36462306a36Sopenharmony_ci 36562306a36Sopenharmony_ci/* CR7C - 661 and later 36662306a36Sopenharmony_ci [7] DualEdge enabled (or: to be enabled) 36762306a36Sopenharmony_ci [6] CRT2 = TV/LCD/VGA enabled (or: to be enabled) 36862306a36Sopenharmony_ci [5] Init done (set at end of SiS_Init) 36962306a36Sopenharmony_ci {4] LVDS LCD capabilities 37062306a36Sopenharmony_ci [3] LVDS LCD capabilities 37162306a36Sopenharmony_ci [2] LVDS LCD capabilities (PWD) 37262306a36Sopenharmony_ci [1] LVDS LCD capabilities (PWD) 37362306a36Sopenharmony_ci [0] LVDS=1, TMDS=0 (SiS or third party) 37462306a36Sopenharmony_ci*/ 37562306a36Sopenharmony_ci 37662306a36Sopenharmony_ci/* CR7E - 661 and later 37762306a36Sopenharmony_ci VBType: 37862306a36Sopenharmony_ci [7] LVDS (third party) 37962306a36Sopenharmony_ci [3] 301C 38062306a36Sopenharmony_ci [2] 302LV 38162306a36Sopenharmony_ci [1] 301LV 38262306a36Sopenharmony_ci [0] 301B 38362306a36Sopenharmony_ci*/ 38462306a36Sopenharmony_ci 38562306a36Sopenharmony_ci/* LCDResInfo */ 38662306a36Sopenharmony_ci#define Panel300_800x600 0x01 /* CR36 */ 38762306a36Sopenharmony_ci#define Panel300_1024x768 0x02 38862306a36Sopenharmony_ci#define Panel300_1280x1024 0x03 38962306a36Sopenharmony_ci#define Panel300_1280x960 0x04 39062306a36Sopenharmony_ci#define Panel300_640x480 0x05 39162306a36Sopenharmony_ci#define Panel300_1024x600 0x06 39262306a36Sopenharmony_ci#define Panel300_1152x768 0x07 39362306a36Sopenharmony_ci#define Panel300_1280x768 0x0a 39462306a36Sopenharmony_ci#define Panel300_Custom 0x0f 39562306a36Sopenharmony_ci#define Panel300_Barco1366 0x10 39662306a36Sopenharmony_ci 39762306a36Sopenharmony_ci#define Panel310_800x600 0x01 39862306a36Sopenharmony_ci#define Panel310_1024x768 0x02 39962306a36Sopenharmony_ci#define Panel310_1280x1024 0x03 40062306a36Sopenharmony_ci#define Panel310_640x480 0x04 40162306a36Sopenharmony_ci#define Panel310_1024x600 0x05 40262306a36Sopenharmony_ci#define Panel310_1152x864 0x06 40362306a36Sopenharmony_ci#define Panel310_1280x960 0x07 40462306a36Sopenharmony_ci#define Panel310_1152x768 0x08 /* LVDS only */ 40562306a36Sopenharmony_ci#define Panel310_1400x1050 0x09 40662306a36Sopenharmony_ci#define Panel310_1280x768 0x0a 40762306a36Sopenharmony_ci#define Panel310_1600x1200 0x0b 40862306a36Sopenharmony_ci#define Panel310_320x240_2 0x0c /* xSTN */ 40962306a36Sopenharmony_ci#define Panel310_320x240_3 0x0d /* xSTN */ 41062306a36Sopenharmony_ci#define Panel310_320x240_1 0x0e /* xSTN - This is fake, can be any */ 41162306a36Sopenharmony_ci#define Panel310_Custom 0x0f 41262306a36Sopenharmony_ci 41362306a36Sopenharmony_ci#define Panel661_800x600 0x01 41462306a36Sopenharmony_ci#define Panel661_1024x768 0x02 41562306a36Sopenharmony_ci#define Panel661_1280x1024 0x03 41662306a36Sopenharmony_ci#define Panel661_640x480 0x04 41762306a36Sopenharmony_ci#define Panel661_1024x600 0x05 41862306a36Sopenharmony_ci#define Panel661_1152x864 0x06 41962306a36Sopenharmony_ci#define Panel661_1280x960 0x07 42062306a36Sopenharmony_ci#define Panel661_1280x854 0x08 42162306a36Sopenharmony_ci#define Panel661_1400x1050 0x09 42262306a36Sopenharmony_ci#define Panel661_1280x768 0x0a 42362306a36Sopenharmony_ci#define Panel661_1600x1200 0x0b 42462306a36Sopenharmony_ci#define Panel661_1280x800 0x0c 42562306a36Sopenharmony_ci#define Panel661_1680x1050 0x0d 42662306a36Sopenharmony_ci#define Panel661_1280x720 0x0e 42762306a36Sopenharmony_ci#define Panel661_Custom 0x0f 42862306a36Sopenharmony_ci 42962306a36Sopenharmony_ci#define Panel_800x600 0x01 /* Unified values */ 43062306a36Sopenharmony_ci#define Panel_1024x768 0x02 /* MUST match BIOS values from 0-e */ 43162306a36Sopenharmony_ci#define Panel_1280x1024 0x03 43262306a36Sopenharmony_ci#define Panel_640x480 0x04 43362306a36Sopenharmony_ci#define Panel_1024x600 0x05 43462306a36Sopenharmony_ci#define Panel_1152x864 0x06 43562306a36Sopenharmony_ci#define Panel_1280x960 0x07 43662306a36Sopenharmony_ci#define Panel_1152x768 0x08 /* LVDS only */ 43762306a36Sopenharmony_ci#define Panel_1400x1050 0x09 43862306a36Sopenharmony_ci#define Panel_1280x768 0x0a /* 30xB/C and LVDS only (BIOS: all) */ 43962306a36Sopenharmony_ci#define Panel_1600x1200 0x0b 44062306a36Sopenharmony_ci#define Panel_1280x800 0x0c /* 661etc (TMDS) */ 44162306a36Sopenharmony_ci#define Panel_1680x1050 0x0d /* 661etc */ 44262306a36Sopenharmony_ci#define Panel_1280x720 0x0e /* 661etc */ 44362306a36Sopenharmony_ci#define Panel_Custom 0x0f /* MUST BE 0x0f (for DVI DDC detection) */ 44462306a36Sopenharmony_ci#define Panel_320x240_1 0x10 /* SiS 550 xSTN */ 44562306a36Sopenharmony_ci#define Panel_Barco1366 0x11 44662306a36Sopenharmony_ci#define Panel_848x480 0x12 44762306a36Sopenharmony_ci#define Panel_320x240_2 0x13 /* SiS 550 xSTN */ 44862306a36Sopenharmony_ci#define Panel_320x240_3 0x14 /* SiS 550 xSTN */ 44962306a36Sopenharmony_ci#define Panel_1280x768_2 0x15 /* 30xLV */ 45062306a36Sopenharmony_ci#define Panel_1280x768_3 0x16 /* (unused) */ 45162306a36Sopenharmony_ci#define Panel_1280x800_2 0x17 /* 30xLV */ 45262306a36Sopenharmony_ci#define Panel_856x480 0x18 45362306a36Sopenharmony_ci#define Panel_1280x854 0x19 /* 661etc */ 45462306a36Sopenharmony_ci 45562306a36Sopenharmony_ci/* Index in ModeResInfo table */ 45662306a36Sopenharmony_ci#define SIS_RI_320x200 0 45762306a36Sopenharmony_ci#define SIS_RI_320x240 1 45862306a36Sopenharmony_ci#define SIS_RI_320x400 2 45962306a36Sopenharmony_ci#define SIS_RI_400x300 3 46062306a36Sopenharmony_ci#define SIS_RI_512x384 4 46162306a36Sopenharmony_ci#define SIS_RI_640x400 5 46262306a36Sopenharmony_ci#define SIS_RI_640x480 6 46362306a36Sopenharmony_ci#define SIS_RI_800x600 7 46462306a36Sopenharmony_ci#define SIS_RI_1024x768 8 46562306a36Sopenharmony_ci#define SIS_RI_1280x1024 9 46662306a36Sopenharmony_ci#define SIS_RI_1600x1200 10 46762306a36Sopenharmony_ci#define SIS_RI_1920x1440 11 46862306a36Sopenharmony_ci#define SIS_RI_2048x1536 12 46962306a36Sopenharmony_ci#define SIS_RI_720x480 13 47062306a36Sopenharmony_ci#define SIS_RI_720x576 14 47162306a36Sopenharmony_ci#define SIS_RI_1280x960 15 47262306a36Sopenharmony_ci#define SIS_RI_800x480 16 47362306a36Sopenharmony_ci#define SIS_RI_1024x576 17 47462306a36Sopenharmony_ci#define SIS_RI_1280x720 18 47562306a36Sopenharmony_ci#define SIS_RI_856x480 19 47662306a36Sopenharmony_ci#define SIS_RI_1280x768 20 47762306a36Sopenharmony_ci#define SIS_RI_1400x1050 21 47862306a36Sopenharmony_ci#define SIS_RI_1152x864 22 /* Up to here SiS conforming */ 47962306a36Sopenharmony_ci#define SIS_RI_848x480 23 48062306a36Sopenharmony_ci#define SIS_RI_1360x768 24 48162306a36Sopenharmony_ci#define SIS_RI_1024x600 25 48262306a36Sopenharmony_ci#define SIS_RI_1152x768 26 48362306a36Sopenharmony_ci#define SIS_RI_768x576 27 48462306a36Sopenharmony_ci#define SIS_RI_1360x1024 28 48562306a36Sopenharmony_ci#define SIS_RI_1680x1050 29 48662306a36Sopenharmony_ci#define SIS_RI_1280x800 30 48762306a36Sopenharmony_ci#define SIS_RI_1920x1080 31 48862306a36Sopenharmony_ci#define SIS_RI_960x540 32 48962306a36Sopenharmony_ci#define SIS_RI_960x600 33 49062306a36Sopenharmony_ci#define SIS_RI_1280x854 34 49162306a36Sopenharmony_ci 49262306a36Sopenharmony_ci/* CR5F */ 49362306a36Sopenharmony_ci#define IsM650 0x80 49462306a36Sopenharmony_ci 49562306a36Sopenharmony_ci/* Timing data */ 49662306a36Sopenharmony_ci#define NTSCHT 1716 49762306a36Sopenharmony_ci#define NTSC2HT 1920 49862306a36Sopenharmony_ci#define NTSCVT 525 49962306a36Sopenharmony_ci#define PALHT 1728 50062306a36Sopenharmony_ci#define PALVT 625 50162306a36Sopenharmony_ci#define StHiTVHT 892 50262306a36Sopenharmony_ci#define StHiTVVT 1126 50362306a36Sopenharmony_ci#define StHiTextTVHT 1000 50462306a36Sopenharmony_ci#define StHiTextTVVT 1126 50562306a36Sopenharmony_ci#define ExtHiTVHT 2100 50662306a36Sopenharmony_ci#define ExtHiTVVT 1125 50762306a36Sopenharmony_ci 50862306a36Sopenharmony_ci/* Indices in (VB)VCLKData tables */ 50962306a36Sopenharmony_ci 51062306a36Sopenharmony_ci#define VCLK28 0x00 /* Index in VCLKData table (300 and 315) */ 51162306a36Sopenharmony_ci#define VCLK40 0x04 /* Index in VCLKData table (300 and 315) */ 51262306a36Sopenharmony_ci#define VCLK65_300 0x09 /* Index in VCLKData table (300) */ 51362306a36Sopenharmony_ci#define VCLK108_2_300 0x14 /* Index in VCLKData table (300) */ 51462306a36Sopenharmony_ci#define VCLK81_300 0x3f /* Index in VCLKData table (300) */ 51562306a36Sopenharmony_ci#define VCLK108_3_300 0x42 /* Index in VCLKData table (300) */ 51662306a36Sopenharmony_ci#define VCLK100_300 0x43 /* Index in VCLKData table (300) */ 51762306a36Sopenharmony_ci#define VCLK34_300 0x3d /* Index in VCLKData table (300) */ 51862306a36Sopenharmony_ci#define VCLK_CUSTOM_300 0x47 51962306a36Sopenharmony_ci 52062306a36Sopenharmony_ci#define VCLK65_315 0x0b /* Indices in (VB)VCLKData table (315) */ 52162306a36Sopenharmony_ci#define VCLK108_2_315 0x19 52262306a36Sopenharmony_ci#define VCLK81_315 0x5b 52362306a36Sopenharmony_ci#define VCLK162_315 0x5e 52462306a36Sopenharmony_ci#define VCLK108_3_315 0x45 52562306a36Sopenharmony_ci#define VCLK100_315 0x46 52662306a36Sopenharmony_ci#define VCLK34_315 0x55 52762306a36Sopenharmony_ci#define VCLK68_315 0x0d 52862306a36Sopenharmony_ci#define VCLK_1280x800_315_2 0x5c 52962306a36Sopenharmony_ci#define VCLK121_315 0x5d 53062306a36Sopenharmony_ci#define VCLK130_315 0x72 53162306a36Sopenharmony_ci#define VCLK_1280x720 0x5f 53262306a36Sopenharmony_ci#define VCLK_1280x768_2 0x60 53362306a36Sopenharmony_ci#define VCLK_1280x768_3 0x61 /* (unused?) */ 53462306a36Sopenharmony_ci#define VCLK_CUSTOM_315 0x62 53562306a36Sopenharmony_ci#define VCLK_1280x720_2 0x63 53662306a36Sopenharmony_ci#define VCLK_720x480 0x67 53762306a36Sopenharmony_ci#define VCLK_720x576 0x68 53862306a36Sopenharmony_ci#define VCLK_768x576 0x68 53962306a36Sopenharmony_ci#define VCLK_848x480 0x65 54062306a36Sopenharmony_ci#define VCLK_856x480 0x66 54162306a36Sopenharmony_ci#define VCLK_800x480 0x65 54262306a36Sopenharmony_ci#define VCLK_1024x576 0x51 54362306a36Sopenharmony_ci#define VCLK_1152x864 0x64 54462306a36Sopenharmony_ci#define VCLK_1360x768 0x58 54562306a36Sopenharmony_ci#define VCLK_1280x800_315 0x6c 54662306a36Sopenharmony_ci#define VCLK_1280x854 0x76 54762306a36Sopenharmony_ci 54862306a36Sopenharmony_ci#define TVCLKBASE_300 0x21 /* Indices on TV clocks in VCLKData table (300) */ 54962306a36Sopenharmony_ci#define TVCLKBASE_315 0x3a /* Indices on TV clocks in (VB)VCLKData table (315) */ 55062306a36Sopenharmony_ci#define TVVCLKDIV2 0x00 /* Index relative to TVCLKBASE */ 55162306a36Sopenharmony_ci#define TVVCLK 0x01 /* Index relative to TVCLKBASE */ 55262306a36Sopenharmony_ci#define HiTVVCLKDIV2 0x02 /* Index relative to TVCLKBASE */ 55362306a36Sopenharmony_ci#define HiTVVCLK 0x03 /* Index relative to TVCLKBASE */ 55462306a36Sopenharmony_ci#define HiTVSimuVCLK 0x04 /* Index relative to TVCLKBASE */ 55562306a36Sopenharmony_ci#define HiTVTextVCLK 0x05 /* Index relative to TVCLKBASE */ 55662306a36Sopenharmony_ci#define YPbPr750pVCLK 0x25 /* Index relative to TVCLKBASE; was 0x0f NOT relative */ 55762306a36Sopenharmony_ci 55862306a36Sopenharmony_ci/* ------------------------------ */ 55962306a36Sopenharmony_ci 56062306a36Sopenharmony_ci#define SetSCARTOutput 0x01 56162306a36Sopenharmony_ci 56262306a36Sopenharmony_ci#define HotPlugFunction 0x08 56362306a36Sopenharmony_ci 56462306a36Sopenharmony_ci#define StStructSize 0x06 56562306a36Sopenharmony_ci 56662306a36Sopenharmony_ci#define SIS_VIDEO_CAPTURE 0x00 - 0x30 56762306a36Sopenharmony_ci#define SIS_VIDEO_PLAYBACK 0x02 - 0x30 56862306a36Sopenharmony_ci#define SIS_CRT2_PORT_04 0x04 - 0x30 56962306a36Sopenharmony_ci#define SIS_CRT2_PORT_10 0x10 - 0x30 57062306a36Sopenharmony_ci#define SIS_CRT2_PORT_12 0x12 - 0x30 57162306a36Sopenharmony_ci#define SIS_CRT2_PORT_14 0x14 - 0x30 57262306a36Sopenharmony_ci 57362306a36Sopenharmony_ci#define ADR_CRT2PtrData 0x20E 57462306a36Sopenharmony_ci#define offset_Zurac 0x210 /* TW: Trumpion Zurac data pointer */ 57562306a36Sopenharmony_ci#define ADR_LVDSDesPtrData 0x212 57662306a36Sopenharmony_ci#define ADR_LVDSCRT1DataPtr 0x214 57762306a36Sopenharmony_ci#define ADR_CHTVVCLKPtr 0x216 57862306a36Sopenharmony_ci#define ADR_CHTVRegDataPtr 0x218 57962306a36Sopenharmony_ci 58062306a36Sopenharmony_ci#define LCDDataLen 8 58162306a36Sopenharmony_ci#define HiTVDataLen 12 58262306a36Sopenharmony_ci#define TVDataLen 16 58362306a36Sopenharmony_ci 58462306a36Sopenharmony_ci#define LVDSDataLen 6 58562306a36Sopenharmony_ci#define LVDSDesDataLen 3 58662306a36Sopenharmony_ci#define ActiveNonExpanding 0x40 58762306a36Sopenharmony_ci#define ActiveNonExpandingShift 6 58862306a36Sopenharmony_ci#define ActivePAL 0x20 58962306a36Sopenharmony_ci#define ActivePALShift 5 59062306a36Sopenharmony_ci#define ModeSwitchStatus 0x0F 59162306a36Sopenharmony_ci#define SoftTVType 0x40 59262306a36Sopenharmony_ci#define SoftSettingAddr 0x52 59362306a36Sopenharmony_ci#define ModeSettingAddr 0x53 59462306a36Sopenharmony_ci 59562306a36Sopenharmony_ci#define _PanelType00 0x00 59662306a36Sopenharmony_ci#define _PanelType01 0x08 59762306a36Sopenharmony_ci#define _PanelType02 0x10 59862306a36Sopenharmony_ci#define _PanelType03 0x18 59962306a36Sopenharmony_ci#define _PanelType04 0x20 60062306a36Sopenharmony_ci#define _PanelType05 0x28 60162306a36Sopenharmony_ci#define _PanelType06 0x30 60262306a36Sopenharmony_ci#define _PanelType07 0x38 60362306a36Sopenharmony_ci#define _PanelType08 0x40 60462306a36Sopenharmony_ci#define _PanelType09 0x48 60562306a36Sopenharmony_ci#define _PanelType0A 0x50 60662306a36Sopenharmony_ci#define _PanelType0B 0x58 60762306a36Sopenharmony_ci#define _PanelType0C 0x60 60862306a36Sopenharmony_ci#define _PanelType0D 0x68 60962306a36Sopenharmony_ci#define _PanelType0E 0x70 61062306a36Sopenharmony_ci#define _PanelType0F 0x78 61162306a36Sopenharmony_ci 61262306a36Sopenharmony_ci#define PRIMARY_VGA 0 /* 1: SiS is primary vga 0:SiS is secondary vga */ 61362306a36Sopenharmony_ci 61462306a36Sopenharmony_ci#define BIOSIDCodeAddr 0x235 /* Offsets to ptrs in BIOS image */ 61562306a36Sopenharmony_ci#define OEMUtilIDCodeAddr 0x237 61662306a36Sopenharmony_ci#define VBModeIDTableAddr 0x239 61762306a36Sopenharmony_ci#define OEMTVPtrAddr 0x241 61862306a36Sopenharmony_ci#define PhaseTableAddr 0x243 61962306a36Sopenharmony_ci#define NTSCFilterTableAddr 0x245 62062306a36Sopenharmony_ci#define PALFilterTableAddr 0x247 62162306a36Sopenharmony_ci#define OEMLCDPtr_1Addr 0x249 62262306a36Sopenharmony_ci#define OEMLCDPtr_2Addr 0x24B 62362306a36Sopenharmony_ci#define LCDHPosTable_1Addr 0x24D 62462306a36Sopenharmony_ci#define LCDHPosTable_2Addr 0x24F 62562306a36Sopenharmony_ci#define LCDVPosTable_1Addr 0x251 62662306a36Sopenharmony_ci#define LCDVPosTable_2Addr 0x253 62762306a36Sopenharmony_ci#define OEMLCDPIDTableAddr 0x255 62862306a36Sopenharmony_ci 62962306a36Sopenharmony_ci#define VBModeStructSize 5 63062306a36Sopenharmony_ci#define PhaseTableSize 4 63162306a36Sopenharmony_ci#define FilterTableSize 4 63262306a36Sopenharmony_ci#define LCDHPosTableSize 7 63362306a36Sopenharmony_ci#define LCDVPosTableSize 5 63462306a36Sopenharmony_ci#define OEMLVDSPIDTableSize 4 63562306a36Sopenharmony_ci#define LVDSHPosTableSize 4 63662306a36Sopenharmony_ci#define LVDSVPosTableSize 6 63762306a36Sopenharmony_ci 63862306a36Sopenharmony_ci#define VB_ModeID 0 63962306a36Sopenharmony_ci#define VB_TVTableIndex 1 64062306a36Sopenharmony_ci#define VB_LCDTableIndex 2 64162306a36Sopenharmony_ci#define VB_LCDHIndex 3 64262306a36Sopenharmony_ci#define VB_LCDVIndex 4 64362306a36Sopenharmony_ci 64462306a36Sopenharmony_ci#define OEMLCDEnable 0x0001 64562306a36Sopenharmony_ci#define OEMLCDDelayEnable 0x0002 64662306a36Sopenharmony_ci#define OEMLCDPOSEnable 0x0004 64762306a36Sopenharmony_ci#define OEMTVEnable 0x0100 64862306a36Sopenharmony_ci#define OEMTVDelayEnable 0x0200 64962306a36Sopenharmony_ci#define OEMTVFlickerEnable 0x0400 65062306a36Sopenharmony_ci#define OEMTVPhaseEnable 0x0800 65162306a36Sopenharmony_ci#define OEMTVFilterEnable 0x1000 65262306a36Sopenharmony_ci 65362306a36Sopenharmony_ci#define OEMLCDPanelIDSupport 0x0080 65462306a36Sopenharmony_ci 65562306a36Sopenharmony_ci/* 65662306a36Sopenharmony_ci ============================================================= 65762306a36Sopenharmony_ci for 315 series (old data layout) 65862306a36Sopenharmony_ci ============================================================= 65962306a36Sopenharmony_ci*/ 66062306a36Sopenharmony_ci#define SoftDRAMType 0x80 66162306a36Sopenharmony_ci#define SoftSetting_OFFSET 0x52 66262306a36Sopenharmony_ci#define SR07_OFFSET 0x7C 66362306a36Sopenharmony_ci#define SR15_OFFSET 0x7D 66462306a36Sopenharmony_ci#define SR16_OFFSET 0x81 66562306a36Sopenharmony_ci#define SR17_OFFSET 0x85 66662306a36Sopenharmony_ci#define SR19_OFFSET 0x8D 66762306a36Sopenharmony_ci#define SR1F_OFFSET 0x99 66862306a36Sopenharmony_ci#define SR21_OFFSET 0x9A 66962306a36Sopenharmony_ci#define SR22_OFFSET 0x9B 67062306a36Sopenharmony_ci#define SR23_OFFSET 0x9C 67162306a36Sopenharmony_ci#define SR24_OFFSET 0x9D 67262306a36Sopenharmony_ci#define SR25_OFFSET 0x9E 67362306a36Sopenharmony_ci#define SR31_OFFSET 0x9F 67462306a36Sopenharmony_ci#define SR32_OFFSET 0xA0 67562306a36Sopenharmony_ci#define SR33_OFFSET 0xA1 67662306a36Sopenharmony_ci 67762306a36Sopenharmony_ci#define CR40_OFFSET 0xA2 67862306a36Sopenharmony_ci#define SR25_1_OFFSET 0xF6 67962306a36Sopenharmony_ci#define CR49_OFFSET 0xF7 68062306a36Sopenharmony_ci 68162306a36Sopenharmony_ci#define VB310Data_1_2_Offset 0xB6 68262306a36Sopenharmony_ci#define VB310Data_4_D_Offset 0xB7 68362306a36Sopenharmony_ci#define VB310Data_4_E_Offset 0xB8 68462306a36Sopenharmony_ci#define VB310Data_4_10_Offset 0xBB 68562306a36Sopenharmony_ci 68662306a36Sopenharmony_ci#define RGBSenseDataOffset 0xBD 68762306a36Sopenharmony_ci#define YCSenseDataOffset 0xBF 68862306a36Sopenharmony_ci#define VideoSenseDataOffset 0xC1 68962306a36Sopenharmony_ci#define OutputSelectOffset 0xF3 69062306a36Sopenharmony_ci 69162306a36Sopenharmony_ci#define ECLK_MCLK_DISTANCE 0x14 69262306a36Sopenharmony_ci#define VBIOSTablePointerStart 0x100 69362306a36Sopenharmony_ci#define StandTablePtrOffset VBIOSTablePointerStart+0x02 69462306a36Sopenharmony_ci#define EModeIDTablePtrOffset VBIOSTablePointerStart+0x04 69562306a36Sopenharmony_ci#define CRT1TablePtrOffset VBIOSTablePointerStart+0x06 69662306a36Sopenharmony_ci#define ScreenOffsetPtrOffset VBIOSTablePointerStart+0x08 69762306a36Sopenharmony_ci#define VCLKDataPtrOffset VBIOSTablePointerStart+0x0A 69862306a36Sopenharmony_ci#define MCLKDataPtrOffset VBIOSTablePointerStart+0x0E 69962306a36Sopenharmony_ci#define CRT2PtrDataPtrOffset VBIOSTablePointerStart+0x10 70062306a36Sopenharmony_ci#define TVAntiFlickPtrOffset VBIOSTablePointerStart+0x12 70162306a36Sopenharmony_ci#define TVDelayPtr1Offset VBIOSTablePointerStart+0x14 70262306a36Sopenharmony_ci#define TVPhaseIncrPtr1Offset VBIOSTablePointerStart+0x16 70362306a36Sopenharmony_ci#define TVYFilterPtr1Offset VBIOSTablePointerStart+0x18 70462306a36Sopenharmony_ci#define LCDDelayPtr1Offset VBIOSTablePointerStart+0x20 70562306a36Sopenharmony_ci#define TVEdgePtr1Offset VBIOSTablePointerStart+0x24 70662306a36Sopenharmony_ci#define CRT2Delay1Offset VBIOSTablePointerStart+0x28 70762306a36Sopenharmony_ci 70862306a36Sopenharmony_ci#endif 709