blob: 7e1f76adf73360feed42eb2d39a541394599fde7 [file] [log] [blame]
apatard@mandriva.comd7636e02010-05-19 10:44:14 +02001#include <linux/version.h>
Kenji Toyama66229952011-04-23 08:27:48 +08002#include <linux/io.h>
apatard@mandriva.comd7636e02010-05-19 10:44:14 +02003#include <linux/types.h>
4#include "XGIfb.h"
apatard@mandriva.comd7636e02010-05-19 10:44:14 +02005
6#include "vb_def.h"
7#include "vgatypes.h"
8#include "vb_struct.h"
9#include "vb_util.h"
10#include "vb_setmode.h"
11#include "vb_ext.h"
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020012
13/**************************************************************
Prashant P. Shah914a4022010-09-01 21:37:35 +053014 *********************** Dynamic Sense ************************
15 *************************************************************/
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020016
Randy Dunlap89229672010-08-10 08:46:44 -070017static unsigned char XGINew_Is301B(struct vb_device_info *pVBInfo)
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020018{
Prashant P. Shah914a4022010-09-01 21:37:35 +053019 unsigned short flag;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020020
Aaro Koskinen58839b02011-03-13 12:26:23 +020021 flag = xgifb_reg_get(pVBInfo->Part4Port, 0x01);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020022
Prashant P. Shah914a4022010-09-01 21:37:35 +053023 if (flag > 0x0B0)
24 return 0; /* 301b */
25 else
26 return 1;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020027}
28
Kenji Toyama66229952011-04-23 08:27:48 +080029static unsigned char XGINew_Sense(unsigned short tempbx,
30 unsigned short tempcx,
31 struct vb_device_info *pVBInfo)
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020032{
Prashant P. Shah914a4022010-09-01 21:37:35 +053033 unsigned short temp, i, tempch;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020034
Prashant P. Shah914a4022010-09-01 21:37:35 +053035 temp = tempbx & 0xFF;
Aaro Koskinen8104e322011-03-13 12:26:22 +020036 xgifb_reg_set(pVBInfo->Part4Port, 0x11, temp);
Prashant P. Shah914a4022010-09-01 21:37:35 +053037 temp = (tempbx & 0xFF00) >> 8;
38 temp |= (tempcx & 0x00FF);
Aaro Koskinenec9e5d32011-03-13 12:26:25 +020039 xgifb_reg_and_or(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020040
Prashant P. Shah914a4022010-09-01 21:37:35 +053041 for (i = 0; i < 10; i++)
42 XGI_LongWait(pVBInfo);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020043
Prashant P. Shah914a4022010-09-01 21:37:35 +053044 tempch = (tempcx & 0x7F00) >> 8;
Aaro Koskinen58839b02011-03-13 12:26:23 +020045 temp = xgifb_reg_get(pVBInfo->Part4Port, 0x03);
Prashant P. Shah914a4022010-09-01 21:37:35 +053046 temp = temp ^ (0x0E);
47 temp &= tempch;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020048
Prashant P. Shah914a4022010-09-01 21:37:35 +053049 if (temp > 0)
50 return 1;
51 else
52 return 0;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020053}
54
Kenji Toyama66229952011-04-23 08:27:48 +080055static unsigned char
56XGINew_GetLCDDDCInfo(struct xgi_hw_device_info *HwDeviceExtension,
57 struct vb_device_info *pVBInfo)
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020058{
Prashant P. Shah914a4022010-09-01 21:37:35 +053059 unsigned short temp;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020060
Prashant P. Shah914a4022010-09-01 21:37:35 +053061 /* add lcd sense */
62 if (HwDeviceExtension->ulCRT2LCDType == LCD_UNKNOWN) {
63 return 0;
64 } else {
65 temp = (unsigned short) HwDeviceExtension->ulCRT2LCDType;
66 switch (HwDeviceExtension->ulCRT2LCDType) {
67 case LCD_INVALID:
68 case LCD_800x600:
69 case LCD_1024x768:
70 case LCD_1280x1024:
71 break;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020072
Prashant P. Shah914a4022010-09-01 21:37:35 +053073 case LCD_640x480:
74 case LCD_1024x600:
75 case LCD_1152x864:
76 case LCD_1280x960:
77 case LCD_1152x768:
78 temp = 0;
79 break;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020080
Prashant P. Shah914a4022010-09-01 21:37:35 +053081 case LCD_1400x1050:
82 case LCD_1280x768:
83 case LCD_1600x1200:
84 break;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020085
Prashant P. Shah914a4022010-09-01 21:37:35 +053086 case LCD_1920x1440:
87 case LCD_2048x1536:
88 temp = 0;
89 break;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020090
Prashant P. Shah914a4022010-09-01 21:37:35 +053091 default:
92 break;
93 }
Aaro Koskinenec9e5d32011-03-13 12:26:25 +020094 xgifb_reg_and_or(pVBInfo->P3d4, 0x36, 0xF0, temp);
Prashant P. Shah914a4022010-09-01 21:37:35 +053095 return 1;
96 }
apatard@mandriva.comd7636e02010-05-19 10:44:14 +020097}
98
Aaro Koskinen3d5375f2011-03-08 22:16:17 +020099static unsigned char XGINew_GetPanelID(struct vb_device_info *pVBInfo)
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200100{
Prashant P. Shah914a4022010-09-01 21:37:35 +0530101 unsigned short PanelTypeTable[16] = { SyncNN | PanelRGB18Bit
102 | Panel800x600 | _PanelType00, SyncNN | PanelRGB18Bit
103 | Panel1024x768 | _PanelType01, SyncNN | PanelRGB18Bit
104 | Panel800x600 | _PanelType02, SyncNN | PanelRGB18Bit
105 | Panel640x480 | _PanelType03, SyncNN | PanelRGB18Bit
106 | Panel1024x768 | _PanelType04, SyncNN | PanelRGB18Bit
107 | Panel1024x768 | _PanelType05, SyncNN | PanelRGB18Bit
108 | Panel1024x768 | _PanelType06, SyncNN | PanelRGB24Bit
109 | Panel1024x768 | _PanelType07, SyncNN | PanelRGB18Bit
110 | Panel800x600 | _PanelType08, SyncNN | PanelRGB18Bit
111 | Panel1024x768 | _PanelType09, SyncNN | PanelRGB18Bit
112 | Panel800x600 | _PanelType0A, SyncNN | PanelRGB18Bit
113 | Panel1024x768 | _PanelType0B, SyncNN | PanelRGB18Bit
114 | Panel1024x768 | _PanelType0C, SyncNN | PanelRGB24Bit
115 | Panel1024x768 | _PanelType0D, SyncNN | PanelRGB18Bit
116 | Panel1024x768 | _PanelType0E, SyncNN | PanelRGB18Bit
117 | Panel1024x768 | _PanelType0F };
118 unsigned short tempax, tempbx, temp;
119 /* unsigned short return_flag; */
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200120
Aaro Koskinen58839b02011-03-13 12:26:23 +0200121 tempax = xgifb_reg_get(pVBInfo->P3c4, 0x1A);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530122 tempbx = tempax & 0x1E;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200123
Prashant P. Shah914a4022010-09-01 21:37:35 +0530124 if (tempax == 0)
125 return 0;
126 else {
127 /*
128 if (!(tempax & 0x10)) {
129 if (pVBInfo->IF_DEF_LVDS == 1) {
130 tempbx = 0;
Aaro Koskinen58839b02011-03-13 12:26:23 +0200131 temp = xgifb_reg_get(pVBInfo->P3c4, 0x38);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530132 if (temp & 0x40)
133 tempbx |= 0x08;
134 if (temp & 0x20)
135 tempbx |= 0x02;
136 if (temp & 0x01)
137 tempbx |= 0x01;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200138
Aaro Koskinen58839b02011-03-13 12:26:23 +0200139 temp = xgifb_reg_get(pVBInfo->P3c4, 0x39);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530140 if (temp & 0x80)
141 tempbx |= 0x04;
142 } else {
143 return(0);
144 }
145 }
146 */
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200147
Prashant P. Shah914a4022010-09-01 21:37:35 +0530148 tempbx = tempbx >> 1;
149 temp = tempbx & 0x00F;
Aaro Koskinen8104e322011-03-13 12:26:22 +0200150 xgifb_reg_set(pVBInfo->P3d4, 0x36, temp);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530151 tempbx--;
152 tempbx = PanelTypeTable[tempbx];
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200153
Prashant P. Shah914a4022010-09-01 21:37:35 +0530154 temp = (tempbx & 0xFF00) >> 8;
Aaro Koskinenec9e5d32011-03-13 12:26:25 +0200155 xgifb_reg_and_or(pVBInfo->P3d4, 0x37, ~(LCDSyncBit
Prashant P. Shah914a4022010-09-01 21:37:35 +0530156 | LCDRGB18Bit), temp);
157 return 1;
158 }
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200159}
160
Kenji Toyama66229952011-04-23 08:27:48 +0800161static unsigned char
162XGINew_BridgeIsEnable(struct xgi_hw_device_info *HwDeviceExtension,
163 struct vb_device_info *pVBInfo)
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200164{
Prashant P. Shah914a4022010-09-01 21:37:35 +0530165 unsigned short flag;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200166
Prashant P. Shah914a4022010-09-01 21:37:35 +0530167 if (XGI_BridgeIsOn(pVBInfo) == 0) {
Aaro Koskinen58839b02011-03-13 12:26:23 +0200168 flag = xgifb_reg_get(pVBInfo->Part1Port, 0x0);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200169
Prashant P. Shah914a4022010-09-01 21:37:35 +0530170 if (flag & 0x050)
171 return 1;
172 else
173 return 0;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200174
Prashant P. Shah914a4022010-09-01 21:37:35 +0530175 }
176 return 0;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200177}
178
Kenji Toyama66229952011-04-23 08:27:48 +0800179static unsigned char
180XGINew_SenseHiTV(struct xgi_hw_device_info *HwDeviceExtension,
181 struct vb_device_info *pVBInfo)
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200182{
Prashant P. Shah914a4022010-09-01 21:37:35 +0530183 unsigned short tempbx, tempcx, temp, i, tempch;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200184
Prashant P. Shah914a4022010-09-01 21:37:35 +0530185 tempbx = *pVBInfo->pYCSenseData2;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200186
Prashant P. Shah914a4022010-09-01 21:37:35 +0530187 tempcx = 0x0604;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200188
Prashant P. Shah914a4022010-09-01 21:37:35 +0530189 temp = tempbx & 0xFF;
Aaro Koskinen8104e322011-03-13 12:26:22 +0200190 xgifb_reg_set(pVBInfo->Part4Port, 0x11, temp);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530191 temp = (tempbx & 0xFF00) >> 8;
192 temp |= (tempcx & 0x00FF);
Aaro Koskinenec9e5d32011-03-13 12:26:25 +0200193 xgifb_reg_and_or(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200194
Prashant P. Shah914a4022010-09-01 21:37:35 +0530195 for (i = 0; i < 10; i++)
196 XGI_LongWait(pVBInfo);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200197
Prashant P. Shah914a4022010-09-01 21:37:35 +0530198 tempch = (tempcx & 0xFF00) >> 8;
Aaro Koskinen58839b02011-03-13 12:26:23 +0200199 temp = xgifb_reg_get(pVBInfo->Part4Port, 0x03);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530200 temp = temp ^ (0x0E);
201 temp &= tempch;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200202
Prashant P. Shah914a4022010-09-01 21:37:35 +0530203 if (temp != tempch)
204 return 0;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200205
Prashant P. Shah914a4022010-09-01 21:37:35 +0530206 tempbx = *pVBInfo->pVideoSenseData2;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200207
Prashant P. Shah914a4022010-09-01 21:37:35 +0530208 tempcx = 0x0804;
209 temp = tempbx & 0xFF;
Aaro Koskinen8104e322011-03-13 12:26:22 +0200210 xgifb_reg_set(pVBInfo->Part4Port, 0x11, temp);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530211 temp = (tempbx & 0xFF00) >> 8;
212 temp |= (tempcx & 0x00FF);
Aaro Koskinenec9e5d32011-03-13 12:26:25 +0200213 xgifb_reg_and_or(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200214
Prashant P. Shah914a4022010-09-01 21:37:35 +0530215 for (i = 0; i < 10; i++)
216 XGI_LongWait(pVBInfo);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200217
Prashant P. Shah914a4022010-09-01 21:37:35 +0530218 tempch = (tempcx & 0xFF00) >> 8;
Aaro Koskinen58839b02011-03-13 12:26:23 +0200219 temp = xgifb_reg_get(pVBInfo->Part4Port, 0x03);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530220 temp = temp ^ (0x0E);
221 temp &= tempch;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200222
Prashant P. Shah914a4022010-09-01 21:37:35 +0530223 if (temp != tempch) {
224 return 0;
225 } else {
226 tempbx = 0x3FF;
227 tempcx = 0x0804;
228 temp = tempbx & 0xFF;
Aaro Koskinen8104e322011-03-13 12:26:22 +0200229 xgifb_reg_set(pVBInfo->Part4Port, 0x11, temp);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530230 temp = (tempbx & 0xFF00) >> 8;
231 temp |= (tempcx & 0x00FF);
Aaro Koskinenec9e5d32011-03-13 12:26:25 +0200232 xgifb_reg_and_or(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200233
Prashant P. Shah914a4022010-09-01 21:37:35 +0530234 for (i = 0; i < 10; i++)
235 XGI_LongWait(pVBInfo);
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200236
Prashant P. Shah914a4022010-09-01 21:37:35 +0530237 tempch = (tempcx & 0xFF00) >> 8;
Aaro Koskinen58839b02011-03-13 12:26:23 +0200238 temp = xgifb_reg_get(pVBInfo->Part4Port, 0x03);
Prashant P. Shah914a4022010-09-01 21:37:35 +0530239 temp = temp ^ (0x0E);
240 temp &= tempch;
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200241
Prashant P. Shah914a4022010-09-01 21:37:35 +0530242 if (temp != tempch)
243 return 1;
244 else
245 return 0;
246 }
apatard@mandriva.comd7636e02010-05-19 10:44:14 +0200247}
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200248
Kenji Toyama66229952011-04-23 08:27:48 +0800249void XGI_GetSenseStatus(struct xgi_hw_device_info *HwDeviceExtension,
250 struct vb_device_info *pVBInfo)
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200251{
Kenji Toyama66229952011-04-23 08:27:48 +0800252 unsigned short tempax = 0, tempbx, tempcx, temp,
253 P2reg0 = 0, SenseModeNo = 0,
254 OutputSelect = *pVBInfo->pOutputSelect,
255 ModeIdIndex, i;
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200256 pVBInfo->BaseAddr = (unsigned long) HwDeviceExtension->pjIOAddress;
257
258 if (pVBInfo->IF_DEF_LVDS == 1) {
Kenji Toyama66229952011-04-23 08:27:48 +0800259 /* ynlai 02/27/2002 */
260 tempax = xgifb_reg_get(pVBInfo->P3c4, 0x1A);
Aaro Koskinen58839b02011-03-13 12:26:23 +0200261 tempbx = xgifb_reg_get(pVBInfo->P3c4, 0x1B);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200262 tempax = ((tempax & 0xFE) >> 1) | (tempbx << 8);
263 if (tempax == 0x00) { /* Get Panel id from DDC */
264 temp = XGINew_GetLCDDDCInfo(HwDeviceExtension, pVBInfo);
265 if (temp == 1) { /* LCD connect */
Kenji Toyama66229952011-04-23 08:27:48 +0800266 /* set CR39 bit0="1" */
267 xgifb_reg_and_or(pVBInfo->P3d4,
268 0x39, 0xFF, 0x01);
269 /* clean CR37 bit4="0" */
270 xgifb_reg_and_or(pVBInfo->P3d4,
271 0x37, 0xEF, 0x00);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200272 temp = LCDSense;
273 } else { /* LCD don't connect */
274 temp = 0;
275 }
276 } else {
277 XGINew_GetPanelID(pVBInfo);
278 temp = LCDSense;
279 }
280
281 tempbx = ~(LCDSense | AVIDEOSense | SVIDEOSense);
Aaro Koskinenec9e5d32011-03-13 12:26:25 +0200282 xgifb_reg_and_or(pVBInfo->P3d4, 0x32, tempbx, temp);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200283 } else { /* for 301 */
284 if (pVBInfo->VBInfo & SetCRT2ToHiVisionTV) { /* for HiVision */
Aaro Koskinen58839b02011-03-13 12:26:23 +0200285 tempax = xgifb_reg_get(pVBInfo->P3c4, 0x38);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200286 temp = tempax & 0x01;
Aaro Koskinen58839b02011-03-13 12:26:23 +0200287 tempax = xgifb_reg_get(pVBInfo->P3c4, 0x3A);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200288 temp = temp | (tempax & 0x02);
Aaro Koskinenec9e5d32011-03-13 12:26:25 +0200289 xgifb_reg_and_or(pVBInfo->P3d4, 0x32, 0xA0, temp);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200290 } else {
291 if (XGI_BridgeIsOn(pVBInfo)) {
Kenji Toyama66229952011-04-23 08:27:48 +0800292 P2reg0 = xgifb_reg_get(pVBInfo->Part2Port,
293 0x00);
294 if (!XGINew_BridgeIsEnable(HwDeviceExtension,
295 pVBInfo)) {
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200296 SenseModeNo = 0x2e;
Kenji Toyama66229952011-04-23 08:27:48 +0800297 /* xgifb_reg_set(pVBInfo->P3d4, 0x30, 0x41);
298 * XGISetModeNew(HwDeviceExtension, 0x2e);
299 * // ynlai InitMode */
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200300
Kenji Toyama66229952011-04-23 08:27:48 +0800301 temp = XGI_SearchModeID(SenseModeNo,
302 &ModeIdIndex,
303 pVBInfo);
304 XGI_GetVGAType(HwDeviceExtension,
305 pVBInfo);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200306 XGI_GetVBType(pVBInfo);
307 pVBInfo->SetFlag = 0x00;
308 pVBInfo->ModeType = ModeVGA;
Kenji Toyama66229952011-04-23 08:27:48 +0800309 pVBInfo->VBInfo = SetCRT2ToRAMDAC |
310 LoadDACFlag |
311 SetInSlaveMode;
312 XGI_GetLCDInfo(0x2e,
313 ModeIdIndex,
314 pVBInfo);
315 XGI_GetTVInfo(0x2e,
316 ModeIdIndex,
317 pVBInfo);
318 XGI_EnableBridge(HwDeviceExtension,
319 pVBInfo);
320 XGI_SetCRT2Group301(SenseModeNo,
321 HwDeviceExtension,
322 pVBInfo);
323 XGI_SetCRT2ModeRegs(0x2e,
324 HwDeviceExtension,
325 pVBInfo);
326 /* XGI_DisableBridge(HwDeviceExtension,
327 * pVBInfo ) ; */
328 /* Display Off 0212 */
329 xgifb_reg_and_or(pVBInfo->P3c4,
330 0x01,
331 0xDF,
332 0x20);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200333 for (i = 0; i < 20; i++)
334 XGI_LongWait(pVBInfo);
335 }
Aaro Koskinen8104e322011-03-13 12:26:22 +0200336 xgifb_reg_set(pVBInfo->Part2Port, 0x00, 0x1c);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200337 tempax = 0;
338 tempbx = *pVBInfo->pRGBSenseData;
339
340 if (!(XGINew_Is301B(pVBInfo)))
341 tempbx = *pVBInfo->pRGBSenseData2;
342
343 tempcx = 0x0E08;
344 if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
Kenji Toyama66229952011-04-23 08:27:48 +0800345 if (XGINew_Sense(tempbx,
346 tempcx,
347 pVBInfo))
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200348 tempax |= Monitor2Sense;
349 }
350
351 if (pVBInfo->VBType & VB_XGI301C)
Kenji Toyama66229952011-04-23 08:27:48 +0800352 xgifb_reg_or(pVBInfo->Part4Port,
353 0x0d,
354 0x04);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200355
Kenji Toyama66229952011-04-23 08:27:48 +0800356 /* add by kuku for Multi-adapter sense HiTV */
357 if (XGINew_SenseHiTV(HwDeviceExtension,
358 pVBInfo)) {
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200359 tempax |= HiTVSense;
360 if ((pVBInfo->VBType & VB_XGI301C))
Kenji Toyama66229952011-04-23 08:27:48 +0800361 tempax ^= (HiTVSense |
362 YPbPrSense);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200363 }
364
Kenji Toyama66229952011-04-23 08:27:48 +0800365 /* start */
366 if (!(tempax & (HiTVSense | YPbPrSense))) {
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200367 tempbx = *pVBInfo->pYCSenseData;
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200368 if (!(XGINew_Is301B(pVBInfo)))
369 tempbx = *pVBInfo->pYCSenseData2;
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200370 tempcx = 0x0604;
Kenji Toyama66229952011-04-23 08:27:48 +0800371 if (XGINew_Sense(tempbx,
372 tempcx,
373 pVBInfo)) {
374 if (XGINew_Sense(tempbx,
375 tempcx,
376 pVBInfo))
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200377 tempax |= SVIDEOSense;
378 }
379
380 if (OutputSelect & BoardTVType) {
381 tempbx = *pVBInfo->pVideoSenseData;
382
383 if (!(XGINew_Is301B(pVBInfo)))
384 tempbx = *pVBInfo->pVideoSenseData2;
385
386 tempcx = 0x0804;
Kenji Toyama66229952011-04-23 08:27:48 +0800387 if (XGINew_Sense(tempbx,
388 tempcx,
389 pVBInfo)) {
390 if (XGINew_Sense(tempbx,
391 tempcx,
392 pVBInfo))
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200393 tempax |= AVIDEOSense;
394 }
395 } else {
396 if (!(tempax & SVIDEOSense)) {
397 tempbx = *pVBInfo->pVideoSenseData;
398
399 if (!(XGINew_Is301B(pVBInfo)))
400 tempbx = *pVBInfo->pVideoSenseData2;
401
402 tempcx = 0x0804;
Kenji Toyama66229952011-04-23 08:27:48 +0800403 if (XGINew_Sense(tempbx,
404 tempcx,
405 pVBInfo)) {
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200406 if (XGINew_Sense(tempbx, tempcx, pVBInfo))
407 tempax |= AVIDEOSense;
408 }
409 }
410 }
411 }
412 } /* end */
413 if (!(tempax & Monitor2Sense)) {
414 if (XGINew_SenseLCD(HwDeviceExtension, pVBInfo))
415 tempax |= LCDSense;
416 }
417 tempbx = 0;
418 tempcx = 0;
419 XGINew_Sense(tempbx, tempcx, pVBInfo);
420
Aaro Koskinenec9e5d32011-03-13 12:26:25 +0200421 xgifb_reg_and_or(pVBInfo->P3d4, 0x32, ~0xDF, tempax);
Aaro Koskinen8104e322011-03-13 12:26:22 +0200422 xgifb_reg_set(pVBInfo->Part2Port, 0x00, P2reg0);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200423
424 if (!(P2reg0 & 0x20)) {
425 pVBInfo->VBInfo = DisableCRT2Display;
Kenji Toyama66229952011-04-23 08:27:48 +0800426 /* XGI_SetCRT2Group301(SenseModeNo,
427 * HwDeviceExtension,
428 * pVBInfo); */
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200429 }
430 }
431 }
432 XGI_DisableBridge(HwDeviceExtension, pVBInfo); /* shampoo 0226 */
433
434}
435
Kenji Toyama66229952011-04-23 08:27:48 +0800436unsigned short XGINew_SenseLCD(struct xgi_hw_device_info *HwDeviceExtension,
437 struct vb_device_info *pVBInfo)
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200438{
439 /* unsigned short SoftSetting ; */
440 unsigned short temp;
441
Aaro Koskinen06587332011-03-13 12:26:10 +0200442 temp = XGINew_GetLCDDDCInfo(HwDeviceExtension, pVBInfo);
Aaro Koskinen3f8214c2011-03-13 12:26:05 +0200443
444 return temp;
445}