blob: 49b39ee93a89af4c1e73a918a61e2d74ee470978 [file] [log] [blame]
#include "osdef.h"
#ifdef WIN2000
#include <dderror.h>
#include <devioctl.h>
#include <miniport.h>
#include <ntddvdeo.h>
#include <video.h>
#include "xgiv.h"
#include "dd_i2c.h"
#include "tools.h"
#endif /* WIN2000 */
#ifdef LINUX_XF86
#include "xf86.h"
#include "xf86PciInfo.h"
#include "xgi.h"
#include "xgi_regs.h"
#endif
#ifdef LINUX_KERNEL
#include <linux/version.h>
#include <asm/io.h>
#include <linux/types.h>
#include "XGIfb.h"
/*#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)
#include <video/XGIfb.h>
#else
#include <linux/XGIfb.h>
#endif*/
#endif
#include "vb_def.h"
#include "vgatypes.h"
#include "vb_struct.h"
#include "vb_util.h"
#include "vb_setmode.h"
#include "vb_ext.h"
extern UCHAR XGI330_SoftSetting;
extern UCHAR XGI330_OutputSelect;
extern USHORT XGI330_RGBSenseData2;
extern USHORT XGI330_YCSenseData2;
extern USHORT XGI330_VideoSenseData2;
#ifdef WIN2000
extern UCHAR SenseCHTV(PHW_DEVICE_EXTENSION pHWDE); /* 2007/05/17 Billy */
#endif
void XGI_GetSenseStatus( PXGI_HW_DEVICE_INFO HwDeviceExtension , PVB_DEVICE_INFO pVBInfo );
BOOLEAN XGINew_GetPanelID(PVB_DEVICE_INFO pVBInfo);
USHORT XGINew_SenseLCD(PXGI_HW_DEVICE_INFO,PVB_DEVICE_INFO pVBInfo);
BOOLEAN XGINew_GetLCDDDCInfo(PXGI_HW_DEVICE_INFO HwDeviceExtension,PVB_DEVICE_INFO pVBInfo);
void XGISetDPMS( PXGI_HW_DEVICE_INFO pXGIHWDE , ULONG VESA_POWER_STATE ) ;
BOOLEAN XGINew_BridgeIsEnable(PXGI_HW_DEVICE_INFO,PVB_DEVICE_INFO pVBInfo );
BOOLEAN XGINew_Sense(USHORT tempbx,USHORT tempcx, PVB_DEVICE_INFO pVBInfo);
BOOLEAN XGINew_SenseHiTV( PXGI_HW_DEVICE_INFO HwDeviceExtension , PVB_DEVICE_INFO pVBInfo ) ;
/**************************************************************
Dynamic Sense
*************************************************************/
void XGI_WaitDisplay(void);
BOOLEAN XGI_Is301C(PVB_DEVICE_INFO);
BOOLEAN XGI_Is301LV(PVB_DEVICE_INFO);
#ifdef WIN2000
UCHAR XGI_SenseLCD(PHW_DEVICE_EXTENSION, PVB_DEVICE_INFO);
UCHAR XGI_GetLCDDDCInfo(PHW_DEVICE_EXTENSION,PVB_DEVICE_INFO);
extern BOOL bGetDdcInfo(
PHW_DEVICE_EXTENSION pHWDE,
ULONG ulWhichOne,
PUCHAR pjQueryBuffer,
ULONG ulBufferSize
);
#endif
/* --------------------------------------------------------------------- */
/* Function : XGINew_Is301B */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
BOOLEAN XGINew_Is301B( PVB_DEVICE_INFO pVBInfo )
{
USHORT flag ;
flag = XGINew_GetReg1( pVBInfo->Part4Port , 0x01 ) ;
if ( flag > 0x0B0 )
return( 0 ) ; /* 301b */
else
return( 1 ) ;
}
/* --------------------------------------------------------------------- */
/* Function : XGI_Is301C */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
BOOLEAN XGI_Is301C( PVB_DEVICE_INFO pVBInfo )
{
if ( ( XGINew_GetReg1( pVBInfo->Part4Port , 0x01 ) & 0xF0 ) == 0xC0 )
return( 1 ) ;
if ( XGINew_GetReg1( pVBInfo->Part4Port , 0x01 ) >= 0xD0 )
{
if ( XGINew_GetReg1( pVBInfo->Part4Port , 0x39 ) == 0xE0 )
return( 1 ) ;
}
return( 0 ) ;
}
/* --------------------------------------------------------------------- */
/* Function : XGI_Is301LV */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
BOOLEAN XGI_Is301LV( PVB_DEVICE_INFO pVBInfo )
{
if ( XGINew_GetReg1( pVBInfo->Part4Port , 0x01 ) >= 0xD0 )
{
if ( XGINew_GetReg1( pVBInfo->Part4Port , 0x39 ) == 0xFF )
{
return( 1 ) ;
}
}
return( 0 ) ;
}
/* --------------------------------------------------------------------- */
/* Function : XGINew_Sense */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
BOOLEAN XGINew_Sense( USHORT tempbx , USHORT tempcx, PVB_DEVICE_INFO pVBInfo )
{
USHORT temp , i , tempch ;
temp = tempbx & 0xFF ;
XGINew_SetReg1( pVBInfo->Part4Port , 0x11 , temp ) ;
temp = ( tempbx & 0xFF00 ) >> 8 ;
temp |= ( tempcx & 0x00FF ) ;
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x10 , ~0x1F , temp ) ;
for( i = 0 ; i < 10 ; i++ )
XGI_LongWait( pVBInfo) ;
tempch = ( tempcx & 0x7F00 ) >> 8 ;
temp = XGINew_GetReg1( pVBInfo->Part4Port , 0x03 ) ;
temp = temp ^ ( 0x0E ) ;
temp &= tempch ;
if ( temp > 0 )
return( 1 ) ;
else
return( 0 ) ;
}
#ifdef WIN2000
/* --------------------------------------------------------------------- */
/* Function : XGI_SenseLCD */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
UCHAR XGI_SenseLCD( PHW_DEVICE_EXTENSION pHWDE, PVB_DEVICE_INFO pVBInfo)
{
USHORT tempax , tempbx , tempcx ;
UCHAR SoftSetting = XGI330_SoftSetting ;
if ( pVBInfo->VBType & ( VB_XGI301LV | VB_XGI302LV ) )
return( 1 ) ;
if ( SoftSetting & HotPlugFunction ) /* Hot Plug Detection */
{
XGINew_SetRegAND( pVBInfo->Part4Port , 0x0F , 0x3F ) ;
tempbx = 0 ;
tempcx = 0x9010 ;
if ( XGINew_Sense( tempbx , tempcx, pVBInfo ) )
return( 1 ) ;
return( 0 ) ;
}
else /* Get LCD Info from EDID */
return(XGI_GetLCDDDCInfo(pHWDE, pVBInfo));
}
/* --------------------------------------------------------------------- */
/* Function : XGI_GetLCDDDCInfo */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
UCHAR XGI_GetLCDDDCInfo( PHW_DEVICE_EXTENSION pHWDE , PVB_DEVICE_INFO pVBInfo)
{
UCHAR tempah , tempbl , tempbh ;
USHORT tempbx , temp ;
UCHAR pjEDIDBuf[ 256 ] ;
ULONG ulBufferSize = 256 ;
UCHAR bMASK_OUTPUTSTATE_CRT2LCD = 2 ; /* 0423 shampoo */
bGetDdcInfo( pHWDE , MASK_OUTPUTSTATE_CRT2LCD , pjEDIDBuf , ulBufferSize ) ;
if ( ( *( ( PULONG )pjEDIDBuf ) == 0xFFFFFF00 ) && ( *( ( PULONG )( pjEDIDBuf + 4 ) ) == 0x00FFFFFF ) )
{
tempah = Panel1024x768 ;
tempbl=( *( pjEDIDBuf + 0x3A ) ) & 0xf0 ;
if ( tempbl != 0x40 )
{
tempah = Panel1600x1200 ;
if ( tempbl != 0x60 )
{
tempah = Panel1280x1024 ;
tempbh = ( *( pjEDIDBuf + 0x3B ) ) ;
if ( tempbh != 0x00 )
{
tempah = Panel1280x960 ;
if ( tempbh != 0x0C0 )
{
tempbx = ( ( *( pjEDIDBuf + 0x24 ) ) << 8 ) | ( *( pjEDIDBuf + 0x23 ) ) ;
tempah = Panel1280x1024 ;
if ( !( tempbx & 0x0100 ) )
{
tempah = Panel1024x768 ;
if ( !( tempbx & 0x0E00 ) )
{
tempah = Panel1280x1024 ;
}
}
}
if ( tempbx & 0x00FF )
{
temp = ScalingLCD ;
XGINew_SetRegOR( pVBInfo->P3d4 , 0x37 , temp ) ;
}
}
}
}
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x36 , ( ~0x07 ) , tempah ) ;
tempah = ( ( *( pjEDIDBuf + 0x47 ) ) & 0x06 ) ; /* Polarity */
tempah = ( tempah ^ 0x06 ) << 4 ;
tempah |= LCDSync ;
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x37 , ( ~LCDSyncBit ) , tempah ) ;
tempbh= XGINew_GetReg1( pVBInfo->P3d4 , 0x36 ) ;
tempbh &= 0x07 ;
if ( tempbh == Panel1280x960 )
XGINew_SetRegAND( pVBInfo->P3d4 , 0x37 , 0x0E ) ;
}
else if ( *pjEDIDBuf == 0x20 )
{
tempah = Panel1024x768 ;
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x36 , ( ~0x07 ) , tempah ) ;
}
else
{
return( 0 ) ;
}
return( 1 ) ;
}
/* --------------------------------------------------------------------- */
/* Function : XGI_DySense */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
BOOLEAN XGI_DySense( PHW_DEVICE_EXTENSION pHWDE , PUCHAR ujConnectStatus)
{
UCHAR pre_CRD,pre_SR1E , pre_Part2_0 , pre_Part4_D ;
USHORT tempax , tempbx , tempcx , pushax , temp ;
VB_DEVICE_INFO VBINF;
PVB_DEVICE_INFO pVBInfo = &VBINF;
UCHAR OutputSelect = XGI330_OutputSelect ;
PXGI_HW_DEVICE_INFO HwDeviceExtension= pHWDE->pXGIHWDE ;
UCHAR bConnectStatus = 0 ;
pVBInfo->BaseAddr = HwDeviceExtension->pjIOAddress ;
pVBInfo->ROMAddr = pHWDE->pjVirtualRomBase ;
pVBInfo->P3c2 = pVBInfo->BaseAddr + 0x12 ;
pVBInfo->P3c4 = pVBInfo->BaseAddr + 0x14 ;
pVBInfo->P3d4 = pVBInfo->BaseAddr + 0x24 ;
pVBInfo->Part2Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_10 ;
pVBInfo->Part4Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 ;
pushax = XGINew_GetReg1( pVBInfo->P3d4 , 0x17 ) ; /* 0512 Fix Dysense hanged */
temp = ( pushax & 0x00FF ) | 0x80 ;
XGINew_SetRegOR( pVBInfo->P3d4 , 0x17 , temp ) ;
XGINew_SetReg1( pVBInfo->P3c4 , 0x05 , 0x86 ) ;
/* beginning of dynamic sense CRT1 */
pVBInfo->IF_DEF_CH7007 = 0;
if (pHWDE->bCH7007)
{
InitTo330Pointer( pHWDE->pXGIHWDE->jChipType, pVBInfo ) ;
HwDeviceExtension->pDevice = (PVOID)pHWDE;
pVBInfo->IF_DEF_CH7007 = 1;
/* [Billy] 2007/05/14 For CH7007 */
if ( pVBInfo->IF_DEF_CH7007 == 1 )
{
bConnectStatus = SenseCHTV(HwDeviceExtension->pDevice) ; /* 07/05/28 */
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x32 , ~0x03 , (UCHAR)bConnectStatus ) ;
}
}
if(( pHWDE->jChipID >= XG40 ) || ( pHWDE->jChipID >= XG20 ))
{
if ( pHWDE->jChipID >= XG40 )
XGINew_SetReg1( pVBInfo->P3d4 , 0x57 , 0x4A ) ; /* write sense pattern 30->4a */
else
XGINew_SetReg1( pVBInfo->P3d4 , 0x57 , 0x5F ) ; /* write sense pattern */
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x53 , 0xFF , 0x02 ) ; /* enable sense DAC */
XGI_WaitDisply(pVBInfo) ;
if(XGINew_GetReg2( pVBInfo->P3c2 ) & 0x10 )
bConnectStatus |= Monitor1Sense ;
XGINew_SetRegAND( pVBInfo->P3d4 , 0x53 , 0xFD ) ; /* disable sense DAC */
XGINew_SetRegAND( pVBInfo->P3d4 , 0x57 , 0x00 ) ; /* clear sense pattern */
/* ---------- End of dynamic sense CRT1 ----------- */
/* ---------- beginning of dynamic sense VB ------------ */
pre_SR1E = XGINew_GetReg1( pVBInfo->P3c4 , 0x1E ) ;
XGINew_SetRegOR( pVBInfo->P3c4 , 0x1E , 0x20 ) ; /* Enable CRT2,work-a-round for 301B/301LV/302LV */
pre_Part2_0 = XGINew_GetReg1( pVBInfo->Part2Port , 0x00 ) ;
pre_Part4_D = XGINew_GetReg1( pVBInfo->Part4Port , 0x0D ) ;
if ( XGI_Is301C( pVBInfo ) ) /* 301C only */
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x0D , ~0x07 , 0x01 ) ; /* Set Part4 0x0D D[2:0] to 001b */
/* tempax = 0 ; */
if ( !XGI_Is301LV( pVBInfo ) )
{
tempbx = XGI330_RGBSenseData2 ;
tempcx = 0x0E08 ;
if(XGINew_Sense( tempbx , tempcx, pVBInfo ) )
{
bConnectStatus |= Monitor2Sense ;
if ( OutputSelect & SetSCARTOutput )
{
bConnectStatus ^= ( Monitor2Sense | SCARTSense ) ;
}
}
}
if ( XGI_Is301C( pVBInfo ) ) /* 301C only */
XGINew_SetRegOR( pVBInfo->Part4Port , 0x0D , 0x04 ) ; /* Set Part4 0x0D D[2]=1 for dynamic sense */
if ( ( XGINew_Is301B( pVBInfo ) ) )
XGINew_SetRegOR( pVBInfo->Part2Port , 0x00 , 0x0C ) ; /* ????????? */
if ( XGINew_SenseHiTV( HwDeviceExtension , pVBInfo) ) /* add by kuku for Dysense HiTV //start */
{
bConnectStatus|= YPbPrSense ;
}
else
{
tempbx = XGI330_YCSenseData2 ; /* Y/C Sense Data Ptr */
tempcx = 0x0604 ;
if ( XGINew_Sense( tempbx , tempcx , pVBInfo) )
bConnectStatus |= SVIDEOSense ;
if ( OutputSelect & BoardTVType )
{
tempbx = XGI330_VideoSenseData2 ;
tempcx = 0x0804 ;
if ( XGINew_Sense(tempbx , tempcx, pVBInfo) )
bConnectStatus|= AVIDEOSense ;
}
else
{
if ( !( bConnectStatus & SVIDEOSense ) )
{
tempbx = XGI330_VideoSenseData2 ;
tempcx = 0x0804 ;
if ( XGINew_Sense( tempbx , tempcx, pVBInfo ) )
bConnectStatus |= AVIDEOSense ;
}
}
} /* end */
/* DySenseVBCnt */
tempbx = 0 ;
tempcx = 0 ;
XGINew_Sense(tempbx , tempcx, pVBInfo ) ;
if ( !( bConnectStatus & Monitor2Sense ) )
{
if ( XGI_SenseLCD( pHWDE , pVBInfo ) )
bConnectStatus |= LCDSense ;
}
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x32 , ~( AVIDEOSense | SVIDEOSense | LCDSense | Monitor2Sense | Monitor1Sense ) , bConnectStatus ) ;
XGINew_SetReg1( pVBInfo->Part4Port , 0x0D , pre_Part4_D ) ;
XGINew_SetReg1( pVBInfo->Part2Port , 0x00 , pre_Part2_0 ) ;
XGINew_SetReg1( pVBInfo->P3c4 , 0x1E , pre_SR1E ) ;
if ( XGI_Is301C( pVBInfo ) ) /* 301C only */
{
tempax = XGINew_GetReg1( pVBInfo->Part2Port , 0x00 ) ;
if ( tempax & 0x20 )
{
/* Reset VBPro */
for( tempcx = 2 ; tempcx > 0 ; tempcx-- )
{
tempax ^= 0x20 ;
XGINew_SetReg1( pVBInfo->Part2Port , 0x00 , tempax ) ;
}
}
}
/* End of dynamic sense VB */
}
else
{
XGI_SenseCRT1(pVBInfo) ;
XGI_GetSenseStatus( HwDeviceExtension, pVBInfo ) ; /* sense CRT2 */
bConnectStatus = XGINew_GetReg1( pVBInfo->P3d4 , 0x32 ) ;
}
temp = pushax & 0x00FF ; /* 0512 Fix Dysense hanged */
XGINew_SetReg1( pVBInfo->P3d4 , 0x17 , temp ) ;
if ( bConnectStatus )
{
*ujConnectStatus = bConnectStatus ;
return( 1 ) ;
}
else
return( 0 ) ;
}
#endif /* WIN2000 */
/* --------------------------------------------------------------------- */
/* Function : XGISetDPMS */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
VOID XGISetDPMS( PXGI_HW_DEVICE_INFO pXGIHWDE , ULONG VESA_POWER_STATE )
{
USHORT ModeNo, ModeIdIndex ;
UCHAR temp ;
VB_DEVICE_INFO VBINF;
PVB_DEVICE_INFO pVBInfo = &VBINF;
pVBInfo->BaseAddr = (ULONG)pXGIHWDE->pjIOAddress ;
pVBInfo->ROMAddr = pXGIHWDE->pjVirtualRomBase ;
pVBInfo->IF_DEF_LVDS = 0 ;
pVBInfo->IF_DEF_CH7005 = 0 ;
pVBInfo->IF_DEF_HiVision = 1 ;
pVBInfo->IF_DEF_LCDA = 1 ;
pVBInfo->IF_DEF_CH7017 = 0 ;
pVBInfo->IF_DEF_YPbPr = 1 ;
pVBInfo->IF_DEF_CRT2Monitor = 0 ;
pVBInfo->IF_DEF_VideoCapture = 0 ;
pVBInfo->IF_DEF_ScaleLCD = 0 ;
pVBInfo->IF_DEF_OEMUtil = 0 ;
pVBInfo->IF_DEF_PWD = 0 ;
InitTo330Pointer( pXGIHWDE->jChipType, pVBInfo ) ;
ReadVBIOSTablData( pXGIHWDE->jChipType , pVBInfo) ;
pVBInfo->P3c4 = pVBInfo->BaseAddr + 0x14 ;
pVBInfo->P3d4 = pVBInfo->BaseAddr + 0x24 ;
pVBInfo->P3c0 = pVBInfo->BaseAddr + 0x10 ;
pVBInfo->P3ce = pVBInfo->BaseAddr + 0x1e ;
pVBInfo->P3c2 = pVBInfo->BaseAddr + 0x12 ;
pVBInfo->P3ca = pVBInfo->BaseAddr + 0x1a ;
pVBInfo->P3c6 = pVBInfo->BaseAddr + 0x16 ;
pVBInfo->P3c7 = pVBInfo->BaseAddr + 0x17 ;
pVBInfo->P3c8 = pVBInfo->BaseAddr + 0x18 ;
pVBInfo->P3c9 = pVBInfo->BaseAddr + 0x19 ;
pVBInfo->P3da = pVBInfo->BaseAddr + 0x2A ;
pVBInfo->Part0Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_00 ;
pVBInfo->Part1Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_04 ;
pVBInfo->Part2Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_10 ;
pVBInfo->Part3Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_12 ;
pVBInfo->Part4Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 ;
pVBInfo->Part5Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 + 2 ;
if ( pXGIHWDE->jChipType == XG27 )
{
if ( ( XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) & 0xE0 ) == 0xC0 )
{
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) ;
ModeNo = XGINew_GetReg1( pVBInfo->P3d4 , 0x34 ) ;
XGI_SearchModeID( ModeNo , &ModeIdIndex, pVBInfo ) ;
XGI_GetVGAType( pXGIHWDE , pVBInfo ) ;
if ( ( pXGIHWDE->ujVBChipID == VB_CHIP_301 ) || ( pXGIHWDE->ujVBChipID == VB_CHIP_302 ) || ( pVBInfo->IF_DEF_CH7007 == 1 ))
{
XGI_GetVBType( pVBInfo ) ;
XGI_GetVBInfo( ModeNo , ModeIdIndex , pXGIHWDE, pVBInfo ) ;
XGI_GetTVInfo( ModeNo , ModeIdIndex, pVBInfo ) ;
XGI_GetLCDInfo( ModeNo , ModeIdIndex, pVBInfo ) ;
}
if ( VESA_POWER_STATE == 0x00000400 )
XGINew_SetReg1( pVBInfo->Part4Port , 0x31 , ( UCHAR )( XGINew_GetReg1( pVBInfo->Part4Port , 0x31 ) & 0xFE ) ) ;
else
XGINew_SetReg1( pVBInfo->Part4Port , 0x31 , ( UCHAR )( XGINew_GetReg1( pVBInfo->Part4Port , 0x31 ) | 0x01 ) ) ;
temp = ( UCHAR )XGINew_GetReg1( pVBInfo->P3c4 , 0x1f ) ;
temp &= 0x3f ;
switch ( VESA_POWER_STATE )
{
case 0x00000000: /* on */
if ( ( pXGIHWDE->ujVBChipID == VB_CHIP_301 ) || ( pXGIHWDE->ujVBChipID == VB_CHIP_302 ) )
{
XGINew_SetReg1( pVBInfo->P3c4 , 0x1f , ( UCHAR )( temp | 0x00 ) ) ;
XGI_EnableBridge( pXGIHWDE, pVBInfo ) ;
}
else
{
if ( pXGIHWDE->jChipType == XG21 )
{
if ( pVBInfo->IF_DEF_LVDS == 1 )
{
XGI_XG21BLSignalVDD( 0x01 , 0x01, pVBInfo ) ; /* LVDS VDD on */
XGI_XG21SetPanelDelay( 2,pVBInfo ) ;
}
}
if ( pXGIHWDE->jChipType == XG27 )
{
if ( pVBInfo->IF_DEF_LVDS == 1 )
{
XGI_XG27BLSignalVDD( 0x01 , 0x01, pVBInfo ) ; /* LVDS VDD on */
XGI_XG21SetPanelDelay( 2,pVBInfo ) ;
}
}
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x1F , ~0xC0 , 0x00 ) ;
XGINew_SetRegAND( pVBInfo->P3c4 , 0x01 , ~0x20 ) ; /* CRT on */
if ( pXGIHWDE->jChipType == XG21 )
{
temp = XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) ;
if ( temp & 0xE0 )
{
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x09 , ~0x80 , 0x80 ) ; /* DVO ON */
XGI_SetXG21FPBits( pVBInfo );
XGINew_SetRegAND( pVBInfo->P3d4 , 0x4A , ~0x20 ) ; /* Enable write GPIOF */
/*XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x48 , ~0x20 , 0x20 ) ;*/ /* LCD Display ON */
}
XGI_XG21BLSignalVDD( 0x20 , 0x20, pVBInfo ) ; /* LVDS signal on */
XGI_DisplayOn( pXGIHWDE, pVBInfo );
}
if ( pXGIHWDE->jChipType == XG27 )
{
temp = XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) ;
if ( temp & 0xE0 )
{
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x09 , ~0x80 , 0x80 ) ; /* DVO ON */
XGI_SetXG27FPBits( pVBInfo );
XGINew_SetRegAND( pVBInfo->P3d4 , 0x4A , ~0x20 ) ; /* Enable write GPIOF */
/*XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x48 , ~0x20 , 0x20 ) ;*/ /* LCD Display ON */
}
XGI_XG27BLSignalVDD( 0x20 , 0x20, pVBInfo ) ; /* LVDS signal on */
XGI_DisplayOn( pXGIHWDE, pVBInfo );
}
}
break ;
case 0x00000100: /* standby */
if ( pXGIHWDE->jChipType >= XG21 )
{
XGI_DisplayOff( pXGIHWDE, pVBInfo );
}
XGINew_SetReg1( pVBInfo->P3c4 , 0x1f , ( UCHAR )( temp | 0x40 ) ) ;
break ;
case 0x00000200: /* suspend */
if ( pXGIHWDE->jChipType == XG21 )
{
XGI_DisplayOff( pXGIHWDE, pVBInfo );
XGI_XG21BLSignalVDD( 0x20 , 0x00, pVBInfo ) ; /* LVDS signal off */
}
if ( pXGIHWDE->jChipType == XG27 )
{
XGI_DisplayOff( pXGIHWDE, pVBInfo );
XGI_XG27BLSignalVDD( 0x20 , 0x00, pVBInfo ) ; /* LVDS signal off */
}
XGINew_SetReg1( pVBInfo->P3c4 , 0x1f , ( UCHAR )( temp | 0x80 ) ) ;
break ;
case 0x00000400: /* off */
if ( (pXGIHWDE->ujVBChipID == VB_CHIP_301 ) || ( pXGIHWDE->ujVBChipID == VB_CHIP_302 ) )
{
XGINew_SetReg1( pVBInfo->P3c4 , 0x1f , ( UCHAR )( temp | 0xc0 ) ) ;
XGI_DisableBridge( pXGIHWDE, pVBInfo ) ;
}
else
{
if ( pXGIHWDE->jChipType == XG21 )
{
XGI_DisplayOff( pXGIHWDE, pVBInfo );
XGI_XG21BLSignalVDD( 0x20 , 0x00, pVBInfo ) ; /* LVDS signal off */
temp = XGINew_GetReg1( pVBInfo->P3d4 , 0x38 ) ;
if ( temp & 0xE0 )
{
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 */
}
}
if ( pXGIHWDE->jChipType == XG27 )
{
XGI_DisplayOff( 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( PXGI_HW_DEVICE_INFO HwDeviceExtension , PVB_DEVICE_INFO pVBInfo)
{
USHORT tempax = 0 , tempbx , tempcx , temp ,
P2reg0 = 0 , SenseModeNo = 0 , OutputSelect = *pVBInfo->pOutputSelect ,
ModeIdIndex , i ;
pVBInfo->BaseAddr = (ULONG)HwDeviceExtension->pjIOAddress ;
if ( pVBInfo->IF_DEF_LVDS == 1 )
{
tempax = XGINew_GetReg1( pVBInfo->P3c4 , 0x1A ) ; /* ynlai 02/27/2002 */
tempbx = XGINew_GetReg1( pVBInfo->P3c4 , 0x1B ) ;
tempax = ( ( tempax & 0xFE ) >> 1 ) | ( tempbx << 8 ) ;
if ( tempax == 0x00 )
{ /* Get Panel id from DDC */
temp = XGINew_GetLCDDDCInfo( HwDeviceExtension, pVBInfo ) ;
if ( temp == 1 )
{ /* LCD connect */
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x39 , 0xFF , 0x01 ) ; /* set CR39 bit0="1" */
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x37 , 0xEF , 0x00 ) ; /* clean CR37 bit4="0" */
temp = LCDSense ;
}
else
{ /* LCD don't connect */
temp = 0 ;
}
}
else
{
XGINew_GetPanelID(pVBInfo) ;
temp = LCDSense ;
}
tempbx = ~( LCDSense | AVIDEOSense | SVIDEOSense ) ;
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x32 , tempbx , temp ) ;
}
else
{ /* for 301 */
if ( pVBInfo->VBInfo & SetCRT2ToHiVisionTV )
{ /* for HiVision */
tempax = XGINew_GetReg1( pVBInfo->P3c4 , 0x38 ) ;
temp = tempax & 0x01 ;
tempax = XGINew_GetReg1( pVBInfo->P3c4 , 0x3A ) ;
temp = temp | ( tempax & 0x02 ) ;
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x32 , 0xA0 , temp ) ;
}
else
{
if ( XGI_BridgeIsOn( pVBInfo ) )
{
P2reg0 = XGINew_GetReg1( pVBInfo->Part2Port , 0x00 ) ;
if ( !XGINew_BridgeIsEnable( HwDeviceExtension, pVBInfo ) )
{
SenseModeNo = 0x2e ;
/* XGINew_SetReg1( pVBInfo->P3d4 , 0x30 , 0x41 ) ; */
/* XGISetModeNew( HwDeviceExtension , 0x2e ) ; // ynlai InitMode */
temp = XGI_SearchModeID( SenseModeNo , &ModeIdIndex, pVBInfo ) ;
XGI_GetVGAType( HwDeviceExtension , pVBInfo) ;
XGI_GetVBType( pVBInfo ) ;
pVBInfo->SetFlag = 0x00 ;
pVBInfo->ModeType = ModeVGA ;
pVBInfo->VBInfo = SetCRT2ToRAMDAC | LoadDACFlag | SetInSlaveMode ;
XGI_GetLCDInfo( 0x2e , ModeIdIndex, pVBInfo ) ;
XGI_GetTVInfo( 0x2e , ModeIdIndex, pVBInfo ) ;
XGI_EnableBridge( HwDeviceExtension, pVBInfo ) ;
XGI_SetCRT2Group301( SenseModeNo , HwDeviceExtension, pVBInfo ) ;
XGI_SetCRT2ModeRegs( 0x2e , HwDeviceExtension, pVBInfo ) ;
/* XGI_DisableBridge( HwDeviceExtension, pVBInfo ) ; */
XGINew_SetRegANDOR( pVBInfo->P3c4 , 0x01 , 0xDF , 0x20 ) ; /* Display Off 0212 */
for( i = 0 ; i < 20 ; i++ )
{
XGI_LongWait(pVBInfo) ;
}
}
XGINew_SetReg1( pVBInfo->Part2Port , 0x00 , 0x1c ) ;
tempax = 0 ;
tempbx = *pVBInfo->pRGBSenseData ;
if ( !( XGINew_Is301B( pVBInfo ) ) )
{
tempbx = *pVBInfo->pRGBSenseData2 ;
}
tempcx = 0x0E08 ;
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) )
{
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) )
{
tempax |= Monitor2Sense ;
}
}
if ( pVBInfo->VBType & VB_XGI301C)
{
XGINew_SetRegOR( pVBInfo->Part4Port , 0x0d , 0x04 ) ;
}
if ( XGINew_SenseHiTV( HwDeviceExtension , pVBInfo) ) /* add by kuku for Multi-adapter sense HiTV */
{
tempax |= HiTVSense ;
if ( ( pVBInfo->VBType & VB_XGI301C ) )
{
tempax ^= ( HiTVSense | YPbPrSense ) ;
}
}
if ( !( tempax & ( HiTVSense | YPbPrSense ) ) ) /* start */
{
tempbx = *pVBInfo->pYCSenseData ;
if ( !( XGINew_Is301B( pVBInfo ) ) )
{
tempbx=*pVBInfo->pYCSenseData2;
}
tempcx = 0x0604 ;
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) )
{
if ( XGINew_Sense(tempbx , tempcx, pVBInfo ) )
{
tempax |= SVIDEOSense ;
}
}
if ( OutputSelect & BoardTVType )
{
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 ;
}
}
}
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 */
}
/* --------------------------------------------------------------------- */
/* Function : XGINew_SenseLCD */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
USHORT XGINew_SenseLCD( PXGI_HW_DEVICE_INFO HwDeviceExtension ,PVB_DEVICE_INFO pVBInfo)
{
/* USHORT SoftSetting ; */
USHORT temp ;
if ( ( HwDeviceExtension->jChipType >= XG20 ) || ( HwDeviceExtension->jChipType >= XG40 ) )
temp = 0 ;
else
temp=XGINew_GetPanelID(pVBInfo) ;
if( !temp )
temp = XGINew_GetLCDDDCInfo( HwDeviceExtension, pVBInfo ) ;
return( temp ) ;
}
/* --------------------------------------------------------------------- */
/* Function : XGINew_GetLCDDDCInfo */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
BOOLEAN XGINew_GetLCDDDCInfo( PXGI_HW_DEVICE_INFO HwDeviceExtension,PVB_DEVICE_INFO pVBInfo)
{
USHORT temp ;
/* add lcd sense */
if ( HwDeviceExtension->ulCRT2LCDType == LCD_UNKNOWN )
{
return( 0 ) ;
}
else
{
temp = ( USHORT )HwDeviceExtension->ulCRT2LCDType ;
switch( HwDeviceExtension->ulCRT2LCDType )
{
case LCD_INVALID:
case LCD_800x600:
case LCD_1024x768:
case LCD_1280x1024:
break ;
case LCD_640x480:
case LCD_1024x600:
case LCD_1152x864:
case LCD_1280x960:
case LCD_1152x768:
temp = 0 ;
break ;
case LCD_1400x1050:
case LCD_1280x768:
case LCD_1600x1200:
break ;
case LCD_1920x1440:
case LCD_2048x1536:
temp = 0 ;
break ;
default:
break ;
}
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x36 , 0xF0 , temp ) ;
return( 1 ) ;
}
}
/* --------------------------------------------------------------------- */
/* Function : */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
BOOLEAN XGINew_GetPanelID(PVB_DEVICE_INFO pVBInfo )
{
USHORT PanelTypeTable[ 16 ] = { SyncNN | PanelRGB18Bit | Panel800x600 | _PanelType00 ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType01 ,
SyncNN | PanelRGB18Bit | Panel800x600 | _PanelType02 ,
SyncNN | PanelRGB18Bit | Panel640x480 | _PanelType03 ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType04 ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType05 ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType06 ,
SyncNN | PanelRGB24Bit | Panel1024x768 | _PanelType07 ,
SyncNN | PanelRGB18Bit | Panel800x600 | _PanelType08 ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType09 ,
SyncNN | PanelRGB18Bit | Panel800x600 | _PanelType0A ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType0B ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType0C ,
SyncNN | PanelRGB24Bit | Panel1024x768 | _PanelType0D ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType0E ,
SyncNN | PanelRGB18Bit | Panel1024x768 | _PanelType0F } ;
USHORT tempax , tempbx , temp ;
/* USHORT return_flag ; */
tempax = XGINew_GetReg1( pVBInfo->P3c4 , 0x1A ) ;
tempbx = tempax & 0x1E ;
if ( tempax == 0 )
return( 0 ) ;
else
{
/*
if ( !( tempax & 0x10 ) )
{
if ( pVBInfo->IF_DEF_LVDS == 1 )
{
tempbx = 0 ;
temp = XGINew_GetReg1( pVBInfo->P3c4 , 0x38 ) ;
if ( temp & 0x40 )
tempbx |= 0x08 ;
if ( temp & 0x20 )
tempbx |= 0x02 ;
if ( temp & 0x01 )
tempbx |= 0x01 ;
temp = XGINew_GetReg1( pVBInfo->P3c4 , 0x39 ) ;
if ( temp & 0x80 )
tempbx |= 0x04 ;
}
else
{
return( 0 ) ;
}
}
*/
tempbx = tempbx >> 1 ;
temp = tempbx & 0x00F ;
XGINew_SetReg1( pVBInfo->P3d4 , 0x36 , temp ) ;
tempbx-- ;
tempbx = PanelTypeTable[ tempbx ] ;
temp = ( tempbx & 0xFF00 ) >> 8 ;
XGINew_SetRegANDOR( pVBInfo->P3d4 , 0x37 , ~( LCDSyncBit | LCDRGB18Bit ) , temp ) ;
return( 1 ) ;
}
}
/* --------------------------------------------------------------------- */
/* Function : XGINew_BridgeIsEnable */
/* Input : */
/* Output : */
/* Description : */
/* --------------------------------------------------------------------- */
BOOLEAN XGINew_BridgeIsEnable( PXGI_HW_DEVICE_INFO HwDeviceExtension ,PVB_DEVICE_INFO pVBInfo)
{
USHORT flag ;
if ( XGI_BridgeIsOn( pVBInfo ) == 0 )
{
flag = XGINew_GetReg1( pVBInfo->Part1Port , 0x0 ) ;
if ( flag & 0x050 )
{
return( 1 ) ;
}
else
{
return( 0 ) ;
}
}
return( 0 ) ;
}
/* ------------------------------------------------------ */
/* Function : XGINew_SenseHiTV */
/* Input : */
/* Output : */
/* Description : */
/* ------------------------------------------------------ */
BOOLEAN XGINew_SenseHiTV( PXGI_HW_DEVICE_INFO HwDeviceExtension , PVB_DEVICE_INFO pVBInfo )
{
USHORT tempbx , tempcx , temp , i , tempch;
tempbx = *pVBInfo->pYCSenseData2 ;
tempcx = 0x0604 ;
temp = tempbx & 0xFF ;
XGINew_SetReg1( pVBInfo->Part4Port , 0x11 , temp ) ;
temp = ( tempbx & 0xFF00 ) >> 8 ;
temp |= ( tempcx & 0x00FF ) ;
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x10 , ~0x1F , temp ) ;
for( i = 0 ; i < 10 ; i++ )
XGI_LongWait(pVBInfo) ;
tempch = ( tempcx & 0xFF00 ) >> 8;
temp = XGINew_GetReg1( pVBInfo->Part4Port , 0x03 ) ;
temp = temp ^ ( 0x0E ) ;
temp &= tempch ;
if ( temp != tempch )
return( 0 ) ;
tempbx = *pVBInfo->pVideoSenseData2 ;
tempcx = 0x0804 ;
temp = tempbx & 0xFF ;
XGINew_SetReg1( pVBInfo->Part4Port , 0x11 , temp ) ;
temp = ( tempbx & 0xFF00 ) >> 8 ;
temp |= ( tempcx & 0x00FF ) ;
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x10 , ~0x1F , temp ) ;
for( i = 0 ; i < 10 ; i++ )
XGI_LongWait(pVBInfo) ;
tempch = ( tempcx & 0xFF00 ) >> 8;
temp = XGINew_GetReg1( pVBInfo->Part4Port , 0x03 ) ;
temp = temp ^ ( 0x0E ) ;
temp &= tempch ;
if ( temp != tempch )
return( 0 ) ;
else
{
tempbx = 0x3FF ;
tempcx = 0x0804 ;
temp = tempbx & 0xFF ;
XGINew_SetReg1( pVBInfo->Part4Port , 0x11 , temp ) ;
temp = ( tempbx & 0xFF00 ) >> 8 ;
temp |= ( tempcx & 0x00FF ) ;
XGINew_SetRegANDOR( pVBInfo->Part4Port , 0x10 , ~0x1F , temp ) ;
for( i = 0 ; i < 10 ; i++ )
XGI_LongWait(pVBInfo) ;
tempch = ( tempcx & 0xFF00 ) >> 8;
temp = XGINew_GetReg1( pVBInfo->Part4Port , 0x03 ) ;
temp = temp ^ ( 0x0E ) ;
temp &= tempch ;
if ( temp != tempch )
return( 1 ) ;
else
return( 0 ) ;
}
}
/*
;-----------------------------------------------------------------------------
; Description: Get Panel support
; O/P :
; BL: Panel ID=81h for no scaler LVDS
; BH: Panel enhanced Mode Count
; CX: Panel H. resolution
; DX: PAnel V. resolution
;-----------------------------------------------------------------------------
*/
void XGI_XG21Fun14Sub70( PVB_DEVICE_INFO pVBInfo , PX86_REGS pBiosArguments )
{
USHORT ModeIdIndex;
USHORT ModeNo;
USHORT EModeCount;
USHORT lvdstableindex;
lvdstableindex = XGI_GetLVDSOEMTableIndex( pVBInfo );
pBiosArguments->h.bl = 0x81;
pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHDE;
pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVDE;
EModeCount = 0;
pBiosArguments->x.ax = 0x0014;
for( ModeIdIndex = 0 ; ; ModeIdIndex ++ )
{
ModeNo = pVBInfo->EModeIDTable[ ModeIdIndex ].Ext_ModeID;
if ( pVBInfo->EModeIDTable[ ModeIdIndex ].Ext_ModeID == 0xFF )
{
pBiosArguments->h.bh = (UCHAR) EModeCount;
return;
}
if ( !XGI_XG21CheckLVDSMode( ModeNo , ModeIdIndex, pVBInfo) )
{
continue;
}
EModeCount++ ;
}
}
/*(
;-----------------------------------------------------------------------------
;
; Description: Get Panel mode ID for enhanced mode
; I/P : BH: EModeIndex ( which < Panel enhanced Mode Count )
; O/P :
; BL: Mode ID
; CX: H. resolution of the assigned by the index
; DX: V. resolution of the assigned by the index
;
;-----------------------------------------------------------------------------
*/
void XGI_XG21Fun14Sub71( PVB_DEVICE_INFO pVBInfo , PX86_REGS pBiosArguments )
{
USHORT EModeCount;
USHORT ModeIdIndex,resindex;
USHORT ModeNo;
USHORT EModeIndex = pBiosArguments->h.bh;
EModeCount = 0;
for( ModeIdIndex = 0 ; ; ModeIdIndex ++ )
{
ModeNo = pVBInfo->EModeIDTable[ ModeIdIndex ].Ext_ModeID;
if ( pVBInfo->EModeIDTable[ ModeIdIndex ].Ext_ModeID == 0xFF )
{
pBiosArguments->x.ax = 0x0114;
return;
}
if ( !XGI_XG21CheckLVDSMode( ModeNo , ModeIdIndex, pVBInfo) )
{
continue;
}
if (EModeCount == EModeIndex)
{
resindex = XGI_GetResInfo( ModeNo , ModeIdIndex, pVBInfo ) ;
pBiosArguments->h.bl = (UCHAR) ModeNo;
pBiosArguments->x.cx = pVBInfo->ModeResInfo[ resindex ].HTotal ; /* xres->ax */
pBiosArguments->x.dx = pVBInfo->ModeResInfo[ resindex ].VTotal ; /* yres->bx */
pBiosArguments->x.ax = 0x0014;
}
EModeCount++ ;
}
}
/*
;-----------------------------------------------------------------------------
;
; Description: Validate Panel modes ID support
; I/P :
; BL: ModeID
; O/P :
; CX: H. resolution of the assigned by the index
; DX: V. resolution of the assigned by the index
;
;-----------------------------------------------------------------------------
*/
void XGI_XG21Fun14Sub72( PVB_DEVICE_INFO pVBInfo , PX86_REGS pBiosArguments )
{
USHORT ModeIdIndex,resindex;
USHORT ModeNo;
ModeNo = pBiosArguments->h.bl ;
XGI_SearchModeID( ModeNo, &ModeIdIndex, pVBInfo);
if ( !XGI_XG21CheckLVDSMode( ModeNo , ModeIdIndex, pVBInfo) )
{
pBiosArguments->x.cx = 0;
pBiosArguments->x.dx = 0;
pBiosArguments->x.ax = 0x0114;
return;
}
resindex = XGI_GetResInfo( ModeNo , ModeIdIndex, pVBInfo ) ;
if ( ModeNo <= 0x13 )
{
pBiosArguments->x.cx = pVBInfo->StResInfo[ resindex ].HTotal ;
pBiosArguments->x.dx = pVBInfo->StResInfo[ resindex ].VTotal ;
}
else
{
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
; I/P : Select
; to get panel horizontal timing
; to get panel vertical timing
; to get channel clock parameter
; to get panel misc information
;
; O/P :
; BL: for input Select = 0 ;
; BX: *Value1 = Horizontal total
; CX: *Value2 = Horizontal front porch
; DX: *Value2 = Horizontal sync width
; BL: for input Select = 1 ;
; BX: *Value1 = Vertical total
; CX: *Value2 = Vertical front porch
; DX: *Value2 = Vertical sync width
; BL: for input Select = 2 ;
; BX: Value1 = The first CLK parameter
; CX: Value2 = The second CLK parameter
; BL: for input Select = 4 ;
; BX[15]: *Value1 D[15] VESA V. Polarity
; BX[14]: *Value1 D[14] VESA H. Polarity
; BX[7]: *Value1 D[7] Panel V. Polarity
; BX[6]: *Value1 D[6] Panel H. Polarity
;-----------------------------------------------------------------------------
*/
void XGI_XG21Fun14Sub73( PVB_DEVICE_INFO pVBInfo , PX86_REGS pBiosArguments )
{
UCHAR Select;
USHORT lvdstableindex;
lvdstableindex = XGI_GetLVDSOEMTableIndex( pVBInfo );
Select = pBiosArguments->h.bl;
switch (Select)
{
case 0:
pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHT;
pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHFP;
pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSHSYNC;
break;
case 1:
pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVT;
pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVFP;
pBiosArguments->x.dx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDSVSYNC;
break;
case 2:
pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].VCLKData1;
pBiosArguments->x.cx = pVBInfo->XG21_LVDSCapList[lvdstableindex].VCLKData2;
break;
case 4:
pBiosArguments->x.bx = pVBInfo->XG21_LVDSCapList[lvdstableindex].LVDS_Capability;
break;
}
pBiosArguments->x.ax = 0x0014;
}
void XGI_XG21Fun14( PXGI_HW_DEVICE_INFO pXGIHWDE, PX86_REGS pBiosArguments)
{
VB_DEVICE_INFO VBINF;
PVB_DEVICE_INFO pVBInfo = &VBINF;
pVBInfo->IF_DEF_LVDS = 0 ;
pVBInfo->IF_DEF_CH7005 = 0 ;
pVBInfo->IF_DEF_HiVision = 1 ;
pVBInfo->IF_DEF_LCDA = 1 ;
pVBInfo->IF_DEF_CH7017 = 0 ;
pVBInfo->IF_DEF_YPbPr = 1 ;
pVBInfo->IF_DEF_CRT2Monitor = 0 ;
pVBInfo->IF_DEF_VideoCapture = 0 ;
pVBInfo->IF_DEF_ScaleLCD = 0 ;
pVBInfo->IF_DEF_OEMUtil = 0 ;
pVBInfo->IF_DEF_PWD = 0 ;
InitTo330Pointer( pXGIHWDE->jChipType, pVBInfo ) ;
ReadVBIOSTablData( pXGIHWDE->jChipType , pVBInfo) ;
pVBInfo->P3c4 = pVBInfo->BaseAddr + 0x14 ;
pVBInfo->P3d4 = pVBInfo->BaseAddr + 0x24 ;
pVBInfo->P3c0 = pVBInfo->BaseAddr + 0x10 ;
pVBInfo->P3ce = pVBInfo->BaseAddr + 0x1e ;
pVBInfo->P3c2 = pVBInfo->BaseAddr + 0x12 ;
pVBInfo->P3ca = pVBInfo->BaseAddr + 0x1a ;
pVBInfo->P3c6 = pVBInfo->BaseAddr + 0x16 ;
pVBInfo->P3c7 = pVBInfo->BaseAddr + 0x17 ;
pVBInfo->P3c8 = pVBInfo->BaseAddr + 0x18 ;
pVBInfo->P3c9 = pVBInfo->BaseAddr + 0x19 ;
pVBInfo->P3da = pVBInfo->BaseAddr + 0x2A ;
pVBInfo->Part0Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_00 ;
pVBInfo->Part1Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_04 ;
pVBInfo->Part2Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_10 ;
pVBInfo->Part3Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_12 ;
pVBInfo->Part4Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 ;
pVBInfo->Part5Port = pVBInfo->BaseAddr + XGI_CRT2_PORT_14 + 2 ;
switch(pBiosArguments->x.ax)
{
case 0x1470:
XGI_XG21Fun14Sub70( pVBInfo , pBiosArguments ) ;
break;
case 0x1471:
XGI_XG21Fun14Sub71( pVBInfo , pBiosArguments ) ;
break;
case 0x1472:
XGI_XG21Fun14Sub72( pVBInfo , pBiosArguments ) ;
break;
case 0x1473:
XGI_XG21Fun14Sub73( pVBInfo , pBiosArguments ) ;
break;
}
}