Commit 914a402d authored by Prashant P. Shah's avatar Prashant P. Shah Committed by Greg Kroah-Hartman

Staging: xgifb: fixed many style issue in vb_ext.c

This is a patch to the vb_ext.c file that fixes many style
issues found by the checkpatch.pl tool.
- extra spaces
- invalid code indent
- extra braces
- invalid comment style
Signed-off-by: default avatarPrashant P. Shah <pshah.mumbai@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 3dc3494b
...@@ -9,1050 +9,849 @@ ...@@ -9,1050 +9,849 @@
#include "vb_util.h" #include "vb_util.h"
#include "vb_setmode.h" #include "vb_setmode.h"
#include "vb_ext.h" #include "vb_ext.h"
extern unsigned char XGI330_SoftSetting; extern unsigned char XGI330_SoftSetting;
extern unsigned char XGI330_OutputSelect; extern unsigned char XGI330_OutputSelect;
extern unsigned short XGI330_RGBSenseData2; extern unsigned short XGI330_RGBSenseData2;
extern unsigned short XGI330_YCSenseData2; extern unsigned short XGI330_YCSenseData2;
extern unsigned short XGI330_VideoSenseData2; extern unsigned short XGI330_VideoSenseData2;
void XGI_GetSenseStatus(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo); void XGI_GetSenseStatus(struct xgi_hw_device_info *HwDeviceExtension,
unsigned char XGINew_GetPanelID(struct vb_device_info *pVBInfo); struct vb_device_info *pVBInfo);
unsigned char XGINew_GetPanelID(struct vb_device_info *pVBInfo);
unsigned short XGINew_SenseLCD(struct xgi_hw_device_info *, unsigned short XGINew_SenseLCD(struct xgi_hw_device_info *,
struct vb_device_info *pVBInfo); struct vb_device_info *pVBInfo);
unsigned char XGINew_GetLCDDDCInfo(struct xgi_hw_device_info *HwDeviceExtension, unsigned char XGINew_GetLCDDDCInfo(
struct vb_device_info *pVBInfo); struct xgi_hw_device_info *HwDeviceExtension,
struct vb_device_info *pVBInfo);
void XGISetDPMS(struct xgi_hw_device_info *pXGIHWDE, void XGISetDPMS(struct xgi_hw_device_info *pXGIHWDE,
unsigned long VESA_POWER_STATE); unsigned long VESA_POWER_STATE);
unsigned char XGINew_BridgeIsEnable(struct xgi_hw_device_info *, struct vb_device_info *pVBInfo); unsigned char XGINew_BridgeIsEnable(struct xgi_hw_device_info *,
struct vb_device_info *pVBInfo);
unsigned char XGINew_Sense(unsigned short tempbx, unsigned short tempcx, unsigned char XGINew_Sense(unsigned short tempbx, unsigned short tempcx,
struct vb_device_info *pVBInfo); struct vb_device_info *pVBInfo);
unsigned char XGINew_SenseHiTV(struct xgi_hw_device_info *HwDeviceExtension, unsigned char XGINew_SenseHiTV(struct xgi_hw_device_info *HwDeviceExtension,
struct vb_device_info *pVBInfo); struct vb_device_info *pVBInfo);
/************************************************************** /**************************************************************
Dynamic Sense *********************** Dynamic Sense ************************
*************************************************************/ *************************************************************/
void XGI_WaitDisplay(void); void XGI_WaitDisplay(void);
unsigned char XGI_Is301C(struct vb_device_info *); unsigned char XGI_Is301C(struct vb_device_info *);
unsigned char XGI_Is301LV(struct vb_device_info *); unsigned char XGI_Is301LV(struct vb_device_info *);
/* --------------------------------------------------------------------- */
/* Function : XGINew_Is301B */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
static unsigned char XGINew_Is301B(struct vb_device_info *pVBInfo) static unsigned char XGINew_Is301B(struct vb_device_info *pVBInfo)
{ {
unsigned short flag ; unsigned short flag;
flag = XGINew_GetReg1( pVBInfo->Part4Port , 0x01 ) ; flag = XGINew_GetReg1(pVBInfo->Part4Port, 0x01);
if ( flag > 0x0B0 ) if (flag > 0x0B0)
return( 0 ) ; /* 301b */ return 0; /* 301b */
else else
return( 1 ) ; return 1;
} }
/* --------------------------------------------------------------------- */
/* Function : XGI_Is301C */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
unsigned char XGI_Is301C(struct vb_device_info *pVBInfo) unsigned char XGI_Is301C(struct vb_device_info *pVBInfo)
{ {
if ( ( XGINew_GetReg1( pVBInfo->Part4Port , 0x01 ) & 0xF0 ) == 0xC0 ) if ((XGINew_GetReg1(pVBInfo->Part4Port, 0x01) & 0xF0) == 0xC0)
return( 1 ) ; return 1;
if ( XGINew_GetReg1( pVBInfo->Part4Port , 0x01 ) >= 0xD0 ) if (XGINew_GetReg1(pVBInfo->Part4Port, 0x01) >= 0xD0) {
{ if (XGINew_GetReg1(pVBInfo->Part4Port, 0x39) == 0xE0)
if ( XGINew_GetReg1( pVBInfo->Part4Port , 0x39 ) == 0xE0 ) return 1;
return( 1 ) ; }
}
return( 0 ) ; return 0;
} }
/* --------------------------------------------------------------------- */
/* Function : XGI_Is301LV */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
unsigned char XGI_Is301LV(struct vb_device_info *pVBInfo) unsigned char XGI_Is301LV(struct vb_device_info *pVBInfo)
{ {
if ( XGINew_GetReg1( pVBInfo->Part4Port , 0x01 ) >= 0xD0 ) if (XGINew_GetReg1(pVBInfo->Part4Port, 0x01) >= 0xD0) {
{ if (XGINew_GetReg1(pVBInfo->Part4Port, 0x39) == 0xFF)
if ( XGINew_GetReg1( pVBInfo->Part4Port , 0x39 ) == 0xFF ) return 1;
{ }
return( 1 ) ; return 0;
}
}
return( 0 ) ;
} }
unsigned char XGINew_Sense(unsigned short tempbx, unsigned short tempcx, struct vb_device_info *pVBInfo)
/* --------------------------------------------------------------------- */
/* Function : XGINew_Sense */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
unsigned char XGINew_Sense(unsigned short tempbx,
unsigned short tempcx,
struct vb_device_info *pVBInfo)
{ {
unsigned short temp, i, tempch; unsigned short temp, i, tempch;
temp = tempbx & 0xFF ; temp = tempbx & 0xFF;
XGINew_SetReg1( pVBInfo->Part4Port , 0x11 , temp ) ; XGINew_SetReg1(pVBInfo->Part4Port, 0x11, temp);
temp = ( tempbx & 0xFF00 ) >> 8 ; temp = (tempbx & 0xFF00) >> 8;
temp |= ( tempcx & 0x00FF ) ; temp |= (tempcx & 0x00FF);
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x10 , ~0x1F , temp ) ; XGINew_SetRegANDOR(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
for( i = 0 ; i < 10 ; i++ ) for (i = 0; i < 10; i++)
XGI_LongWait( pVBInfo) ; XGI_LongWait(pVBInfo);
tempch = ( tempcx & 0x7F00 ) >> 8 ; tempch = (tempcx & 0x7F00) >> 8;
temp = XGINew_GetReg1( pVBInfo->Part4Port , 0x03 ) ; temp = XGINew_GetReg1(pVBInfo->Part4Port, 0x03);
temp = temp ^ ( 0x0E ) ; temp = temp ^ (0x0E);
temp &= tempch ; temp &= tempch;
if ( temp > 0 ) if (temp > 0)
return( 1 ) ; return 1;
else else
return( 0 ) ; return 0;
} }
void XGISetDPMS(struct xgi_hw_device_info *pXGIHWDE, unsigned long VESA_POWER_STATE)
/* --------------------------------------------------------------------- */
/* Function : XGISetDPMS */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
void XGISetDPMS(struct xgi_hw_device_info *pXGIHWDE,
unsigned long VESA_POWER_STATE)
{ {
unsigned short ModeNo, ModeIdIndex; unsigned short ModeNo, ModeIdIndex;
unsigned char temp; unsigned char temp;
struct vb_device_info VBINF; struct vb_device_info VBINF;
struct vb_device_info *pVBInfo = &VBINF; struct vb_device_info *pVBInfo = &VBINF;
pVBInfo->BaseAddr = (unsigned long)pXGIHWDE->pjIOAddress ; pVBInfo->BaseAddr = (unsigned long) pXGIHWDE->pjIOAddress;
pVBInfo->ROMAddr = pXGIHWDE->pjVirtualRomBase ; pVBInfo->ROMAddr = pXGIHWDE->pjVirtualRomBase;
pVBInfo->IF_DEF_LVDS = 0;
pVBInfo->IF_DEF_LVDS = 0 ; pVBInfo->IF_DEF_CH7005 = 0;
pVBInfo->IF_DEF_CH7005 = 0 ; pVBInfo->IF_DEF_HiVision = 1;
pVBInfo->IF_DEF_HiVision = 1 ; pVBInfo->IF_DEF_LCDA = 1;
pVBInfo->IF_DEF_LCDA = 1 ; pVBInfo->IF_DEF_CH7017 = 0;
pVBInfo->IF_DEF_CH7017 = 0 ; pVBInfo->IF_DEF_YPbPr = 1;
pVBInfo->IF_DEF_YPbPr = 1 ; pVBInfo->IF_DEF_CRT2Monitor = 0;
pVBInfo->IF_DEF_CRT2Monitor = 0 ; pVBInfo->IF_DEF_VideoCapture = 0;
pVBInfo->IF_DEF_VideoCapture = 0 ; pVBInfo->IF_DEF_ScaleLCD = 0;
pVBInfo->IF_DEF_ScaleLCD = 0 ; pVBInfo->IF_DEF_OEMUtil = 0;
pVBInfo->IF_DEF_OEMUtil = 0 ; pVBInfo->IF_DEF_PWD = 0;
pVBInfo->IF_DEF_PWD = 0 ;
InitTo330Pointer(pXGIHWDE->jChipType, pVBInfo);
InitTo330Pointer( pXGIHWDE->jChipType, pVBInfo ) ; ReadVBIOSTablData(pXGIHWDE->jChipType, pVBInfo);
ReadVBIOSTablData( pXGIHWDE->jChipType , pVBInfo) ;
pVBInfo->P3c4 = pVBInfo->BaseAddr + 0x14;
pVBInfo->P3c4 = pVBInfo->BaseAddr + 0x14 ; pVBInfo->P3d4 = pVBInfo->BaseAddr + 0x24;
pVBInfo->P3d4 = pVBInfo->BaseAddr + 0x24 ; pVBInfo->P3c0 = pVBInfo->BaseAddr + 0x10;
pVBInfo->P3c0 = pVBInfo->BaseAddr + 0x10 ; pVBInfo->P3ce = pVBInfo->BaseAddr + 0x1e;
pVBInfo->P3ce = pVBInfo->BaseAddr + 0x1e ; pVBInfo->P3c2 = pVBInfo->BaseAddr + 0x12;
pVBInfo->P3c2 = pVBInfo->BaseAddr + 0x12 ; pVBInfo->P3ca = pVBInfo->BaseAddr + 0x1a;
pVBInfo->P3ca = pVBInfo->BaseAddr + 0x1a ; pVBInfo->P3c6 = pVBInfo->BaseAddr + 0x16;
pVBInfo->P3c6 = pVBInfo->BaseAddr + 0x16 ; pVBInfo->P3c7 = pVBInfo->BaseAddr + 0x17;
pVBInfo->P3c7 = pVBInfo->BaseAddr + 0x17 ; pVBInfo->P3c8 = pVBInfo->BaseAddr + 0x18;
pVBInfo->P3c8 = pVBInfo->BaseAddr + 0x18 ; pVBInfo->P3c9 = pVBInfo->BaseAddr + 0x19;
pVBInfo->P3c9 = pVBInfo->BaseAddr + 0x19 ; pVBInfo->P3da = pVBInfo->BaseAddr + 0x2A;
pVBInfo->P3da = pVBInfo->BaseAddr + 0x2A ; pVBInfo->Part0Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_00;
pVBInfo->Part0Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_00 ; pVBInfo->Part1Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_04;
pVBInfo->Part1Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_04 ; pVBInfo->Part2Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_10;
pVBInfo->Part2Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_10 ; pVBInfo->Part3Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_12;
pVBInfo->Part3Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_12 ; pVBInfo->Part4Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14;
pVBInfo->Part4Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 ; pVBInfo->Part5Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 + 2;
pVBInfo->Part5Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 + 2 ;
if (pXGIHWDE->jChipType == XG27) {
if ( pXGIHWDE->jChipType == XG27 ) if ((XGINew_GetReg1(pVBInfo->P3d4, 0x38) & 0xE0) == 0xC0) {
{ if (XGINew_GetReg1(pVBInfo->P3d4, 0x30) & 0x20)
if ( ( XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) & 0xE0 ) == 0xC0 ) pVBInfo->IF_DEF_LVDS = 1;
{ }
if ( XGINew_GetReg1( pVBInfo->P3d4 , 0x30 ) & 0x20 ) }
{
pVBInfo->IF_DEF_LVDS = 1 ; if (pVBInfo->IF_DEF_CH7007 == 0)
} XGINew_SetModeScratch(pXGIHWDE, pVBInfo);
}
} XGINew_SetReg1(pVBInfo->P3c4, 0x05, 0x86); /* 1.Openkey */
XGI_UnLockCRT2(pXGIHWDE, pVBInfo);
if ( pVBInfo->IF_DEF_CH7007 == 0 ) ModeNo = XGINew_GetReg1(pVBInfo->P3d4, 0x34);
{ XGI_SearchModeID(ModeNo, &ModeIdIndex, pVBInfo);
XGINew_SetModeScratch ( pXGIHWDE , pVBInfo ) ; XGI_GetVGAType(pXGIHWDE, pVBInfo);
}
XGINew_SetReg1( pVBInfo->P3c4 , 0x05 , 0x86 ) ; /* 1.Openkey */ if ((pXGIHWDE->ujVBChipID == VB_CHIP_301) || (pXGIHWDE->ujVBChipID == VB_CHIP_302) || (pVBInfo->IF_DEF_CH7007 == 1)) {
XGI_UnLockCRT2( pXGIHWDE , pVBInfo) ; XGI_GetVBType(pVBInfo);
ModeNo = XGINew_GetReg1( pVBInfo->P3d4 , 0x34 ) ; XGI_GetVBInfo(ModeNo, ModeIdIndex, pXGIHWDE, pVBInfo);
XGI_SearchModeID( ModeNo , &ModeIdIndex, pVBInfo ) ; XGI_GetTVInfo(ModeNo, ModeIdIndex, pVBInfo);
XGI_GetVGAType( pXGIHWDE , pVBInfo ) ; XGI_GetLCDInfo(ModeNo, ModeIdIndex, pVBInfo);
}
if ( ( pXGIHWDE->ujVBChipID == VB_CHIP_301 ) || ( pXGIHWDE->ujVBChipID == VB_CHIP_302 ) || ( pVBInfo->IF_DEF_CH7007 == 1 ))
{ if (VESA_POWER_STATE == 0x00000400)
XGI_GetVBType( pVBInfo ) ; XGINew_SetReg1(pVBInfo->Part4Port, 0x31, (unsigned char) (XGINew_GetReg1(pVBInfo->Part4Port, 0x31) & 0xFE));
XGI_GetVBInfo( ModeNo , ModeIdIndex , pXGIHWDE, pVBInfo ) ; else
XGI_GetTVInfo( ModeNo , ModeIdIndex, pVBInfo ) ; XGINew_SetReg1(pVBInfo->Part4Port, 0x31, (unsigned char) (XGINew_GetReg1(pVBInfo->Part4Port, 0x31) | 0x01));
XGI_GetLCDInfo( ModeNo , ModeIdIndex, pVBInfo ) ;
} temp = (unsigned char) XGINew_GetReg1(pVBInfo->P3c4, 0x1f);
temp &= 0x3f;
if ( VESA_POWER_STATE == 0x00000400 ) switch (VESA_POWER_STATE) {
XGINew_SetReg1(pVBInfo->Part4Port, 0x31, (unsigned char)(XGINew_GetReg1(pVBInfo->Part4Port, 0x31) & 0xFE)); case 0x00000000: /* on */
else if ((pXGIHWDE->ujVBChipID == VB_CHIP_301) || (pXGIHWDE->ujVBChipID == VB_CHIP_302)) {
XGINew_SetReg1(pVBInfo->Part4Port, 0x31, (unsigned char)(XGINew_GetReg1(pVBInfo->Part4Port, 0x31) | 0x01)); XGINew_SetReg1(pVBInfo->P3c4, 0x1f, (unsigned char) (temp | 0x00));
XGI_EnableBridge(pXGIHWDE, pVBInfo);
temp = (unsigned char)XGINew_GetReg1(pVBInfo->P3c4, 0x1f); } else {
temp &= 0x3f ; if (pXGIHWDE->jChipType == XG21) {
switch ( VESA_POWER_STATE ) if (pVBInfo->IF_DEF_LVDS == 1) {
{ XGI_XG21BLSignalVDD(0x01, 0x01, pVBInfo); /* LVDS VDD on */
case 0x00000000: /* on */ XGI_XG21SetPanelDelay(2, pVBInfo);
if ( ( pXGIHWDE->ujVBChipID == VB_CHIP_301 ) || ( pXGIHWDE->ujVBChipID == VB_CHIP_302 ) ) }
{ }
XGINew_SetReg1(pVBInfo->P3c4, 0x1f, (unsigned char)(temp | 0x00)); if (pXGIHWDE->jChipType == XG27) {
XGI_EnableBridge( pXGIHWDE, pVBInfo ) ; if (pVBInfo->IF_DEF_LVDS == 1) {
} XGI_XG27BLSignalVDD(0x01, 0x01, pVBInfo); /* LVDS VDD on */
else XGI_XG21SetPanelDelay(2, pVBInfo);
{ }
if ( pXGIHWDE->jChipType == XG21 ) }
{ XGINew_SetRegANDOR(pVBInfo->P3c4, 0x1F, ~0xC0, 0x00);
if ( pVBInfo->IF_DEF_LVDS == 1 ) XGINew_SetRegAND(pVBInfo->P3c4, 0x01, ~0x20); /* CRT on */
{
XGI_XG21BLSignalVDD( 0x01 , 0x01, pVBInfo ) ; /* LVDS VDD on */ if (pXGIHWDE->jChipType == XG21) {
XGI_XG21SetPanelDelay( 2,pVBInfo ) ; temp = XGINew_GetReg1(pVBInfo->P3d4, 0x38);
} if (temp & 0xE0) {
} XGINew_SetRegANDOR(pVBInfo->P3c4, 0x09, ~0x80, 0x80); /* DVO ON */
if ( pXGIHWDE->jChipType == XG27 ) XGI_SetXG21FPBits(pVBInfo);
{ XGINew_SetRegAND(pVBInfo->P3d4, 0x4A, ~0x20); /* Enable write GPIOF */
if ( pVBInfo->IF_DEF_LVDS == 1 ) /* XGINew_SetRegANDOR(pVBInfo->P3d4, 0x48, ~0x20, 0x20); *//* LCD Display ON */
{ }
XGI_XG27BLSignalVDD( 0x01 , 0x01, pVBInfo ) ; /* LVDS VDD on */ XGI_XG21BLSignalVDD(0x20, 0x20, pVBInfo); /* LVDS signal on */
XGI_XG21SetPanelDelay( 2,pVBInfo ) ; XGI_DisplayOn(pXGIHWDE, pVBInfo);
} }
} if (pXGIHWDE->jChipType == XG27) {
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x1F , ~0xC0 , 0x00 ) ; temp = XGINew_GetReg1(pVBInfo->P3d4, 0x38);
XGINew_SetRegAND( pVBInfo->P3c4 , 0x01 , ~0x20 ) ; /* CRT on */ if (temp & 0xE0) {
XGINew_SetRegANDOR(pVBInfo->P3c4, 0x09, ~0x80, 0x80); /* DVO ON */
if ( pXGIHWDE->jChipType == XG21 ) XGI_SetXG27FPBits(pVBInfo);
{ XGINew_SetRegAND(pVBInfo->P3d4, 0x4A, ~0x20); /* Enable write GPIOF */
temp = XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) ; /* XGINew_SetRegANDOR(pVBInfo->P3d4, 0x48, ~0x20, 0x20); *//* LCD Display ON */
if ( temp & 0xE0 ) }
{ XGI_XG27BLSignalVDD(0x20, 0x20, pVBInfo); /* LVDS signal on */
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x09 , ~0x80 , 0x80 ) ; /* DVO ON */ XGI_DisplayOn(pXGIHWDE, pVBInfo);
XGI_SetXG21FPBits( pVBInfo ); }
XGINew_SetRegAND( pVBInfo->P3d4 , 0x4A , ~0x20 ) ; /* Enable write GPIOF */ }
/*XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x48 , ~0x20 , 0x20 ) ;*/ /* LCD Display ON */ break;
}
XGI_XG21BLSignalVDD( 0x20 , 0x20, pVBInfo ) ; /* LVDS signal on */ case 0x00000100: /* standby */
XGI_DisplayOn( pXGIHWDE, pVBInfo ); if (pXGIHWDE->jChipType >= XG21)
} XGI_DisplayOff(pXGIHWDE, pVBInfo);
if ( pXGIHWDE->jChipType == XG27 ) XGINew_SetReg1(pVBInfo->P3c4, 0x1f, (unsigned char) (temp | 0x40));
{ break;
temp = XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) ;
if ( temp & 0xE0 ) case 0x00000200: /* suspend */
{ if (pXGIHWDE->jChipType == XG21) {
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x09 , ~0x80 , 0x80 ) ; /* DVO ON */ XGI_DisplayOff(pXGIHWDE, pVBInfo);
XGI_SetXG27FPBits( pVBInfo ); XGI_XG21BLSignalVDD(0x20, 0x00, pVBInfo); /* LVDS signal off */
XGINew_SetRegAND( pVBInfo->P3d4 , 0x4A , ~0x20 ) ; /* Enable write GPIOF */ }
/*XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x48 , ~0x20 , 0x20 ) ;*/ /* LCD Display ON */ if (pXGIHWDE->jChipType == XG27) {
} XGI_DisplayOff(pXGIHWDE, pVBInfo);
XGI_XG27BLSignalVDD( 0x20 , 0x20, pVBInfo ) ; /* LVDS signal on */ XGI_XG27BLSignalVDD(0x20, 0x00, pVBInfo); /* LVDS signal off */
XGI_DisplayOn( pXGIHWDE, pVBInfo ); }
} XGINew_SetReg1(pVBInfo->P3c4, 0x1f, (unsigned char) (temp | 0x80));
} break;
break ;
case 0x00000100: /* standby */ case 0x00000400: /* off */
if ( pXGIHWDE->jChipType >= XG21 ) if ((pXGIHWDE->ujVBChipID == VB_CHIP_301) || (pXGIHWDE->ujVBChipID == VB_CHIP_302)) {
{ XGINew_SetReg1(pVBInfo->P3c4, 0x1f, (unsigned char) (temp | 0xc0));
XGI_DisplayOff( pXGIHWDE, pVBInfo ); XGI_DisableBridge(pXGIHWDE, pVBInfo);
} } else {
if (pXGIHWDE->jChipType == XG21) {
XGINew_SetReg1(pVBInfo->P3c4, 0x1f, (unsigned char)(temp | 0x40)); XGI_DisplayOff(pXGIHWDE, pVBInfo);
break ;
case 0x00000200: /* suspend */ XGI_XG21BLSignalVDD(0x20, 0x00, pVBInfo); /* LVDS signal off */
if ( pXGIHWDE->jChipType == XG21 )
{ temp = XGINew_GetReg1(pVBInfo->P3d4, 0x38);
XGI_DisplayOff( pXGIHWDE, pVBInfo ); if (temp & 0xE0) {
XGI_XG21BLSignalVDD( 0x20 , 0x00, pVBInfo ) ; /* LVDS signal off */ XGINew_SetRegAND(pVBInfo->P3c4, 0x09, ~0x80); /* DVO Off */
} XGINew_SetRegAND(pVBInfo->P3d4, 0x4A, ~0x20); /* Enable write GPIOF */
if ( pXGIHWDE->jChipType == XG27 ) /* XGINew_SetRegAND(pVBInfo->P3d4, 0x48, ~0x20); *//* LCD Display OFF */
{ }
XGI_DisplayOff( pXGIHWDE, pVBInfo ); }
XGI_XG27BLSignalVDD( 0x20 , 0x00, pVBInfo ) ; /* LVDS signal off */ if (pXGIHWDE->jChipType == XG27) {
} XGI_DisplayOff(pXGIHWDE, pVBInfo);
XGINew_SetReg1(pVBInfo->P3c4, 0x1f, (unsigned char)(temp | 0x80));
break ; XGI_XG27BLSignalVDD(0x20, 0x00, pVBInfo); /* LVDS signal off */
case 0x00000400: /* off */
if ( (pXGIHWDE->ujVBChipID == VB_CHIP_301 ) || ( pXGIHWDE->ujVBChipID == VB_CHIP_302 ) ) temp = XGINew_GetReg1(pVBInfo->P3d4, 0x38);
{ if (temp & 0xE0)
XGINew_SetReg1(pVBInfo->P3c4, 0x1f, (unsigned char)(temp | 0xc0)); XGINew_SetRegAND(pVBInfo->P3c4, 0x09, ~0x80); /* DVO Off */
XGI_DisableBridge( pXGIHWDE, pVBInfo ) ; }
} XGINew_SetRegANDOR(pVBInfo->P3c4, 0x1F, ~0xC0, 0xC0);
else XGINew_SetRegOR(pVBInfo->P3c4, 0x01, 0x20); /* CRT Off */
{
if ( pXGIHWDE->jChipType == XG21 ) if ((pXGIHWDE->jChipType == XG21) && (pVBInfo->IF_DEF_LVDS == 1)) {
{ XGI_XG21SetPanelDelay(4, pVBInfo);
XGI_DisplayOff( pXGIHWDE, pVBInfo ); XGI_XG21BLSignalVDD(0x01, 0x00, pVBInfo); /* LVDS VDD off */
XGI_XG21SetPanelDelay(5, pVBInfo);
XGI_XG21BLSignalVDD( 0x20 , 0x00, pVBInfo ) ; /* LVDS signal off */ }
if ((pXGIHWDE->jChipType == XG27) && (pVBInfo->IF_DEF_LVDS == 1)) {
temp = XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) ; XGI_XG21SetPanelDelay(4, pVBInfo);
if ( temp & 0xE0 ) XGI_XG27BLSignalVDD(0x01, 0x00, pVBInfo); /* LVDS VDD off */
{ XGI_XG21SetPanelDelay(5, pVBInfo);
XGINew_SetRegAND( pVBInfo->P3c4 , 0x09 , ~0x80 ) ; /* DVO Off */ }
XGINew_SetRegAND( pVBInfo->P3d4 , 0x4A , ~0x20 ) ; /* Enable write GPIOF */ }
/*XGINew_SetRegAND( pVBInfo->P3d4 , 0x48 , ~0x20 ) ;*/ /* LCD Display OFF */ break;
}
} default:
if ( pXGIHWDE->jChipType == XG27 ) break;
{ }
XGI_DisplayOff( pXGIHWDE, pVBInfo ); XGI_LockCRT2(pXGIHWDE, pVBInfo);
XGI_XG27BLSignalVDD( 0x20 , 0x00, pVBInfo ) ; /* LVDS signal off */
temp = XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) ;
if ( temp & 0xE0 )
{
XGINew_SetRegAND( pVBInfo->P3c4 , 0x09 , ~0x80 ) ; /* DVO Off */
}
}
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x1F , ~0xC0 , 0xC0 ) ;
XGINew_SetRegOR( pVBInfo->P3c4 , 0x01 , 0x20 ) ; /* CRT Off */
if ( ( pXGIHWDE->jChipType == XG21 ) && ( pVBInfo->IF_DEF_LVDS == 1 ) )
{
XGI_XG21SetPanelDelay( 4,pVBInfo ) ;
XGI_XG21BLSignalVDD( 0x01 , 0x00, pVBInfo ) ; /* LVDS VDD off */
XGI_XG21SetPanelDelay( 5,pVBInfo ) ;
}
if ( ( pXGIHWDE->jChipType == XG27 ) && ( pVBInfo->IF_DEF_LVDS == 1 ) )
{
XGI_XG21SetPanelDelay( 4,pVBInfo ) ;
XGI_XG27BLSignalVDD( 0x01 , 0x00, pVBInfo ) ; /* LVDS VDD off */
XGI_XG21SetPanelDelay( 5,pVBInfo ) ;
}
}
break ;
default:
break ;
}
XGI_LockCRT2( pXGIHWDE , pVBInfo ) ;
} }
/* --------------------------------------------------------------------- */
/* Function : XGI_GetSenseStatus */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
void XGI_GetSenseStatus(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo) void XGI_GetSenseStatus(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
{ {
unsigned short tempax = 0 , tempbx , tempcx , temp , unsigned short tempax = 0, tempbx, tempcx, temp, P2reg0 = 0, SenseModeNo = 0,
P2reg0 = 0 , SenseModeNo = 0 , OutputSelect = *pVBInfo->pOutputSelect , OutputSelect = *pVBInfo->pOutputSelect, ModeIdIndex, i;
ModeIdIndex , i ; pVBInfo->BaseAddr = (unsigned long) HwDeviceExtension->pjIOAddress;
pVBInfo->BaseAddr = (unsigned long)HwDeviceExtension->pjIOAddress ;
if (pVBInfo->IF_DEF_LVDS == 1) {
if ( pVBInfo->IF_DEF_LVDS == 1 ) tempax = XGINew_GetReg1(pVBInfo->P3c4, 0x1A); /* ynlai 02/27/2002 */
{ tempbx = XGINew_GetReg1(pVBInfo->P3c4, 0x1B);
tempax = XGINew_GetReg1( pVBInfo->P3c4 , 0x1A ) ; /* ynlai 02/27/2002 */ tempax = ((tempax & 0xFE) >> 1) | (tempbx << 8);
tempbx = XGINew_GetReg1( pVBInfo->P3c4 , 0x1B ) ; if (tempax == 0x00) { /* Get Panel id from DDC */
tempax = ( ( tempax & 0xFE ) >> 1 ) | ( tempbx << 8 ) ; temp = XGINew_GetLCDDDCInfo(HwDeviceExtension, pVBInfo);
if ( tempax == 0x00 ) if (temp == 1) { /* LCD connect */
{ /* Get Panel id from DDC */ XGINew_SetRegANDOR(pVBInfo->P3d4, 0x39, 0xFF, 0x01); /* set CR39 bit0="1" */
temp = XGINew_GetLCDDDCInfo( HwDeviceExtension, pVBInfo ) ; XGINew_SetRegANDOR(pVBInfo->P3d4, 0x37, 0xEF, 0x00); /* clean CR37 bit4="0" */
if ( temp == 1 ) temp = LCDSense;
{ /* LCD connect */ } else { /* LCD don't connect */
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x39 , 0xFF , 0x01 ) ; /* set CR39 bit0="1" */ temp = 0;
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x37 , 0xEF , 0x00 ) ; /* clean CR37 bit4="0" */ }
temp = LCDSense ; } else {
} XGINew_GetPanelID(pVBInfo);
else temp = LCDSense;
{ /* LCD don't connect */ }
temp = 0 ;
} tempbx = ~(LCDSense | AVIDEOSense | SVIDEOSense);
} XGINew_SetRegANDOR(pVBInfo->P3d4, 0x32, tempbx, temp);
else } else { /* for 301 */
{ if (pVBInfo->VBInfo & SetCRT2ToHiVisionTV) { /* for HiVision */
XGINew_GetPanelID(pVBInfo) ; tempax = XGINew_GetReg1(pVBInfo->P3c4, 0x38);
temp = LCDSense ; temp = tempax & 0x01;
} tempax = XGINew_GetReg1(pVBInfo->P3c4, 0x3A);
temp = temp | (tempax & 0x02);
tempbx = ~( LCDSense | AVIDEOSense | SVIDEOSense ) ; XGINew_SetRegANDOR(pVBInfo->P3d4, 0x32, 0xA0, temp);
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x32 , tempbx , temp ) ; } else {
} if (XGI_BridgeIsOn(pVBInfo)) {
else P2reg0 = XGINew_GetReg1(pVBInfo->Part2Port, 0x00);
{ /* for 301 */ if (!XGINew_BridgeIsEnable(HwDeviceExtension, pVBInfo)) {
if ( pVBInfo->VBInfo & SetCRT2ToHiVisionTV ) SenseModeNo = 0x2e;
{ /* for HiVision */ /* XGINew_SetReg1(pVBInfo->P3d4, 0x30, 0x41); */
tempax = XGINew_GetReg1( pVBInfo->P3c4 , 0x38 ) ; /* XGISetModeNew(HwDeviceExtension, 0x2e); // ynlai InitMode */
temp = tempax & 0x01 ;
tempax = XGINew_GetReg1( pVBInfo->P3c4 , 0x3A ) ; temp = XGI_SearchModeID(SenseModeNo, &ModeIdIndex, pVBInfo);
temp = temp | ( tempax & 0x02 ) ; XGI_GetVGAType(HwDeviceExtension, pVBInfo);
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x32 , 0xA0 , temp ) ; XGI_GetVBType(pVBInfo);
} pVBInfo->SetFlag = 0x00;
else pVBInfo->ModeType = ModeVGA;
{ pVBInfo->VBInfo = SetCRT2ToRAMDAC | LoadDACFlag | SetInSlaveMode;
if ( XGI_BridgeIsOn( pVBInfo ) ) XGI_GetLCDInfo(0x2e, ModeIdIndex, pVBInfo);
{ XGI_GetTVInfo(0x2e, ModeIdIndex, pVBInfo);
P2reg0 = XGINew_GetReg1( pVBInfo->Part2Port , 0x00 ) ; XGI_EnableBridge(HwDeviceExtension, pVBInfo);
if ( !XGINew_BridgeIsEnable( HwDeviceExtension, pVBInfo ) ) XGI_SetCRT2Group301(SenseModeNo, HwDeviceExtension, pVBInfo);
{ XGI_SetCRT2ModeRegs(0x2e, HwDeviceExtension, pVBInfo);
SenseModeNo = 0x2e ; /* XGI_DisableBridge( HwDeviceExtension, pVBInfo ) ; */
/* XGINew_SetReg1( pVBInfo->P3d4 , 0x30 , 0x41 ) ; */ XGINew_SetRegANDOR(pVBInfo->P3c4, 0x01, 0xDF, 0x20); /* Display Off 0212 */
/* XGISetModeNew( HwDeviceExtension , 0x2e ) ; // ynlai InitMode */ for (i = 0; i < 20; i++)
XGI_LongWait(pVBInfo);
temp = XGI_SearchModeID( SenseModeNo , &ModeIdIndex, pVBInfo ) ; }
XGI_GetVGAType( HwDeviceExtension , pVBInfo) ; XGINew_SetReg1(pVBInfo->Part2Port, 0x00, 0x1c);
XGI_GetVBType( pVBInfo ) ; tempax = 0;
pVBInfo->SetFlag = 0x00 ; tempbx = *pVBInfo->pRGBSenseData;
pVBInfo->ModeType = ModeVGA ;
pVBInfo->VBInfo = SetCRT2ToRAMDAC | LoadDACFlag | SetInSlaveMode ; if (!(XGINew_Is301B(pVBInfo)))
XGI_GetLCDInfo( 0x2e , ModeIdIndex, pVBInfo ) ; tempbx = *pVBInfo->pRGBSenseData2;
XGI_GetTVInfo( 0x2e , ModeIdIndex, pVBInfo ) ;
XGI_EnableBridge( HwDeviceExtension, pVBInfo ) ; tempcx = 0x0E08;
XGI_SetCRT2Group301( SenseModeNo , HwDeviceExtension, pVBInfo ) ; if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
XGI_SetCRT2ModeRegs( 0x2e , HwDeviceExtension, pVBInfo ) ; if (XGINew_Sense(tempbx, tempcx, pVBInfo))
/* XGI_DisableBridge( HwDeviceExtension, pVBInfo ) ; */ tempax |= Monitor2Sense;
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x01 , 0xDF , 0x20 ) ; /* Display Off 0212 */ }
for( i = 0 ; i < 20 ; i++ )
{ if (pVBInfo->VBType & VB_XGI301C)
XGI_LongWait(pVBInfo) ; XGINew_SetRegOR(pVBInfo->Part4Port, 0x0d, 0x04);
}
} if (XGINew_SenseHiTV(HwDeviceExtension, pVBInfo)) { /* add by kuku for Multi-adapter sense HiTV */
XGINew_SetReg1( pVBInfo->Part2Port , 0x00 , 0x1c ) ; tempax |= HiTVSense;
tempax = 0 ; if ((pVBInfo->VBType & VB_XGI301C))
tempbx = *pVBInfo->pRGBSenseData ; tempax ^= (HiTVSense | YPbPrSense);
}
if ( !( XGINew_Is301B( pVBInfo ) ) )
{ if (!(tempax & (HiTVSense | YPbPrSense))) { /* start */
tempbx = *pVBInfo->pRGBSenseData2 ;
} tempbx = *pVBInfo->pYCSenseData;
tempcx = 0x0E08 ; if (!(XGINew_Is301B(pVBInfo)))
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) ) tempbx = *pVBInfo->pYCSenseData2;
{
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) ) tempcx = 0x0604;
{ if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
tempax |= Monitor2Sense ; if (XGINew_Sense(tempbx, tempcx, pVBInfo))
} tempax |= SVIDEOSense;
} }
if ( pVBInfo->VBType & VB_XGI301C) if (OutputSelect & BoardTVType) {
{ tempbx = *pVBInfo->pVideoSenseData;
XGINew_SetRegOR( pVBInfo->Part4Port , 0x0d , 0x04 ) ;
} if (!(XGINew_Is301B(pVBInfo)))
tempbx = *pVBInfo->pVideoSenseData2;
if ( XGINew_SenseHiTV( HwDeviceExtension , pVBInfo) ) /* add by kuku for Multi-adapter sense HiTV */
{ tempcx = 0x0804;
tempax |= HiTVSense ; if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
if ( ( pVBInfo->VBType & VB_XGI301C ) ) if (XGINew_Sense(tempbx, tempcx, pVBInfo))
{ tempax |= AVIDEOSense;
tempax ^= ( HiTVSense | YPbPrSense ) ; }
} } else {
} if (!(tempax & SVIDEOSense)) {
tempbx = *pVBInfo->pVideoSenseData;
if ( !( tempax & ( HiTVSense | YPbPrSense ) ) ) /* start */
{ if (!(XGINew_Is301B(pVBInfo)))
tempbx = *pVBInfo->pVideoSenseData2;
tempbx = *pVBInfo->pYCSenseData ;
tempcx = 0x0804;
if ( !( XGINew_Is301B( pVBInfo ) ) ) if (XGINew_Sense(tempbx, tempcx, pVBInfo)) {
{ if (XGINew_Sense(tempbx, tempcx, pVBInfo))
tempbx=*pVBInfo->pYCSenseData2; tempax |= AVIDEOSense;
} }
}
tempcx = 0x0604 ; }
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) ) }
{ } /* end */
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) ) if (!(tempax & Monitor2Sense)) {
{ if (XGINew_SenseLCD(HwDeviceExtension, pVBInfo))
tempax |= SVIDEOSense ; tempax |= LCDSense;
} }
} tempbx = 0;
tempcx = 0;
if ( OutputSelect & BoardTVType ) XGINew_Sense(tempbx, tempcx, pVBInfo);
{
tempbx = *pVBInfo->pVideoSenseData ; XGINew_SetRegANDOR(pVBInfo->P3d4, 0x32, ~0xDF, tempax);
XGINew_SetReg1(pVBInfo->Part2Port, 0x00, P2reg0);
if ( !( XGINew_Is301B( pVBInfo ) ) )
{ if (!(P2reg0 & 0x20)) {
tempbx = *pVBInfo->pVideoSenseData2 ; pVBInfo->VBInfo = DisableCRT2Display;
} /* XGI_SetCRT2Group301(SenseModeNo, HwDeviceExtension, pVBInfo); */
}
tempcx = 0x0804 ; }
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) ) }
{ XGI_DisableBridge(HwDeviceExtension, pVBInfo); /* shampoo 0226 */
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) )
{
tempax |= AVIDEOSense ;
}
}
}
else
{
if ( !( tempax & SVIDEOSense ) )
{
tempbx = *pVBInfo->pVideoSenseData ;
if ( !( XGINew_Is301B( pVBInfo ) ) )
{
tempbx=*pVBInfo->pVideoSenseData2;
}
tempcx = 0x0804 ;
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) )
{
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) )
{
tempax |= AVIDEOSense ;
}
}
}
}
}
} /* end */
if ( !( tempax & Monitor2Sense ) )
{
if ( XGINew_SenseLCD( HwDeviceExtension, pVBInfo ) )
{
tempax |= LCDSense ;
}
}
tempbx = 0 ;
tempcx = 0 ;
XGINew_Sense(tempbx , tempcx, pVBInfo ) ;
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x32 , ~0xDF , tempax ) ;
XGINew_SetReg1( pVBInfo->Part2Port , 0x00 , P2reg0 ) ;
if ( !( P2reg0 & 0x20 ) )
{
pVBInfo->VBInfo = DisableCRT2Display ;
/* XGI_SetCRT2Group301( SenseModeNo , HwDeviceExtension, pVBInfo ) ; */
}
}
}
XGI_DisableBridge( HwDeviceExtension, pVBInfo ) ; /* shampoo 0226 */
} }
unsigned short XGINew_SenseLCD(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
/* --------------------------------------------------------------------- */
/* Function : XGINew_SenseLCD */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
unsigned short XGINew_SenseLCD(struct xgi_hw_device_info *HwDeviceExtension,
struct vb_device_info *pVBInfo)
{ {
/* unsigned short SoftSetting ; */ /* unsigned short SoftSetting ; */
unsigned short temp ; unsigned short temp;
if ( ( HwDeviceExtension->jChipType >= XG20 ) || ( HwDeviceExtension->jChipType >= XG40 ) ) if ((HwDeviceExtension->jChipType >= XG20) || (HwDeviceExtension->jChipType >= XG40))
temp = 0 ; temp = 0;
else else
temp=XGINew_GetPanelID(pVBInfo) ; temp = XGINew_GetPanelID(pVBInfo);
if( !temp ) if (!temp)
temp = XGINew_GetLCDDDCInfo( HwDeviceExtension, pVBInfo ) ; temp = XGINew_GetLCDDDCInfo(HwDeviceExtension, pVBInfo);
return( temp ) ; return temp;
} }
/* --------------------------------------------------------------------- */
/* Function : XGINew_GetLCDDDCInfo */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
unsigned char XGINew_GetLCDDDCInfo(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo) unsigned char XGINew_GetLCDDDCInfo(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
{ {
unsigned short temp ; unsigned short temp;
/* add lcd sense */ /* add lcd sense */
if ( HwDeviceExtension->ulCRT2LCDType == LCD_UNKNOWN ) if (HwDeviceExtension->ulCRT2LCDType == LCD_UNKNOWN) {
{ return 0;
return( 0 ) ; } else {
} temp = (unsigned short) HwDeviceExtension->ulCRT2LCDType;
else switch (HwDeviceExtension->ulCRT2LCDType) {
{ case LCD_INVALID:
temp = (unsigned short)HwDeviceExtension->ulCRT2LCDType ; case LCD_800x600:
switch( HwDeviceExtension->ulCRT2LCDType ) case LCD_1024x768:
{ case LCD_1280x1024:
case LCD_INVALID: break;
case LCD_800x600:
case LCD_1024x768: case LCD_640x480:
case LCD_1280x1024: case LCD_1024x600:
break ; case LCD_1152x864:
case LCD_1280x960:
case LCD_640x480: case LCD_1152x768:
case LCD_1024x600: temp = 0;
case LCD_1152x864: break;
case LCD_1280x960:
case LCD_1152x768: case LCD_1400x1050:
temp = 0 ; case LCD_1280x768:
break ; case LCD_1600x1200:
break;
case LCD_1400x1050:
case LCD_1280x768: case LCD_1920x1440:
case LCD_1600x1200: case LCD_2048x1536:
break ; temp = 0;
break;
case LCD_1920x1440:
case LCD_2048x1536: default:
temp = 0 ; break;
break ; }
XGINew_SetRegANDOR(pVBInfo->P3d4, 0x36, 0xF0, temp);
default: return 1;
break ; }
}
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x36 , 0xF0 , temp ) ;
return( 1 ) ;
}
} }
/* --------------------------------------------------------------------- */
/* Function : */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
unsigned char XGINew_GetPanelID(struct vb_device_info *pVBInfo) unsigned char XGINew_GetPanelID(struct vb_device_info *pVBInfo)
{ {
unsigned short PanelTypeTable[16] = { unsigned short PanelTypeTable[16] = { SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel800x600 | _PanelType00, | Panel800x600 | _PanelType00, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType01, | Panel1024x768 | _PanelType01, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel800x600 | _PanelType02, | Panel800x600 | _PanelType02, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel640x480 | _PanelType03, | Panel640x480 | _PanelType03, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType04, | Panel1024x768 | _PanelType04, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType05, | Panel1024x768 | _PanelType05, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType06, | Panel1024x768 | _PanelType06, SyncNN | PanelRGB24Bit
SyncNN | PanelRGB24Bit | Panel1024x768 | _PanelType07, | Panel1024x768 | _PanelType07, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel800x600 | _PanelType08, | Panel800x600 | _PanelType08, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType09, | Panel1024x768 | _PanelType09, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel800x600 | _PanelType0A, | Panel800x600 | _PanelType0A, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType0B, | Panel1024x768 | _PanelType0B, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType0C, | Panel1024x768 | _PanelType0C, SyncNN | PanelRGB24Bit
SyncNN | PanelRGB24Bit | Panel1024x768 | _PanelType0D, | Panel1024x768 | _PanelType0D, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType0E, | Panel1024x768 | _PanelType0E, SyncNN | PanelRGB18Bit
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType0F }; | Panel1024x768 | _PanelType0F };
unsigned short tempax , tempbx, temp; unsigned short tempax, tempbx, temp;
/* unsigned short return_flag ; */ /* unsigned short return_flag; */
tempax = XGINew_GetReg1( pVBInfo->P3c4 , 0x1A ) ; tempax = XGINew_GetReg1(pVBInfo->P3c4, 0x1A);
tempbx = tempax & 0x1E ; tempbx = tempax & 0x1E;
if ( tempax == 0 ) if (tempax == 0)
return( 0 ) ; return 0;
else else {
{ /*
/* if (!(tempax & 0x10)) {
if ( !( tempax & 0x10 ) ) if (pVBInfo->IF_DEF_LVDS == 1) {
{ tempbx = 0;
if ( pVBInfo->IF_DEF_LVDS == 1 ) temp = XGINew_GetReg1(pVBInfo->P3c4, 0x38);
{ if (temp & 0x40)
tempbx = 0 ; tempbx |= 0x08;
temp = XGINew_GetReg1( pVBInfo->P3c4 , 0x38 ) ; if (temp & 0x20)
if ( temp & 0x40 ) tempbx |= 0x02;
tempbx |= 0x08 ; if (temp & 0x01)
if ( temp & 0x20 ) tempbx |= 0x01;
tempbx |= 0x02 ;
if ( temp & 0x01 ) temp = XGINew_GetReg1(pVBInfo->P3c4, 0x39);
tempbx |= 0x01 ; if (temp & 0x80)
tempbx |= 0x04;
temp = XGINew_GetReg1( pVBInfo->P3c4 , 0x39 ) ; } else {
if ( temp & 0x80 ) return(0);
tempbx |= 0x04 ; }
} }
else */
{
return( 0 ) ; tempbx = tempbx >> 1;
} temp = tempbx & 0x00F;
} XGINew_SetReg1(pVBInfo->P3d4, 0x36, temp);
*/ tempbx--;
tempbx = PanelTypeTable[tempbx];
tempbx = tempbx >> 1 ;
temp = tempbx & 0x00F ; temp = (tempbx & 0xFF00) >> 8;
XGINew_SetReg1( pVBInfo->P3d4 , 0x36 , temp ) ; XGINew_SetRegANDOR(pVBInfo->P3d4, 0x37, ~(LCDSyncBit
tempbx-- ; | LCDRGB18Bit), temp);
tempbx = PanelTypeTable[ tempbx ] ; return 1;
}
temp = ( tempbx & 0xFF00 ) >> 8 ;
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x37 , ~( LCDSyncBit | LCDRGB18Bit ) , temp ) ;
return( 1 ) ;
}
} }
/* --------------------------------------------------------------------- */
/* Function : XGINew_BridgeIsEnable */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
unsigned char XGINew_BridgeIsEnable(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo) unsigned char XGINew_BridgeIsEnable(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
{ {
unsigned short flag ; unsigned short flag;
if ( XGI_BridgeIsOn( pVBInfo ) == 0 ) if (XGI_BridgeIsOn(pVBInfo) == 0) {
{ flag = XGINew_GetReg1(pVBInfo->Part1Port, 0x0);
flag = XGINew_GetReg1( pVBInfo->Part1Port , 0x0 ) ;
if (flag & 0x050)
if ( flag & 0x050 ) return 1;
{ else
return( 1 ) ; return 0;
}
else }
{ return 0;
return( 0 ) ;
}
}
return( 0 ) ;
} }
/* ------------------------------------------------------ */
/* Function : XGINew_SenseHiTV */
/* Input : */
/* Output : */
/* Description : */
/* ------------------------------------------------------ */
unsigned char XGINew_SenseHiTV(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo) unsigned char XGINew_SenseHiTV(struct xgi_hw_device_info *HwDeviceExtension, struct vb_device_info *pVBInfo)
{ {
unsigned short tempbx , tempcx , temp , i , tempch; unsigned short tempbx, tempcx, temp, i, tempch;
tempbx = *pVBInfo->pYCSenseData2 ; tempbx = *pVBInfo->pYCSenseData2;
tempcx = 0x0604 ; tempcx = 0x0604;
temp = tempbx & 0xFF ; temp = tempbx & 0xFF;
XGINew_SetReg1( pVBInfo->Part4Port , 0x11 , temp ) ; XGINew_SetReg1(pVBInfo->Part4Port, 0x11, temp);
temp = ( tempbx & 0xFF00 ) >> 8 ; temp = (tempbx & 0xFF00) >> 8;
temp |= ( tempcx & 0x00FF ) ; temp |= (tempcx & 0x00FF);
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x10 , ~0x1F , temp ) ; XGINew_SetRegANDOR(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
for( i = 0 ; i < 10 ; i++ ) for (i = 0; i < 10; i++)
XGI_LongWait(pVBInfo) ; XGI_LongWait(pVBInfo);
tempch = ( tempcx & 0xFF00 ) >> 8; tempch = (tempcx & 0xFF00) >> 8;
temp = XGINew_GetReg1( pVBInfo->Part4Port , 0x03 ) ; temp = XGINew_GetReg1(pVBInfo->Part4Port, 0x03);
temp = temp ^ ( 0x0E ) ; temp = temp ^ (0x0E);
temp &= tempch ; temp &= tempch;
if ( temp != tempch ) if (temp != tempch)
return( 0 ) ; return 0;
tempbx = *pVBInfo->pVideoSenseData2 ; tempbx = *pVBInfo->pVideoSenseData2;
tempcx = 0x0804 ; tempcx = 0x0804;
temp = tempbx & 0xFF ; temp = tempbx & 0xFF;
XGINew_SetReg1( pVBInfo->Part4Port , 0x11 , temp ) ; XGINew_SetReg1(pVBInfo->Part4Port, 0x11, temp);
temp = ( tempbx & 0xFF00 ) >> 8 ; temp = (tempbx & 0xFF00) >> 8;
temp |= ( tempcx & 0x00FF ) ; temp |= (tempcx & 0x00FF);
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x10 , ~0x1F , temp ) ; XGINew_SetRegANDOR(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
for( i = 0 ; i < 10 ; i++ ) for (i = 0; i < 10; i++)
XGI_LongWait(pVBInfo) ; XGI_LongWait(pVBInfo);
tempch = ( tempcx & 0xFF00 ) >> 8; tempch = (tempcx & 0xFF00) >> 8;
temp = XGINew_GetReg1( pVBInfo->Part4Port , 0x03 ) ; temp = XGINew_GetReg1(pVBInfo->Part4Port, 0x03);
temp = temp ^ ( 0x0E ) ; temp = temp ^ (0x0E);
temp &= tempch ; temp &= tempch;
if ( temp != tempch ) if (temp != tempch) {
return( 0 ) ; return 0;
else } else {
{ tempbx = 0x3FF;
tempbx = 0x3FF ; tempcx = 0x0804;
tempcx = 0x0804 ; temp = tempbx & 0xFF;
temp = tempbx & 0xFF ; XGINew_SetReg1(pVBInfo->Part4Port, 0x11, temp);
XGINew_SetReg1( pVBInfo->Part4Port , 0x11 , temp ) ; temp = (tempbx & 0xFF00) >> 8;
temp = ( tempbx & 0xFF00 ) >> 8 ; temp |= (tempcx & 0x00FF);
temp |= ( tempcx & 0x00FF ) ; XGINew_SetRegANDOR(pVBInfo->Part4Port, 0x10, ~0x1F, temp);
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x10 , ~0x1F , temp ) ;
for (i = 0; i < 10; i++)
for( i = 0 ; i < 10 ; i++ ) XGI_LongWait(pVBInfo);
XGI_LongWait(pVBInfo) ;
tempch = (tempcx & 0xFF00) >> 8;
tempch = ( tempcx & 0xFF00 ) >> 8; temp = XGINew_GetReg1(pVBInfo->Part4Port, 0x03);
temp = XGINew_GetReg1( pVBInfo->Part4Port , 0x03 ) ; temp = temp ^ (0x0E);
temp = temp ^ ( 0x0E ) ; temp &= tempch;
temp &= tempch ;
if (temp != tempch)
if ( temp != tempch ) return 1;
return( 1 ) ; else
else return 0;
return( 0 ) ; }
}
} }
/* ----------------------------------------------------------------------------
* Description: Get Panel support
/* * O/P :
;----------------------------------------------------------------------------- * BL: Panel ID=81h for no scaler LVDS
; Description: Get Panel support * BH: Panel enhanced Mode Count
; O/P : * CX: Panel H. resolution
; BL: Panel ID=81h for no scaler LVDS * DX: PAnel V. resolution
; BH: Panel enhanced Mode Count * ----------------------------------------------------------------------------
; CX: Panel H. resolution */
; DX: PAnel V. resolution static void XGI_XG21Fun14Sub70(struct vb_device_info *pVBInfo, PX86_REGS pBiosArguments)
;-----------------------------------------------------------------------------
*/
static void XGI_XG21Fun14Sub70(struct vb_device_info *pVBInfo,
PX86_REGS pBiosArguments)
{ {
unsigned short ModeIdIndex;
unsigned short ModeIdIndex; unsigned short ModeNo;
unsigned short ModeNo;
unsigned short EModeCount;
unsigned short EModeCount; unsigned short lvdstableindex;
unsigned short lvdstableindex;
lvdstableindex = XGI_GetLVDSOEMTableIndex(pVBInfo);
lvdstableindex = XGI_GetLVDSOEMTableIndex( pVBInfo ); pBiosArguments->h.bl = 0x81;
pBiosArguments->h.bl = 0x81; pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHDE;
pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHDE; pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVDE;
pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVDE; EModeCount = 0;
EModeCount = 0;
pBiosArguments->x.ax = 0x0014;
pBiosArguments->x.ax = 0x0014; for (ModeIdIndex = 0;; ModeIdIndex++) {
for( ModeIdIndex = 0 ; ; ModeIdIndex ++ ) ModeNo = pVBInfo->EModeIDTable[ModeIdIndex].Ext_ModeID;
{ if (pVBInfo->EModeIDTable[ModeIdIndex].Ext_ModeID == 0xFF) {
ModeNo = pVBInfo->EModeIDTable[ ModeIdIndex ].Ext_ModeID; pBiosArguments->h.bh = (unsigned char) EModeCount;
if ( pVBInfo->EModeIDTable[ ModeIdIndex ].Ext_ModeID == 0xFF ) return;
{ }
pBiosArguments->h.bh = (unsigned char) EModeCount; if (!XGI_XG21CheckLVDSMode(ModeNo, ModeIdIndex, pVBInfo))
return; continue;
}
if ( !XGI_XG21CheckLVDSMode( ModeNo , ModeIdIndex, pVBInfo) ) EModeCount++;
{ }
continue;
}
EModeCount++ ;
}
} }
/*(
;----------------------------------------------------------------------------- /* ----------------------------------------------------------------------------
; *
; Description: Get Panel mode ID for enhanced mode * Description: Get Panel mode ID for enhanced mode
; I/P : BH: EModeIndex ( which < Panel enhanced Mode Count ) * I/P : BH: EModeIndex ( which < Panel enhanced Mode Count )
; O/P : * O/P :
; BL: Mode ID * BL: Mode ID
; CX: H. resolution of the assigned by the index * CX: H. resolution of the assigned by the index
; DX: V. resolution of the assigned by the index * DX: V. resolution of the assigned by the index
; *
;----------------------------------------------------------------------------- * ----------------------------------------------------------------------------
*/ */
static void XGI_XG21Fun14Sub71(struct vb_device_info *pVBInfo,
PX86_REGS pBiosArguments) static void XGI_XG21Fun14Sub71(struct vb_device_info *pVBInfo, PX86_REGS pBiosArguments)
{ {
unsigned short EModeCount; unsigned short EModeCount;
unsigned short ModeIdIndex, resindex; unsigned short ModeIdIndex, resindex;
unsigned short ModeNo; unsigned short ModeNo;
unsigned short EModeIndex = pBiosArguments->h.bh; unsigned short EModeIndex = pBiosArguments->h.bh;
EModeCount = 0; EModeCount = 0;
for( ModeIdIndex = 0 ; ; ModeIdIndex ++ ) for (ModeIdIndex = 0;; ModeIdIndex++) {
{ ModeNo = pVBInfo->EModeIDTable[ModeIdIndex].Ext_ModeID;
ModeNo = pVBInfo->EModeIDTable[ ModeIdIndex ].Ext_ModeID; if (pVBInfo->EModeIDTable[ModeIdIndex].Ext_ModeID == 0xFF) {
if ( pVBInfo->EModeIDTable[ ModeIdIndex ].Ext_ModeID == 0xFF ) pBiosArguments->x.ax = 0x0114;
{ return;
pBiosArguments->x.ax = 0x0114; }
return; if (!XGI_XG21CheckLVDSMode(ModeNo, ModeIdIndex, pVBInfo))
} continue;
if ( !XGI_XG21CheckLVDSMode( ModeNo , ModeIdIndex, pVBInfo) )
{ if (EModeCount == EModeIndex) {
continue; resindex = XGI_GetResInfo(ModeNo, ModeIdIndex, pVBInfo);
} pBiosArguments->h.bl = (unsigned char) ModeNo;
if (EModeCount == EModeIndex) pBiosArguments->x.cx = pVBInfo->ModeResInfo[resindex].HTotal; /* xres->ax */
{ pBiosArguments->x.dx = pVBInfo->ModeResInfo[resindex].VTotal; /* yres->bx */
resindex = XGI_GetResInfo( ModeNo , ModeIdIndex, pVBInfo ) ; pBiosArguments->x.ax = 0x0014;
pBiosArguments->h.bl = (unsigned char) ModeNo; }
pBiosArguments->x.cx = pVBInfo->ModeResInfo[ resindex ].HTotal ; /* xres->ax */ EModeCount++;
pBiosArguments->x.dx = pVBInfo->ModeResInfo[ resindex ].VTotal ; /* yres->bx */
pBiosArguments->x.ax = 0x0014; }
}
EModeCount++ ;
}
} }
/*
;----------------------------------------------------------------------------- /* ----------------------------------------------------------------------------
; *
; Description: Validate Panel modes ID support * Description: Validate Panel modes ID support
; I/P : * I/P :
; BL: ModeID * BL: ModeID
; O/P : * O/P :
; CX: H. resolution of the assigned by the index * CX: H. resolution of the assigned by the index
; DX: V. resolution of the assigned by the index * DX: V. resolution of the assigned by the index
; *
;----------------------------------------------------------------------------- * ----------------------------------------------------------------------------
*/ */
static void XGI_XG21Fun14Sub72(struct vb_device_info *pVBInfo, static void XGI_XG21Fun14Sub72(struct vb_device_info *pVBInfo, PX86_REGS pBiosArguments)
PX86_REGS pBiosArguments)
{ {
unsigned short ModeIdIndex, resindex; unsigned short ModeIdIndex, resindex;
unsigned short ModeNo; unsigned short ModeNo;
ModeNo = pBiosArguments->h.bl;
ModeNo = pBiosArguments->h.bl ; XGI_SearchModeID(ModeNo, &ModeIdIndex, pVBInfo);
XGI_SearchModeID( ModeNo, &ModeIdIndex, pVBInfo); if (!XGI_XG21CheckLVDSMode(ModeNo, ModeIdIndex, pVBInfo)) {
if ( !XGI_XG21CheckLVDSMode( ModeNo , ModeIdIndex, pVBInfo) ) pBiosArguments->x.cx = 0;
{ pBiosArguments->x.dx = 0;
pBiosArguments->x.cx = 0; pBiosArguments->x.ax = 0x0114;
pBiosArguments->x.dx = 0; return;
pBiosArguments->x.ax = 0x0114; }
return; resindex = XGI_GetResInfo(ModeNo, ModeIdIndex, pVBInfo);
} if (ModeNo <= 0x13) {
resindex = XGI_GetResInfo( ModeNo , ModeIdIndex, pVBInfo ) ; pBiosArguments->x.cx = pVBInfo->StResInfo[resindex].HTotal;
if ( ModeNo <= 0x13 ) pBiosArguments->x.dx = pVBInfo->StResInfo[resindex].VTotal;
{ } else {
pBiosArguments->x.cx = pVBInfo->StResInfo[ resindex ].HTotal ; pBiosArguments->x.cx = pVBInfo->ModeResInfo[resindex].HTotal; /* xres->ax */
pBiosArguments->x.dx = pVBInfo->StResInfo[ resindex ].VTotal ; pBiosArguments->x.dx = pVBInfo->ModeResInfo[resindex].VTotal; /* yres->bx */
} }
else
{ pBiosArguments->x.ax = 0x0014;
pBiosArguments->x.cx = pVBInfo->ModeResInfo[ resindex ].HTotal ; /* xres->ax */
pBiosArguments->x.dx = pVBInfo->ModeResInfo[ resindex ].VTotal ; /* yres->bx */
}
pBiosArguments->x.ax = 0x0014;
} }
/* /* ----------------------------------------------------------------------------
;----------------------------------------------------------------------------- *
; Description: Get Customized Panel misc. information support * Description: Get Customized Panel misc. information support
; I/P : Select * I/P : Select
; to get panel horizontal timing * to get panel horizontal timing
; to get panel vertical timing * to get panel vertical timing
; to get channel clock parameter * to get channel clock parameter
; to get panel misc information * to get panel misc information
; *
; O/P : * O/P :
; BL: for input Select = 0 ; * BL: for input Select = 0 ;
; BX: *Value1 = Horizontal total * BX: *Value1 = Horizontal total
; CX: *Value2 = Horizontal front porch * CX: *Value2 = Horizontal front porch
; DX: *Value2 = Horizontal sync width * DX: *Value2 = Horizontal sync width
; BL: for input Select = 1 ; * BL: for input Select = 1 ;
; BX: *Value1 = Vertical total * BX: *Value1 = Vertical total
; CX: *Value2 = Vertical front porch * CX: *Value2 = Vertical front porch
; DX: *Value2 = Vertical sync width * DX: *Value2 = Vertical sync width
; BL: for input Select = 2 ; * BL: for input Select = 2 ;
; BX: Value1 = The first CLK parameter * BX: Value1 = The first CLK parameter
; CX: Value2 = The second CLK parameter * CX: Value2 = The second CLK parameter
; BL: for input Select = 4 ; * BL: for input Select = 4 ;
; BX[15]: *Value1 D[15] VESA V. Polarity * BX[15]: *Value1 D[15] VESA V. Polarity
; BX[14]: *Value1 D[14] VESA H. Polarity * BX[14]: *Value1 D[14] VESA H. Polarity
; BX[7]: *Value1 D[7] Panel V. Polarity * BX[7]: *Value1 D[7] Panel V. Polarity
; BX[6]: *Value1 D[6] Panel H. Polarity * BX[6]: *Value1 D[6] Panel H. Polarity
;----------------------------------------------------------------------------- * ----------------------------------------------------------------------------
*/ */
static void XGI_XG21Fun14Sub73(struct vb_device_info *pVBInfo, static void XGI_XG21Fun14Sub73(struct vb_device_info *pVBInfo, PX86_REGS pBiosArguments)
PX86_REGS pBiosArguments)
{ {
unsigned char Select; unsigned char Select;
unsigned short lvdstableindex; unsigned short lvdstableindex;
lvdstableindex = XGI_GetLVDSOEMTableIndex( pVBInfo ); lvdstableindex = XGI_GetLVDSOEMTableIndex(pVBInfo);
Select = pBiosArguments->h.bl; Select = pBiosArguments->h.bl;
switch (Select) switch (Select) {
{ case 0:
case 0: pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHT;
pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHT; pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHFP;
pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHFP; pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHSYNC;
pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHSYNC; break;
break; case 1:
case 1: pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVT;
pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVT; pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVFP;
pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVFP; pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVSYNC;
pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVSYNC; break;
break; case 2:
case 2: pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].VCLKData1;
pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].VCLKData1; pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].VCLKData2;
pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].VCLKData2; break;
break; case 4:
case 4: pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDS_Capability;
pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDS_Capability; break;
break; }
}
pBiosArguments->x.ax = 0x0014;
pBiosArguments->x.ax = 0x0014;
} }
void XGI_XG21Fun14(struct xgi_hw_device_info *pXGIHWDE, PX86_REGS pBiosArguments) void XGI_XG21Fun14(struct xgi_hw_device_info *pXGIHWDE, PX86_REGS pBiosArguments)
{ {
struct vb_device_info VBINF; struct vb_device_info VBINF;
struct vb_device_info *pVBInfo = &VBINF; struct vb_device_info *pVBInfo = &VBINF;
pVBInfo->IF_DEF_LVDS = 0 ; pVBInfo->IF_DEF_LVDS = 0;
pVBInfo->IF_DEF_CH7005 = 0 ; pVBInfo->IF_DEF_CH7005 = 0;
pVBInfo->IF_DEF_HiVision = 1 ; pVBInfo->IF_DEF_HiVision = 1;
pVBInfo->IF_DEF_LCDA = 1 ; pVBInfo->IF_DEF_LCDA = 1;
pVBInfo->IF_DEF_CH7017 = 0 ; pVBInfo->IF_DEF_CH7017 = 0;
pVBInfo->IF_DEF_YPbPr = 1 ; pVBInfo->IF_DEF_YPbPr = 1;
pVBInfo->IF_DEF_CRT2Monitor = 0 ; pVBInfo->IF_DEF_CRT2Monitor = 0;
pVBInfo->IF_DEF_VideoCapture = 0 ; pVBInfo->IF_DEF_VideoCapture = 0;
pVBInfo->IF_DEF_ScaleLCD = 0 ; pVBInfo->IF_DEF_ScaleLCD = 0;
pVBInfo->IF_DEF_OEMUtil = 0 ; pVBInfo->IF_DEF_OEMUtil = 0;
pVBInfo->IF_DEF_PWD = 0 ; pVBInfo->IF_DEF_PWD = 0;
InitTo330Pointer( pXGIHWDE->jChipType, pVBInfo ) ; InitTo330Pointer(pXGIHWDE->jChipType, pVBInfo);
ReadVBIOSTablData( pXGIHWDE->jChipType , pVBInfo) ; ReadVBIOSTablData(pXGIHWDE->jChipType, pVBInfo);
pVBInfo->P3c4 = pVBInfo->BaseAddr + 0x14 ; pVBInfo->P3c4 = pVBInfo->BaseAddr + 0x14;
pVBInfo->P3d4 = pVBInfo->BaseAddr + 0x24 ; pVBInfo->P3d4 = pVBInfo->BaseAddr + 0x24;
pVBInfo->P3c0 = pVBInfo->BaseAddr + 0x10 ; pVBInfo->P3c0 = pVBInfo->BaseAddr + 0x10;
pVBInfo->P3ce = pVBInfo->BaseAddr + 0x1e ; pVBInfo->P3ce = pVBInfo->BaseAddr + 0x1e;
pVBInfo->P3c2 = pVBInfo->BaseAddr + 0x12 ; pVBInfo->P3c2 = pVBInfo->BaseAddr + 0x12;
pVBInfo->P3ca = pVBInfo->BaseAddr + 0x1a ; pVBInfo->P3ca = pVBInfo->BaseAddr + 0x1a;
pVBInfo->P3c6 = pVBInfo->BaseAddr + 0x16 ; pVBInfo->P3c6 = pVBInfo->BaseAddr + 0x16;
pVBInfo->P3c7 = pVBInfo->BaseAddr + 0x17 ; pVBInfo->P3c7 = pVBInfo->BaseAddr + 0x17;
pVBInfo->P3c8 = pVBInfo->BaseAddr + 0x18 ; pVBInfo->P3c8 = pVBInfo->BaseAddr + 0x18;
pVBInfo->P3c9 = pVBInfo->BaseAddr + 0x19 ; pVBInfo->P3c9 = pVBInfo->BaseAddr + 0x19;
pVBInfo->P3da = pVBInfo->BaseAddr + 0x2A ; pVBInfo->P3da = pVBInfo->BaseAddr + 0x2A;
pVBInfo->Part0Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_00 ; pVBInfo->Part0Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_00;
pVBInfo->Part1Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_04 ; pVBInfo->Part1Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_04;
pVBInfo->Part2Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_10 ; pVBInfo->Part2Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_10;
pVBInfo->Part3Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_12 ; pVBInfo->Part3Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_12;
pVBInfo->Part4Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 ; pVBInfo->Part4Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14;
pVBInfo->Part5Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 + 2 ; pVBInfo->Part5Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 + 2;
switch(pBiosArguments->x.ax) switch (pBiosArguments->x.ax) {
{ case 0x1470:
case 0x1470: XGI_XG21Fun14Sub70(pVBInfo, pBiosArguments);
XGI_XG21Fun14Sub70( pVBInfo , pBiosArguments ) ; break;
break; case 0x1471:
case 0x1471: XGI_XG21Fun14Sub71(pVBInfo, pBiosArguments);
XGI_XG21Fun14Sub71( pVBInfo , pBiosArguments ) ; break;
break; case 0x1472:
case 0x1472: XGI_XG21Fun14Sub72(pVBInfo, pBiosArguments);
XGI_XG21Fun14Sub72( pVBInfo , pBiosArguments ) ; break;
break; case 0x1473:
case 0x1473: XGI_XG21Fun14Sub73(pVBInfo, pBiosArguments);
XGI_XG21Fun14Sub73( pVBInfo , pBiosArguments ) ; break;
break; }
}
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment