]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - drivers/staging/xgifb/vb_def.h
Merge tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm
[mirror_ubuntu-artful-kernel.git] / drivers / staging / xgifb / vb_def.h
CommitLineData
84359ef6
PH
1#ifndef _VB_DEF_
2#define _VB_DEF_
f7018c21 3#include "../../video/fbdev/sis/initdef.h"
d7636e0b 4
661f659e 5#define VB_XGI301C 0x0020 /* for 301C */
d7636e0b 6
661f659e 7#define SupportCRT2in301C 0x0100 /* for 301C */
661f659e 8#define SetCHTVOverScan 0x8000
d7636e0b 9
661f659e 10#define PanelResInfo 0x1F /* CR36 Panel Type/LCDResInfo */
255aabd2
PH
11#define Panel_1024x768x75 0x22
12#define Panel_1280x1024x75 0x23
d7636e0b 13
14#define PanelRef60Hz 0x00
15#define PanelRef75Hz 0x20
d7636e0b 16
d7636e0b 17#define YPbPr525iVCLK 0x03B
18#define YPbPr525iVCLK_2 0x03A
19
661f659e 20#define XGI_CRT2_PORT_00 (0x00 - 0x030)
d7636e0b 21
661f659e 22#define SupportAllCRT2 0x0078
661f659e
KT
23#define NoSupportTV 0x0070
24#define NoSupportHiVisionTV 0x0060
25#define NoSupportLCD 0x0058
d7636e0b 26
27/* -------------- SetMode Stack/Scratch */
a3d675c8 28#define XGI_SetCRT2ToLCDA 0x0100
661f659e 29#define SetCRT2ToDualEdge 0x8000
661f659e 30
661f659e 31#define ReserveTVOption 0x0008
661f659e 32
661f659e 33#define SetTVLowResolution 0x0400
661f659e
KT
34#define TVSimuMode 0x0800
35#define RPLLDIV2XO 0x1000
36#define NTSC1024x768 0x2000
37#define SetTVLockMode 0x4000
38
a3d675c8
PH
39#define XGI_LCDVESATiming 0x0001 /* LCD Info/CR37 */
40#define XGI_EnableLVDSDDA 0x0002
661f659e
KT
41#define EnableScalingLCD 0x0008
42#define SetPWDEnable 0x0004
43#define SetLCDtoNonExpanding 0x0010
661f659e
KT
44#define SetLCDDualLink 0x0100
45#define SetLCDLowResolution 0x0200
661f659e
KT
46
47/* LCD Capability shampoo */
48#define DefaultLCDCap 0x80ea
661f659e 49#define EnableLCD24bpp 0x0004 /* default */
661f659e 50#define LCDPolarity 0x00c0 /* default: SyncNN */
a3d675c8 51#define XGI_LCDDualLink 0x0100
661f659e 52#define EnableSpectrum 0x0200
661f659e 53#define PWDEnable 0x0400
661f659e 54#define EnableVBCLKDRVLOW 0x4000
661f659e 55#define EnablePLLSPLOW 0x8000
661f659e 56
661f659e
KT
57#define AVIDEOSense 0x01 /* CR32 */
58#define SVIDEOSense 0x02
59#define SCARTSense 0x04
60#define LCDSense 0x08
61#define Monitor2Sense 0x10
62#define Monitor1Sense 0x20
63#define HiTVSense 0x40
64
661f659e 65#define YPbPrSense 0x80 /* NEW SCRATCH */
d7636e0b 66
661f659e
KT
67#define TVSense 0xc7
68
661f659e
KT
69#define YPbPrMode 0xe0
70#define YPbPrMode525i 0x00
71#define YPbPrMode525p 0x20
72#define YPbPrMode750p 0x40
73#define YPbPrMode1080i 0x60
d7636e0b 74
661f659e 75#define ScalingLCD 0x08
d7636e0b 76
661f659e 77#define SetYPbPr 0x04
661f659e 78
d7636e0b 79/* ---------------------- VUMA Information */
661f659e 80#define DisplayDeviceFromCMOS 0x10
d7636e0b 81
82/* ---------------------- HK Evnet Definition */
a3d675c8 83#define XGI_ModeSwitchStatus 0xf0
661f659e
KT
84#define ActiveCRT1 0x10
85#define ActiveLCD 0x0020
86#define ActiveTV 0x40
87#define ActiveCRT2 0x80
88
661f659e
KT
89#define ActiveAVideo 0x01
90#define ActiveSVideo 0x02
91#define ActiveSCART 0x04
92#define ActiveHiTV 0x08
93#define ActiveYPbPr 0x10
94
661f659e 95#define NTSC1024x768HT 1908
661f659e
KT
96
97#define YPbPrTV525iHT 1716 /* YPbPr */
98#define YPbPrTV525iVT 525
99#define YPbPrTV525pHT 1716
100#define YPbPrTV525pVT 525
101#define YPbPrTV750pHT 1650
102#define YPbPrTV750pVT 750
103
661f659e
KT
104#define VCLK25_175 0x00
105#define VCLK28_322 0x01
106#define VCLK31_5 0x02
107#define VCLK36 0x03
661f659e
KT
108#define VCLK43_163 0x05
109#define VCLK44_9 0x06
110#define VCLK49_5 0x07
111#define VCLK50 0x08
112#define VCLK52_406 0x09
113#define VCLK56_25 0x0A
661f659e
KT
114#define VCLK68_179 0x0D
115#define VCLK72_852 0x0E
116#define VCLK75 0x0F
661f659e
KT
117#define VCLK78_75 0x11
118#define VCLK79_411 0x12
119#define VCLK83_95 0x13
661f659e
KT
120#define VCLK86_6 0x15
121#define VCLK94_5 0x16
661f659e
KT
122#define VCLK113_309 0x1B
123#define VCLK116_406 0x1C
661f659e
KT
124#define VCLK135_5 0x1E
125#define VCLK139_054 0x1F
126#define VCLK157_5 0x20
127#define VCLK162 0x21
128#define VCLK175 0x22
129#define VCLK189 0x23
661f659e
KT
130#define VCLK202_5 0x25
131#define VCLK229_5 0x26
132#define VCLK234 0x27
661f659e 133#define VCLK254_817 0x29
661f659e
KT
134#define VCLK266_952 0x2B
135#define VCLK269_655 0x2C
661f659e 136#define VCLK277_015 0x2E
661f659e
KT
137#define VCLK291_132 0x30
138#define VCLK291_766 0x31
661f659e
KT
139#define VCLK315_195 0x33
140#define VCLK323_586 0x34
141#define VCLK330_615 0x35
661f659e
KT
142#define VCLK340_477 0x37
143#define VCLK375_847 0x38
144#define VCLK388_631 0x39
145#define VCLK125_999 0x51
146#define VCLK148_5 0x52
661f659e 147#define VCLK217_325 0x55
a3d675c8 148#define XGI_YPbPr750pVCLK 0x57
661f659e 149
661f659e 150#define VCLK39_77 0x40
c3b3b3f9 151#define YPbPr525pVCLK 0x3A
661f659e 152#define NTSC1024VCLK 0x41
661f659e
KT
153#define VCLK35_2 0x49 /* ; 800x480 */
154#define VCLK122_61 0x4A
155#define VCLK80_350 0x4B
156#define VCLK107_385 0x4C
157
661f659e
KT
158#define RES320x200 0x00
159#define RES320x240 0x01
160#define RES400x300 0x02
161#define RES512x384 0x03
162#define RES640x400 0x04
163#define RES640x480x60 0x05
164#define RES640x480x72 0x06
165#define RES640x480x75 0x07
166#define RES640x480x85 0x08
167#define RES640x480x100 0x09
168#define RES640x480x120 0x0A
169#define RES640x480x160 0x0B
170#define RES640x480x200 0x0C
171#define RES800x600x56 0x0D
172#define RES800x600x60 0x0E
173#define RES800x600x72 0x0F
174#define RES800x600x75 0x10
175#define RES800x600x85 0x11
176#define RES800x600x100 0x12
177#define RES800x600x120 0x13
178#define RES800x600x160 0x14
179#define RES1024x768x43 0x15
180#define RES1024x768x60 0x16
181#define RES1024x768x70 0x17
182#define RES1024x768x75 0x18
183#define RES1024x768x85 0x19
184#define RES1024x768x100 0x1A
185#define RES1024x768x120 0x1B
186#define RES1280x1024x43 0x1C
187#define RES1280x1024x60 0x1D
188#define RES1280x1024x75 0x1E
189#define RES1280x1024x85 0x1F
190#define RES1600x1200x60 0x20
191#define RES1600x1200x65 0x21
192#define RES1600x1200x70 0x22
193#define RES1600x1200x75 0x23
194#define RES1600x1200x85 0x24
195#define RES1600x1200x100 0x25
196#define RES1600x1200x120 0x26
197#define RES1920x1440x60 0x27
198#define RES1920x1440x65 0x28
199#define RES1920x1440x70 0x29
200#define RES1920x1440x75 0x2A
201#define RES1920x1440x85 0x2B
202#define RES1920x1440x100 0x2C
203#define RES2048x1536x60 0x2D
204#define RES2048x1536x65 0x2E
205#define RES2048x1536x70 0x2F
206#define RES2048x1536x75 0x30
207#define RES2048x1536x85 0x31
208#define RES800x480x60 0x32
209#define RES800x480x75 0x33
210#define RES800x480x85 0x34
211#define RES1024x576x60 0x35
212#define RES1024x576x75 0x36
213#define RES1024x576x85 0x37
214#define RES1280x720x60 0x38
215#define RES1280x720x75 0x39
216#define RES1280x720x85 0x3A
217#define RES1280x960x60 0x3B
218#define RES720x480x60 0x3C
219#define RES720x576x56 0x3D
220#define RES856x480x79I 0x3E
221#define RES856x480x60 0x3F
222#define RES1280x768x60 0x40
223#define RES1400x1050x60 0x41
224#define RES1152x864x60 0x42
225#define RES1152x864x75 0x43
226#define RES1024x768x160 0x44
227#define RES1280x960x75 0x45
228#define RES1280x960x85 0x46
229#define RES1280x960x120 0x47
230
6d12dae4
PH
231
232#define XG27_CR8F 0x0C
233#define XG27_SR36 0x30
234#define XG27_SR40 0x04
235#define XG27_SR41 0x00
236#define XG40_CRCF 0x13
237#define XGI330_CRT2Data_1_2 0
238#define XGI330_CRT2Data_4_D 0
239#define XGI330_CRT2Data_4_E 0
240#define XGI330_CRT2Data_4_10 0x80
241#define XGI330_SR07 0x18
242#define XGI330_SR1F 0
243#define XGI330_SR23 0xf6
244#define XGI330_SR24 0x0d
6d12dae4
PH
245#define XGI330_SR31 0xc0
246#define XGI330_SR32 0x11
247#define XGI330_SR33 0
248
b397992e 249extern const struct XGI_ExtStruct XGI330_EModeIDTable[];
a39325d2 250extern const struct XGI_Ext2Struct XGI330_RefIndex[];
7853bced 251extern const struct XGI_CRT1TableStruct XGI_CRT1Table[];
9b047458 252extern const struct XGI_ECLKDataStruct XGI340_ECLKData[];
acfe093e 253extern const struct SiS_VCLKData XGI_VCLKData[];
5ce24760 254extern const unsigned char XGI340_CR6B[][4];
ea12b4e0 255extern const unsigned char XGI340_AGPReg[];
b397992e 256
d7636e0b 257#endif