1 #include <linux/version.h>
3 #include <linux/types.h>
10 #include "vb_setmode.h"
13 /**************************************************************
14 *********************** Dynamic Sense ************************
15 *************************************************************/
17 static unsigned char XGINew_Is301B(struct vb_device_info *pVBInfo)
21 flag = XGINew_GetReg1(pVBInfo->Part4Port, 0x01);
29 static unsigned char XGINew_Sense(unsigned short tempbx, unsigned short tempcx, struct vb_device_info *pVBInfo)
31 unsigned short temp, i, tempch;
34 XGINew_SetReg1(pVBInfo->Part4Port, 0x11, temp);
35 temp = (tempbx & 0xFF00) >> 8;
36 temp |= (tempcx & 0x00FF);
37 XGINew_SetRegANDOR(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
39 for (i = 0; i < 10; i++)
40 XGI_LongWait(pVBInfo);
42 tempch = (tempcx & 0x7F00) >> 8;
43 temp = XGINew_GetReg1(pVBInfo->Part4Port, 0x03);
53 static unsigned char XGINew_GetLCDDDCInfo(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
58 if (HwDeviceExtension->ulCRT2LCDType == LCD_UNKNOWN) {
61 temp = (unsigned short) HwDeviceExtension->ulCRT2LCDType;
62 switch (HwDeviceExtension->ulCRT2LCDType) {
90 XGINew_SetRegANDOR(pVBInfo->P3d4, 0x36, 0xF0, temp);
95 static unsigned char XGINew_GetPanelID(struct vb_device_info *pVBInfo)
97 unsigned short PanelTypeTable[16] = { SyncNN | PanelRGB18Bit
98 | Panel800x600 | _PanelType00, SyncNN | PanelRGB18Bit
99 | Panel1024x768 | _PanelType01, SyncNN | PanelRGB18Bit
100 | Panel800x600 | _PanelType02, SyncNN | PanelRGB18Bit
101 | Panel640x480 | _PanelType03, SyncNN | PanelRGB18Bit
102 | Panel1024x768 | _PanelType04, SyncNN | PanelRGB18Bit
103 | Panel1024x768 | _PanelType05, SyncNN | PanelRGB18Bit
104 | Panel1024x768 | _PanelType06, SyncNN | PanelRGB24Bit
105 | Panel1024x768 | _PanelType07, SyncNN | PanelRGB18Bit
106 | Panel800x600 | _PanelType08, SyncNN | PanelRGB18Bit
107 | Panel1024x768 | _PanelType09, SyncNN | PanelRGB18Bit
108 | Panel800x600 | _PanelType0A, SyncNN | PanelRGB18Bit
109 | Panel1024x768 | _PanelType0B, SyncNN | PanelRGB18Bit
110 | Panel1024x768 | _PanelType0C, SyncNN | PanelRGB24Bit
111 | Panel1024x768 | _PanelType0D, SyncNN | PanelRGB18Bit
112 | Panel1024x768 | _PanelType0E, SyncNN | PanelRGB18Bit
113 | Panel1024x768 | _PanelType0F };
114 unsigned short tempax, tempbx, temp;
115 /* unsigned short return_flag; */
117 tempax = XGINew_GetReg1(pVBInfo->P3c4, 0x1A);
118 tempbx = tempax & 0x1E;
124 if (!(tempax & 0x10)) {
125 if (pVBInfo->IF_DEF_LVDS == 1) {
127 temp = XGINew_GetReg1(pVBInfo->P3c4, 0x38);
135 temp = XGINew_GetReg1(pVBInfo->P3c4, 0x39);
144 tempbx = tempbx >> 1;
145 temp = tempbx & 0x00F;
146 XGINew_SetReg1(pVBInfo->P3d4, 0x36, temp);
148 tempbx = PanelTypeTable[tempbx];
150 temp = (tempbx & 0xFF00) >> 8;
151 XGINew_SetRegANDOR(pVBInfo->P3d4, 0x37, ~(LCDSyncBit
152 | LCDRGB18Bit), temp);
157 static unsigned char XGINew_BridgeIsEnable(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
161 if (XGI_BridgeIsOn(pVBInfo) == 0) {
162 flag = XGINew_GetReg1(pVBInfo->Part1Port, 0x0);
173 static unsigned char XGINew_SenseHiTV(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
175 unsigned short tempbx, tempcx, temp, i, tempch;
177 tempbx = *pVBInfo->pYCSenseData2;
181 temp = tempbx & 0xFF;
182 XGINew_SetReg1(pVBInfo->Part4Port, 0x11, temp);
183 temp = (tempbx & 0xFF00) >> 8;
184 temp |= (tempcx & 0x00FF);
185 XGINew_SetRegANDOR(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
187 for (i = 0; i < 10; i++)
188 XGI_LongWait(pVBInfo);
190 tempch = (tempcx & 0xFF00) >> 8;
191 temp = XGINew_GetReg1(pVBInfo->Part4Port, 0x03);
192 temp = temp ^ (0x0E);
198 tempbx = *pVBInfo->pVideoSenseData2;
201 temp = tempbx & 0xFF;
202 XGINew_SetReg1(pVBInfo->Part4Port, 0x11, temp);
203 temp = (tempbx & 0xFF00) >> 8;
204 temp |= (tempcx & 0x00FF);
205 XGINew_SetRegANDOR(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
207 for (i = 0; i < 10; i++)
208 XGI_LongWait(pVBInfo);
210 tempch = (tempcx & 0xFF00) >> 8;
211 temp = XGINew_GetReg1(pVBInfo->Part4Port, 0x03);
212 temp = temp ^ (0x0E);
215 if (temp != tempch) {
220 temp = tempbx & 0xFF;
221 XGINew_SetReg1(pVBInfo->Part4Port, 0x11, temp);
222 temp = (tempbx & 0xFF00) >> 8;
223 temp |= (tempcx & 0x00FF);
224 XGINew_SetRegANDOR(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
226 for (i = 0; i < 10; i++)
227 XGI_LongWait(pVBInfo);
229 tempch = (tempcx & 0xFF00) >> 8;
230 temp = XGINew_GetReg1(pVBInfo->Part4Port, 0x03);
231 temp = temp ^ (0x0E);
241 void XGI_GetSenseStatus(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
243 unsigned short tempax = 0, tempbx, tempcx, temp, P2reg0 = 0, SenseModeNo = 0,
244 OutputSelect = *pVBInfo->pOutputSelect, ModeIdIndex, i;
245 pVBInfo->BaseAddr = (unsigned long) HwDeviceExtension->pjIOAddress;
247 if (pVBInfo->IF_DEF_LVDS == 1) {
248 tempax = XGINew_GetReg1(pVBInfo->P3c4, 0x1A); /* ynlai 02/27/2002 */
249 tempbx = XGINew_GetReg1(pVBInfo->P3c4, 0x1B);
250 tempax = ((tempax & 0xFE) >> 1) | (tempbx << 8);
251 if (tempax == 0x00) { /* Get Panel id from DDC */
252 temp = XGINew_GetLCDDDCInfo(HwDeviceExtension, pVBInfo);
253 if (temp == 1) { /* LCD connect */
254 XGINew_SetRegANDOR(pVBInfo->P3d4, 0x39, 0xFF, 0x01); /* set CR39 bit0="1" */
255 XGINew_SetRegANDOR(pVBInfo->P3d4, 0x37, 0xEF, 0x00); /* clean CR37 bit4="0" */
257 } else { /* LCD don't connect */
261 XGINew_GetPanelID(pVBInfo);
265 tempbx = ~(LCDSense | AVIDEOSense | SVIDEOSense);
266 XGINew_SetRegANDOR(pVBInfo->P3d4, 0x32, tempbx, temp);
267 } else { /* for 301 */
268 if (pVBInfo->VBInfo & SetCRT2ToHiVisionTV) { /* for HiVision */
269 tempax = XGINew_GetReg1(pVBInfo->P3c4, 0x38);
270 temp = tempax & 0x01;
271 tempax = XGINew_GetReg1(pVBInfo->P3c4, 0x3A);
272 temp = temp | (tempax & 0x02);
273 XGINew_SetRegANDOR(pVBInfo->P3d4, 0x32, 0xA0, temp);
275 if (XGI_BridgeIsOn(pVBInfo)) {
276 P2reg0 = XGINew_GetReg1(pVBInfo->Part2Port, 0x00);
277 if (!XGINew_BridgeIsEnable(HwDeviceExtension, pVBInfo)) {
279 /* XGINew_SetReg1(pVBInfo->P3d4, 0x30, 0x41); */
280 /* XGISetModeNew(HwDeviceExtension, 0x2e); // ynlai InitMode */
282 temp = XGI_SearchModeID(SenseModeNo, &ModeIdIndex, pVBInfo);
283 XGI_GetVGAType(HwDeviceExtension, pVBInfo);
284 XGI_GetVBType(pVBInfo);
285 pVBInfo->SetFlag = 0x00;
286 pVBInfo->ModeType = ModeVGA;
287 pVBInfo->VBInfo = SetCRT2ToRAMDAC | LoadDACFlag | SetInSlaveMode;
288 XGI_GetLCDInfo(0x2e, ModeIdIndex, pVBInfo);
289 XGI_GetTVInfo(0x2e, ModeIdIndex, pVBInfo);
290 XGI_EnableBridge(HwDeviceExtension, pVBInfo);
291 XGI_SetCRT2Group301(SenseModeNo, HwDeviceExtension, pVBInfo);
292 XGI_SetCRT2ModeRegs(0x2e, HwDeviceExtension, pVBInfo);
293 /* XGI_DisableBridge( HwDeviceExtension, pVBInfo ) ; */
294 XGINew_SetRegANDOR(pVBInfo->P3c4, 0x01, 0xDF, 0x20); /* Display Off 0212 */
295 for (i = 0; i < 20; i++)
296 XGI_LongWait(pVBInfo);
298 XGINew_SetReg1(pVBInfo->Part2Port, 0x00, 0x1c);
300 tempbx = *pVBInfo->pRGBSenseData;
302 if (!(XGINew_Is301B(pVBInfo)))
303 tempbx = *pVBInfo->pRGBSenseData2;
306 if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
307 if (XGINew_Sense(tempbx, tempcx, pVBInfo))
308 tempax |= Monitor2Sense;
311 if (pVBInfo->VBType & VB_XGI301C)
312 XGINew_SetRegOR(pVBInfo->Part4Port, 0x0d, 0x04);
314 if (XGINew_SenseHiTV(HwDeviceExtension, pVBInfo)) { /* add by kuku for Multi-adapter sense HiTV */
316 if ((pVBInfo->VBType & VB_XGI301C))
317 tempax ^= (HiTVSense | YPbPrSense);
320 if (!(tempax & (HiTVSense | YPbPrSense))) { /* start */
322 tempbx = *pVBInfo->pYCSenseData;
324 if (!(XGINew_Is301B(pVBInfo)))
325 tempbx = *pVBInfo->pYCSenseData2;
328 if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
329 if (XGINew_Sense(tempbx, tempcx, pVBInfo))
330 tempax |= SVIDEOSense;
333 if (OutputSelect & BoardTVType) {
334 tempbx = *pVBInfo->pVideoSenseData;
336 if (!(XGINew_Is301B(pVBInfo)))
337 tempbx = *pVBInfo->pVideoSenseData2;
340 if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
341 if (XGINew_Sense(tempbx, tempcx, pVBInfo))
342 tempax |= AVIDEOSense;
345 if (!(tempax & SVIDEOSense)) {
346 tempbx = *pVBInfo->pVideoSenseData;
348 if (!(XGINew_Is301B(pVBInfo)))
349 tempbx = *pVBInfo->pVideoSenseData2;
352 if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
353 if (XGINew_Sense(tempbx, tempcx, pVBInfo))
354 tempax |= AVIDEOSense;
360 if (!(tempax & Monitor2Sense)) {
361 if (XGINew_SenseLCD(HwDeviceExtension, pVBInfo))
366 XGINew_Sense(tempbx, tempcx, pVBInfo);
368 XGINew_SetRegANDOR(pVBInfo->P3d4, 0x32, ~0xDF, tempax);
369 XGINew_SetReg1(pVBInfo->Part2Port, 0x00, P2reg0);
371 if (!(P2reg0 & 0x20)) {
372 pVBInfo->VBInfo = DisableCRT2Display;
373 /* XGI_SetCRT2Group301(SenseModeNo, HwDeviceExtension, pVBInfo); */
377 XGI_DisableBridge(HwDeviceExtension, pVBInfo); /* shampoo 0226 */
381 unsigned short XGINew_SenseLCD(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
383 /* unsigned short SoftSetting ; */
386 if ((HwDeviceExtension->jChipType >= XG20) || (HwDeviceExtension->jChipType >= XG40))
389 temp = XGINew_GetPanelID(pVBInfo);
392 temp = XGINew_GetLCDDDCInfo(HwDeviceExtension, pVBInfo);