mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1116 lines
43 KiB
1116 lines
43 KiB
/*/****************************************************************************
|
|
* name: MGAVidInit
|
|
*
|
|
* description: Initialise the VIDEO related hardware of the MGA device.
|
|
*
|
|
* designed: Bart Simpson, february 11, 1993
|
|
* last modified: $Author: bleblanc $, $Date: 94/11/09 10:48:34 $
|
|
*
|
|
* version: $Id: VID.C 1.49 94/11/09 10:48:34 bleblanc Exp $
|
|
*
|
|
* parameters: BYTE* to Video buffer
|
|
* modifies: MGA hardware
|
|
* calls: GetMGAConfiguration
|
|
* returns: -
|
|
******************************************************************************/
|
|
|
|
#include "switches.h"
|
|
#include "g3dstd.h"
|
|
|
|
#include "caddi.h"
|
|
#include "def.h"
|
|
#include "mga.h"
|
|
|
|
#include "global.h"
|
|
#include "proto.h"
|
|
|
|
#include "mgai.h"
|
|
|
|
#ifdef WINDOWS_NT
|
|
#include "video.h"
|
|
#if defined(ALLOC_PRAGMA)
|
|
#pragma alloc_text(PAGE,MGAVidInit)
|
|
#endif
|
|
#endif
|
|
|
|
/* extern void setTVP3026Freq(volatile BYTE _Far *pDevice, LONG fout_voulue, LONG reg, WORD pWidth); */
|
|
|
|
/*-------------- start of extern global variables -----------------------*/
|
|
|
|
VOID MGAVidInit(BYTE* pInitBuffer, BYTE* pVideoBuffer)
|
|
{
|
|
DWORD DST0, DST1, Info;
|
|
DWORD TmpDword, ByteCount, RegisterCount;
|
|
BYTE TmpByte, DUB_SEL;
|
|
BOOL pixelClk90Mhz;
|
|
volatile BYTE _Far *pDevice;
|
|
WORD res;
|
|
|
|
#if( defined(WINDOWS) || defined(OS2))
|
|
|
|
((struct {unsigned short o; short s;}*) &pDevice)->o = *((WORD*)(pInitBuffer + INITBUF_MgaOffset));
|
|
((struct {unsigned short o; short s;}*) &pDevice)->s = *((WORD*)(pInitBuffer + INITBUF_MgaSegment));
|
|
|
|
#else
|
|
#ifdef WINDOWS_NT
|
|
|
|
pDevice = (BYTE *)(*((DWORD*)(pInitBuffer + INITBUF_MgaOffset)));
|
|
|
|
#else
|
|
|
|
#ifdef __MICROSOFTC600__
|
|
/*** DOS real-mode 32-bit address ***/
|
|
pDevice = *((DWORD*)(pInitBuffer + INITBUF_MgaOffset));
|
|
#else
|
|
/*** DOS protected-mode 48-bit address ***/
|
|
((struct {unsigned long o; short s;}*) &pDevice)->o = *((DWORD*)(pInitBuffer + INITBUF_MgaOffset));
|
|
((struct {unsigned long o; short s;}*) &pDevice)->s = *((WORD*)(pInitBuffer + INITBUF_MgaSegment));
|
|
#endif
|
|
|
|
#endif
|
|
#endif
|
|
|
|
/* value is true if PixelClk >= 90Mhz */
|
|
pixelClk90Mhz = *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)) >= 90000;
|
|
/*** ##### DUBIC PATCH Disable mouse IRQ and proceed ###### ***/
|
|
|
|
if ( (*((BYTE*)(pInitBuffer + INITBUF_DubicPresent))) ) /* Dubic Present */
|
|
{
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_NDX_PTR), 0x08);
|
|
mgaReadBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_DUB_SEL), DUB_SEL);
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_DUB_SEL), 0x00);
|
|
}
|
|
|
|
/*** ###################################################### ***/
|
|
|
|
/*** Get System Configuration ***/
|
|
|
|
GetMGAConfiguration(pDevice, &DST0, &DST1, &Info);
|
|
|
|
/*** Program the Titan CRTC_CTRL register ***/
|
|
|
|
mgaReadDWORD(*(pDevice + TITAN_OFFSET + TITAN_CRT_CTRL), TmpDword);
|
|
|
|
TmpDword &= ~((DWORD)TITAN_CRTCBPP_M |
|
|
(DWORD)TITAN_ALW_M |
|
|
(DWORD)TITAN_INTERLACE_M |
|
|
(DWORD)TITAN_VIDEODELAY0_M |
|
|
(DWORD)TITAN_VIDEODELAY1_M |
|
|
(DWORD)TITAN_VIDEODELAY2_M |
|
|
(DWORD)TITAN_VSCALE_M |
|
|
(DWORD)TITAN_SYNCDEL_M);
|
|
|
|
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pInitBuffer + INITBUF_PWidth))) << TITAN_CRTCBPP_A) & (DWORD)TITAN_CRTCBPP_M;
|
|
|
|
/* PACK PIXEL */
|
|
if( !(*((BYTE*)(pInitBuffer + INITBUF_PWidth)) == (BYTE)(TITAN_PWIDTH_PW24 >> TITAN_PWIDTH_A))/* NOT PACK PIXEL */ )
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_ALW))) << TITAN_ALW_A) & (DWORD)TITAN_ALW_M;
|
|
|
|
if (*((BYTE*)(pVideoBuffer + VIDEOBUF_Interlace)) == TRUE)
|
|
{
|
|
if (*((WORD*)(pInitBuffer + INITBUF_ScreenWidth)) <= (WORD)768)
|
|
{
|
|
TmpDword |= (DWORD)TITAN_INTERLACE_768;
|
|
}
|
|
else
|
|
{
|
|
if (*((WORD*)(pInitBuffer + INITBUF_ScreenWidth)) <= (WORD)1024)
|
|
{
|
|
TmpDword |= (DWORD)TITAN_INTERLACE_1024;
|
|
}
|
|
else
|
|
{
|
|
TmpDword |= (DWORD)TITAN_INTERLACE_1280;
|
|
}
|
|
}
|
|
}
|
|
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_VideoDelay))) << TITAN_VIDEODELAY0_A) & (DWORD)TITAN_VIDEODELAY0_M;
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_VideoDelay))) << (TITAN_VIDEODELAY1_A - 1)) & (DWORD)TITAN_VIDEODELAY1_M;
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_VideoDelay))) << (TITAN_VIDEODELAY2_A - 2)) & (DWORD)TITAN_VIDEODELAY2_M;
|
|
|
|
|
|
/* Programing Atlas VSCALE and SYNCDEL if NO DUBIC */
|
|
|
|
if ( !(*((BYTE*)(pInitBuffer + INITBUF_DubicPresent))) ) /* No Dubic */
|
|
{
|
|
|
|
/*********************************************************************/
|
|
if ( ((Info & (DWORD)Info_Dac_M) != (DWORD)Info_Dac_ViewPoint ) &&
|
|
(*((BYTE*)(pInitBuffer + INITBUF_ChipSet)) != 2/*ATHENA_CHIP*/)
|
|
)
|
|
{
|
|
/*------ hsync and vsync polarity extern implementation */
|
|
mgaReadBYTE(*(pDevice + TITAN_OFFSET + TITAN_CONFIG + 2), TmpByte);
|
|
TmpByte |= 1; /* Expansion device available <16> of CONFIG */
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_CONFIG + 2), TmpByte);
|
|
TmpByte = *(BYTE*)(pVideoBuffer + VIDEOBUF_VsyncPol);
|
|
TmpByte |= *(BYTE*)(pVideoBuffer + VIDEOBUF_HsyncPol) << 1;
|
|
mgaWriteBYTE(*(pDevice + EXPDEV_OFFSET), TmpByte );
|
|
}
|
|
/*********************************************************************/
|
|
|
|
/*** Set synch polarity for athena chipset ***/
|
|
/* MISC REGISTER
|
|
bit 7: 0 - Vsync positive
|
|
1 - Vsync negative
|
|
bit 6: 0 - Hsync positive
|
|
1 - Hsync negative
|
|
*/
|
|
if(*((BYTE*)(pInitBuffer + INITBUF_ChipSet)) == 2/*ATHENA_CHIP*/)
|
|
{
|
|
mgaReadBYTE(*(pDevice + TITAN_OFFSET + TITAN_MISC_OUT_R), TmpByte);
|
|
TmpByte &= 0x3f; /* Set bit <7:6> to 0 */
|
|
TmpByte |= *(BYTE*)(pVideoBuffer + VIDEOBUF_HsyncPol) << 6;
|
|
TmpByte |= *(BYTE*)(pVideoBuffer + VIDEOBUF_VsyncPol) << 7;
|
|
|
|
if (((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_TVP3026) ||
|
|
((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_ViewPoint)
|
|
)
|
|
TmpByte |= 0xc0; /* force <7:6> to negative polarity and
|
|
use DAC support for synch polarity */
|
|
else
|
|
TmpByte ^= 0xc0; /* reverse bit <7:6> */
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_MISC_OUT_W), TmpByte);
|
|
}
|
|
|
|
switch (Info & (DWORD)Info_Dac_M)
|
|
{
|
|
case (DWORD)Info_Dac_BT484:
|
|
case (DWORD)Info_Dac_BT485:
|
|
case (DWORD)Info_Dac_PX2085:
|
|
case (DWORD)Info_Dac_ATT2050:
|
|
switch ( *((BYTE*)(pVideoBuffer + VIDEOBUF_HsyncDelay)) )
|
|
{
|
|
default:
|
|
case 0:
|
|
TmpDword |= (((DWORD)0 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break;
|
|
|
|
case 3:
|
|
TmpDword |= (((DWORD)1 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break;
|
|
|
|
case 5:
|
|
TmpDword |= (((DWORD)2 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break;
|
|
|
|
case 8:
|
|
TmpDword |= (((DWORD)3 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break;
|
|
}
|
|
|
|
/* PACK PIXEL */
|
|
switch ( *((BYTE*)(pInitBuffer + INITBUF_PWidth)) & 0x3 )
|
|
{
|
|
case TITAN_CRTCBPP_8:
|
|
TmpDword |= (DWORD)0x01 << TITAN_VSCALE_A;
|
|
break; /* 0x1 = clock divide by 2 */
|
|
|
|
case TITAN_CRTCBPP_16:
|
|
TmpDword |= (((DWORD)0 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
TmpDword |= (DWORD)0x02 << TITAN_VSCALE_A;
|
|
break;
|
|
|
|
case TITAN_CRTCBPP_32:
|
|
TmpDword |= (((DWORD)0 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
TmpDword |= (DWORD)0x03 << TITAN_VSCALE_A;
|
|
break;
|
|
|
|
}
|
|
break;
|
|
|
|
|
|
case (DWORD)Info_Dac_ViewPoint:
|
|
case (DWORD)Info_Dac_TVP3026:
|
|
switch ( *((BYTE*)(pVideoBuffer + VIDEOBUF_HsyncDelay)) )
|
|
{
|
|
case 0:
|
|
case 1:
|
|
TmpDword |= (((DWORD)0 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break;
|
|
|
|
case 2:
|
|
case 3:
|
|
TmpDword |= (((DWORD)1 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break;
|
|
|
|
case 4:
|
|
case 5:
|
|
case 6:
|
|
TmpDword |= (((DWORD)2 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break;
|
|
|
|
case 7:
|
|
case 8:
|
|
default:
|
|
TmpDword |= (((DWORD)3 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break;
|
|
}
|
|
/* PACK PIXEL */
|
|
switch ( *((BYTE*)(pInitBuffer + INITBUF_PWidth)) & 0x3)
|
|
{ /* for PRO board (2 DUBIC) */
|
|
case TITAN_CRTCBPP_8:
|
|
TmpDword |= (((DWORD)0 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
break; /* VSCALE = 0 */
|
|
|
|
case TITAN_CRTCBPP_16:
|
|
TmpDword |= (((DWORD)0 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
TmpDword |= (DWORD)0x01 << TITAN_VSCALE_A;
|
|
break;
|
|
|
|
case TITAN_CRTCBPP_32:
|
|
TmpDword |= (((DWORD)0 << TITAN_SYNCDEL_A) & (DWORD)TITAN_SYNCDEL_M);
|
|
TmpDword |= (DWORD)0x02 << TITAN_VSCALE_A;
|
|
break;
|
|
}
|
|
break;
|
|
|
|
}
|
|
|
|
mgaWriteDWORD(*(pDevice + TITAN_OFFSET + TITAN_CRT_CTRL), TmpDword);
|
|
}
|
|
else /* ELSE NO DUBIC programming DUBIC */
|
|
{
|
|
mgaWriteDWORD(*(pDevice + TITAN_OFFSET + TITAN_CRT_CTRL), TmpDword);
|
|
|
|
|
|
|
|
|
|
/*** Program the Dubic DUB_CTL register ***/
|
|
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_NDX_PTR), DUBIC_DUB_CTL);
|
|
|
|
for (TmpDword = 0, ByteCount = 0; ByteCount <= 3; ByteCount++)
|
|
{
|
|
mgaReadBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_DATA), TmpByte);
|
|
TmpDword |= ((DWORD)TmpByte << ((DWORD)8 * ByteCount));
|
|
}
|
|
|
|
/** Do not program the LVID field, KEEP it for EXTERNAL APPLICATION
|
|
*** if bit 7 of LvidInitFlag is 1
|
|
**/
|
|
if (*((BYTE*)(pVideoBuffer + VIDEOBUF_LvidInitFlag)) & 0x80)
|
|
{
|
|
TmpDword &= ~((DWORD)DUBIC_IMOD_M | (DWORD)DUBIC_VSYNC_POL_M | (DWORD)DUBIC_HSYNC_POL_M |
|
|
(DWORD)DUBIC_DACTYPE_M | (DWORD)DUBIC_INT_EN_M | (DWORD)DUBIC_GENLOCK_M |
|
|
(DWORD)DUBIC_BLANK_SEL_M | (DWORD)DUBIC_SYNC_DEL_M | (DWORD)DUBIC_SRATE_M |
|
|
(DWORD)DUBIC_FBM_M | (DWORD)DUBIC_VGA_EN_M | (DWORD)DUBIC_BLANKDEL_M);
|
|
}
|
|
else /*** disable live video ***/
|
|
{
|
|
TmpDword &= ~((DWORD)DUBIC_IMOD_M | (DWORD)DUBIC_VSYNC_POL_M | (DWORD)DUBIC_HSYNC_POL_M |
|
|
(DWORD)DUBIC_DACTYPE_M | (DWORD)DUBIC_INT_EN_M | (DWORD)DUBIC_GENLOCK_M |
|
|
(DWORD)DUBIC_BLANK_SEL_M | (DWORD)DUBIC_SYNC_DEL_M | (DWORD)DUBIC_SRATE_M |
|
|
(DWORD)DUBIC_FBM_M | (DWORD)DUBIC_VGA_EN_M | (DWORD)DUBIC_BLANKDEL_M |
|
|
(DWORD)DUBIC_LVID_M);
|
|
}
|
|
|
|
TmpDword |= ((~((DWORD)(*((BYTE*)(pInitBuffer + INITBUF_PWidth))) + (DWORD)1)) << DUBIC_IMOD_A) & (DWORD)DUBIC_IMOD_M;
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_VsyncPol))) << DUBIC_VSYNC_POL_A) & (DWORD)DUBIC_VSYNC_POL_M;
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_HsyncPol))) << DUBIC_HSYNC_POL_A) & (DWORD)DUBIC_HSYNC_POL_M;
|
|
|
|
TmpDword |= (Info << DUBIC_DACTYPE_A) & (DWORD)DUBIC_DACTYPE_M;
|
|
|
|
if (*((BYTE*)(pVideoBuffer + VIDEOBUF_Interlace)) == TRUE)
|
|
{
|
|
TmpDword |= (DWORD)DUBIC_INT_EN_M;
|
|
}
|
|
|
|
/*** GenLock forced to 0 ***/
|
|
|
|
/*** vga_en forced to 0 ***/
|
|
|
|
/*** BlankSel forced to 0 (only one DAC) ***/
|
|
|
|
/*** Blankdel forced to 0 for mode TERMINATOR ***/
|
|
|
|
switch (Info & (DWORD)Info_Dac_M) /*** IMOD need to be set in TmpDword (DUB_CTL) ***/
|
|
{
|
|
case (DWORD)Info_Dac_ATT:
|
|
|
|
switch (TmpDword & (DWORD)DUBIC_IMOD_M)
|
|
{
|
|
case (DWORD)DUBIC_IMOD_32:
|
|
TmpDword |= (((DWORD)1 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
|
|
case (DWORD)DUBIC_IMOD_16:
|
|
TmpDword |= (((DWORD)8 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
|
|
case (DWORD)DUBIC_IMOD_8:
|
|
TmpDword |= (((DWORD)4 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
}
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_BT481:
|
|
case (DWORD)Info_Dac_BT482:
|
|
|
|
switch (TmpDword & (DWORD)DUBIC_IMOD_M)
|
|
{
|
|
case (DWORD)DUBIC_IMOD_32:
|
|
TmpDword |= (((DWORD)1 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
|
|
case (DWORD)DUBIC_IMOD_16:
|
|
TmpDword |= (((DWORD)8 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
|
|
case (DWORD)DUBIC_IMOD_8:
|
|
TmpDword |= (((DWORD)7 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
}
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_Sierra:
|
|
|
|
switch (TmpDword & (DWORD)DUBIC_IMOD_M)
|
|
{
|
|
case (DWORD)DUBIC_IMOD_32:
|
|
TmpDword |= (((DWORD)1 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
|
|
case (DWORD)DUBIC_IMOD_16:
|
|
TmpDword |= (((DWORD)12 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
|
|
case (DWORD)DUBIC_IMOD_8:
|
|
TmpDword |= (((DWORD)8 << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
}
|
|
break;
|
|
|
|
|
|
case (DWORD)Info_Dac_BT484:
|
|
case (DWORD)Info_Dac_BT485:
|
|
case (DWORD)Info_Dac_PX2085:
|
|
case (DWORD)Info_Dac_ATT2050:
|
|
|
|
/*** BEN note: Definir cette facon de faire pour les autres RAMDAC lorsque
|
|
ce sera calcule dans vidfile.c ... ***/
|
|
TmpDword |= ( ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_HsyncDelay))) << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
break;
|
|
|
|
|
|
case (DWORD)Info_Dac_Chameleon: /*** UNKNOWN ***/
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_TVP3026:
|
|
case (DWORD)Info_Dac_ViewPoint:
|
|
TmpDword |= ( ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_HsyncDelay))) << DUBIC_SYNC_DEL_A) & (DWORD)DUBIC_SYNC_DEL_M);
|
|
TmpDword |= (DWORD)DUBIC_BLANKDEL_M;
|
|
break;
|
|
}
|
|
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pInitBuffer + INITBUF_FBM))) << DUBIC_FBM_A) & (DWORD)DUBIC_FBM_M;
|
|
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_Srate))) << DUBIC_SRATE_A) & (DWORD)DUBIC_SRATE_M;
|
|
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_NDX_PTR), DUBIC_DUB_CTL);
|
|
|
|
for (ByteCount = 0; ByteCount <= 3; ByteCount++)
|
|
{
|
|
TmpByte = (BYTE)(TmpDword >> ((DWORD)8 * ByteCount));
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_DATA), TmpByte);
|
|
}
|
|
|
|
/*** Program the Dubic DUB_CTL2 register ***/
|
|
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_NDX_PTR), DUBIC_DUB_CTL2);
|
|
|
|
for (TmpDword = 0, ByteCount = 0; ByteCount <= 3; ByteCount++)
|
|
{
|
|
mgaReadBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_DATA), TmpByte);
|
|
TmpDword |= ((DWORD)TmpByte << ((DWORD)8 * ByteCount));
|
|
}
|
|
|
|
|
|
/*** !!!??? This comment is not valid since we set LVIDFIELD just after that ***/
|
|
/** Do not program the LVIDFIELD field, KEEP it for EXTERNAL APPLICATION
|
|
*** if bit 7 of LvidInitFlag is 1
|
|
**/
|
|
|
|
if (*((BYTE*)(pVideoBuffer + VIDEOBUF_LvidInitFlag)) & 0x80)
|
|
{
|
|
TmpDword &= ~((DWORD)DUBIC_SYNCEN_M | (DWORD)DUBIC_LASERSCL_M |
|
|
(DWORD)DUBIC_CLKSEL_M | (DWORD)DUBIC_LDCLKEN_M);
|
|
}
|
|
else /*** Disable live video ***/
|
|
{
|
|
TmpDword &= ~((DWORD)DUBIC_SYNCEN_M | (DWORD)DUBIC_LASERSCL_M | (DWORD)DUBIC_LVIDFIELD_M |
|
|
(DWORD)DUBIC_CLKSEL_M | (DWORD)DUBIC_LDCLKEN_M);
|
|
}
|
|
|
|
|
|
/** Because we lost the cursor in interlace mode , we have to program **/
|
|
/** LVIDFIELD to 1 **/
|
|
|
|
if (*((BYTE*)(pVideoBuffer + VIDEOBUF_Interlace)) == TRUE)
|
|
TmpDword |= (DWORD)DUBIC_LVIDFIELD_M;
|
|
else
|
|
TmpDword &= ~((DWORD)DUBIC_LVIDFIELD_M);
|
|
|
|
|
|
|
|
TmpDword |= ((DWORD)(*((BYTE*)(pVideoBuffer + VIDEOBUF_LaserScl))) << DUBIC_LASERSCL_A) & (DWORD)DUBIC_LASERSCL_M;
|
|
|
|
TmpDword |= (DWORD)DUBIC_SYNCEN_M; /*** sync forced to enable ***/
|
|
|
|
/*** CLOCKSEL forced to 0 except for viewpoint ***/
|
|
|
|
if (
|
|
((Info & (DWORD)Info_Dac_M) == Info_Dac_ViewPoint) ||
|
|
((Info & (DWORD)Info_Dac_M) == Info_Dac_TVP3026)
|
|
)
|
|
TmpDword |= (DWORD)DUBIC_CLKSEL_M;
|
|
|
|
/* Special case for BT485: LDCLKEN must be set to 1 only in VGA mode */
|
|
/* and in 24-bit mode */
|
|
if( ((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_BT485) ||
|
|
((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_PX2085) ||
|
|
((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_ATT2050)
|
|
)
|
|
{
|
|
if( *((BYTE*)(pInitBuffer + INITBUF_PWidth)) == (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A) )
|
|
TmpDword |= (DWORD)DUBIC_LDCLKEN_M; /*** ldclkl running ***/
|
|
}
|
|
else
|
|
TmpDword |= (DWORD)DUBIC_LDCLKEN_M; /*** ldclkl running ***/
|
|
|
|
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_NDX_PTR), DUBIC_DUB_CTL2);
|
|
|
|
for (ByteCount = 0; ByteCount <= 3; ByteCount++)
|
|
{
|
|
TmpByte = (BYTE)(TmpDword >> ((DWORD)8 * ByteCount));
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_DATA), TmpByte);
|
|
}
|
|
|
|
/*** Program the Dubic OVS_COL register ***/
|
|
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_NDX_PTR), DUBIC_OVS_COL);
|
|
|
|
TmpDword = *((DWORD*)(pVideoBuffer + VIDEOBUF_OvsColor));
|
|
|
|
for (ByteCount = 0; ByteCount <= 3; ByteCount++)
|
|
{
|
|
TmpByte = (BYTE)(TmpDword >> ((DWORD)8 * ByteCount));
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_DATA), TmpByte);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
/*** Program the RAMDAC ***/
|
|
|
|
switch (Info & (DWORD)Info_Dac_M)
|
|
{
|
|
case (DWORD)Info_Dac_ATT: /*** UNKNOWN ***/
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_BT481: /*** UNKNOWN ***/
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_BT482:
|
|
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
TmpByte = 0x01;
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_565Mode)) )
|
|
TmpByte = 0xe1;
|
|
else
|
|
TmpByte = 0xa1;
|
|
break;
|
|
}
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT482_CMD_REGA), TmpByte);
|
|
|
|
/*** Read Mask (INDIRECT) ***/
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT482_WADR_PAL), 0x00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT482_PIX_RD_MSK), 0xff);
|
|
|
|
/*** Command Register B (INDIRECT) ***/
|
|
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Pedestal)) & (BYTE)0x1) << 5) | (BYTE)0x02;
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT482_WADR_PAL), 0x02);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT482_PIX_RD_MSK), TmpByte);
|
|
|
|
/*** Cursor Register (INDIRECT) ***/
|
|
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Interlace)) & (BYTE)0x1) << 4) | (BYTE)0x04;
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT482_WADR_PAL), 0x03);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT482_PIX_RD_MSK), TmpByte);
|
|
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_Sierra: /*** UNKNOWN ***/
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_BT484:
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT484_PIX_RD_MSK), 0xff);
|
|
/* Overlay must me 0 */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT484_WADR_OVL), 0x00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT484_COL_OVL), 0x00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT484_COL_OVL), 0x00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT484_COL_OVL), 0x00);
|
|
/** BEN 0x1e */
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Pedestal)) & (BYTE)0x1) << 5) | (BYTE)0x02;
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT484_CMD_REG0), TmpByte);
|
|
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
TmpByte = 0x40;
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_565Mode)) )
|
|
TmpByte = 0x28;
|
|
else
|
|
TmpByte = 0x20;
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
TmpByte = 0x00;
|
|
break;
|
|
}
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT484_CMD_REG1), TmpByte);
|
|
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Interlace)) & (BYTE)0x1) << 3) | (BYTE)0x24;
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT484_CMD_REG2), TmpByte);
|
|
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_BT485:
|
|
case (DWORD)Info_Dac_PX2085:
|
|
case (DWORD)Info_Dac_ATT2050:
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_PIX_RD_MSK), 0xff);
|
|
/** BEN 0x9e */
|
|
/* OverScan must me 0 */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_WADR_OVL), 0x00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_COL_OVL), 0x00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_COL_OVL), 0x00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_COL_OVL), 0x00);
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Pedestal)) & (BYTE)0x1) << 5) | (BYTE)0x82;
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_CMD_REG0), TmpByte);
|
|
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
TmpByte = 0x40;
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_565Mode)) )
|
|
TmpByte = 0x28;
|
|
else
|
|
TmpByte = 0x20;
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
TmpByte = 0x00;
|
|
break;
|
|
}
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_CMD_REG1), TmpByte);
|
|
|
|
|
|
if( ((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_BT485) ||
|
|
((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_ATT2050)
|
|
)
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Interlace)) & (BYTE)0x1) << 3) | (BYTE)0x24;
|
|
else /* PX2085 */
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Interlace)) & (BYTE)0x1) << 3) | (BYTE)0x44;
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_CMD_REG2), TmpByte);
|
|
|
|
|
|
/*** Indirect addressing from STATUS REGISTER ***/
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_WADR_PAL), 0x01);
|
|
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
if ( ((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_PX2085) ||
|
|
((Info & (DWORD)Info_Dac_M) == (DWORD)Info_Dac_BT485) ||
|
|
pixelClk90Mhz /* pclk >= 90Mhz */
|
|
)
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_CMD_REG3), 0x08);
|
|
else
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_CMD_REG3), 0x00);
|
|
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + BT485_CMD_REG3), 0x00);
|
|
break;
|
|
}
|
|
break;
|
|
|
|
|
|
case (DWORD)Info_Dac_Chameleon: /*** UNKNOWN ***/
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_ViewPoint:
|
|
|
|
/* Software reset to put the DAC in a default state */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_RESET);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x00 );
|
|
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_PIX_RD_MSK), 0xff);
|
|
|
|
/* OverScan must me 0 */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_OVS_RED);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x00 );
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_OVS_GREEN);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x00 );
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_OVS_BLUE);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x00 );
|
|
|
|
/* Misc. Control Register */
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Pedestal)) & (BYTE)0x1) << 4);
|
|
|
|
/*** (94/02/07) BEN modif to program sync polarity in VIEWPOINT ***/
|
|
/*** (94/04/11) Christian: doesn't apply for ATHENA ***/
|
|
/* if ( ! (*((BYTE*)(pInitBuffer + INITBUF_DubicPresent))) && */
|
|
/* (*((BYTE*)(pInitBuffer + INITBUF_ChipSet)) != 2) */ /*ATHENA_CHIP*/
|
|
/* ) */
|
|
if ( ! (*((BYTE*)(pInitBuffer + INITBUF_DubicPresent))))
|
|
{
|
|
TmpByte &= 0xfc; /* Set bit 0,1 to 0 */
|
|
TmpByte |= *(BYTE*)(pVideoBuffer + VIDEOBUF_HsyncPol);
|
|
TmpByte |= *(BYTE*)(pVideoBuffer + VIDEOBUF_VsyncPol) << 1;
|
|
}
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_GEN_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), TmpByte);
|
|
|
|
/* Multiplex Control Register (True Color 24 bit) */
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_MUX_CTL1);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x80 );
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_MUX_CTL2);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x1c );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_565Mode)) )
|
|
{
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_MUX_CTL1);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x45 ); /* XGA */
|
|
}
|
|
else
|
|
{
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_MUX_CTL1);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x44 ); /* Targa */
|
|
}
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_MUX_CTL2);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x04 );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_MUX_CTL1);
|
|
|
|
#if !(MACRO_ECHO)
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_ChipSet)) == 1) /* ATLAS */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x46 );
|
|
else
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x46 );
|
|
#else
|
|
/*
|
|
* Redundant if-else causes massive compilation error in macro
|
|
* debug echo mode.
|
|
*/
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x46 );
|
|
#endif
|
|
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_MUX_CTL2);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x04 );
|
|
break;
|
|
}
|
|
|
|
|
|
/* Input Clock Select Register (Select CLK1 as doubled clock source */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_INPUT_CLK);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x11 );
|
|
|
|
/* Output Clock Selection Register Bits
|
|
VCLK/2 output ratio (xx001xxx)
|
|
RCLK/2 output ratio (xxxxx001)
|
|
*/
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_OUTPUT_CLK);
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x5b );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x52 );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x49 );
|
|
break;
|
|
}
|
|
|
|
if ( ! (*((BYTE*)(pInitBuffer + INITBUF_DubicPresent))) )
|
|
{
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_GEN_IO_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x03 );
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_GEN_IO_DATA);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x01 );
|
|
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_AUX_CTL);
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x09 );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x08 );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x08 );
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_INDEX), VPOINT_KEY_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + VPOINT_DATA), (BYTE)0x10 );
|
|
|
|
|
|
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_TVP3026:
|
|
|
|
/* Software reset to put the DAC in a default state */
|
|
res = *((WORD*)(pInitBuffer + INITBUF_ScreenWidth));
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_PIX_RD_MSK), 0xff);
|
|
|
|
/* FIX AVEC GAL DAT No GEN014 */
|
|
/* general purpose I/O tell to the gal the vertical resolution */
|
|
/* if vertical resolution is >= 1024, the count is by increment
|
|
/* of two */
|
|
|
|
if ( res < 1280)
|
|
{
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_GEN_IO_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x00 );
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_GEN_IO_DATA);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x01 );
|
|
}
|
|
else
|
|
{
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_GEN_IO_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x01 );
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_GEN_IO_DATA);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x00 );
|
|
}
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_MISC_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x0c);
|
|
|
|
|
|
/* init Interlace Cursor support */
|
|
/* NOTE: We set the vertival detect method bit to 1 to be in synch
|
|
with NPI diag code. Whith some video parameters, the cursor
|
|
disaper if we put this bit a 0.
|
|
*/
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_CURSOR_CTL);
|
|
mgaReadBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), TmpByte);
|
|
/* Set interlace bit */
|
|
TmpByte &= ~(BYTE)(1 << 5);
|
|
TmpByte |= (((*((BYTE*)(pVideoBuffer + VIDEOBUF_Interlace)) & (BYTE)0x1)) << 5);
|
|
/* Set vertival detect method */
|
|
TmpByte |= 0x10;
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), TmpByte);
|
|
|
|
|
|
|
|
/* OverScan must me 0 */
|
|
/* Overscan is not enabled in general ctl register */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_CUR_COL_ADDR), 00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_CUR_COL_DATA), 00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_CUR_COL_DATA), 00);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_CUR_COL_DATA), 00);
|
|
/* Put to ZERO */
|
|
|
|
/* Misc. Control Register */
|
|
TmpByte = ((*((BYTE*)(pVideoBuffer + VIDEOBUF_Pedestal)) & (BYTE)0x1) << 4);
|
|
|
|
/* For the TVP3026, we use DAC capability for sync polarity */
|
|
if (! (*((BYTE*)(pInitBuffer + INITBUF_DubicPresent))) )
|
|
{
|
|
TmpByte &= 0xfc; /* Set bit 0,1 to 0 */
|
|
TmpByte |= *(BYTE*)(pVideoBuffer + VIDEOBUF_HsyncPol);
|
|
TmpByte |= *(BYTE*)(pVideoBuffer + VIDEOBUF_VsyncPol) << 1;
|
|
}
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_GEN_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), TmpByte);
|
|
|
|
/* Multiplex Control Register (True Color 24 bit) */
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_CLK_SEL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0xb5 );
|
|
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_TRUE_COLOR_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0xa0 );
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_MUX_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x4c );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_CLK_SEL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0xa5 );
|
|
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_565Mode)) )
|
|
{
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_TRUE_COLOR_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x65 );
|
|
}
|
|
else
|
|
{
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_TRUE_COLOR_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x64 );
|
|
}
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_MUX_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x54 );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_CLK_SEL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x95 );
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_TRUE_COLOR_CTL);
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_ChipSet)) == 1) /* ATLAS */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x66 );
|
|
else
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x66 );
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_MUX_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x5c );
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW24 >> TITAN_PWIDTH_A):
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_CLK_SEL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x95 );
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_TRUE_COLOR_CTL);
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_ChipSet)) == 1) /* ATLAS */
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x76 );
|
|
else
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x76 );
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_MUX_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), (BYTE)0x5c );
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_LATCH_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), 4 );
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_DB_FrontBack)) )
|
|
{
|
|
/** Enable double buffer feature of the TVP3026 and set DAC mask **/
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_TRUE_COLOR_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), 0xA0);
|
|
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_MUX_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), 0x54);
|
|
|
|
/*** Always display buffer A ***/
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_INDEX), TVP3026_LATCH_CTL);
|
|
mgaWriteBYTE(*(pDevice + RAMDAC_OFFSET + TVP3026_DATA), 0x86);
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
/*** Program the LUT in the DAC (the LUT is internal to the function) ***/
|
|
/*** Done only if flag LUTMode is FALSE ***/
|
|
|
|
if ( ! (*((BYTE*)(pInitBuffer + INITBUF_LUTMode))) )
|
|
{
|
|
if ( *((BYTE*)(pInitBuffer + INITBUF_565Mode)) )
|
|
SetMGALUT(pDevice, (BYTE*)0, *((BYTE*)(pInitBuffer + INITBUF_PWidth)), 0x08);
|
|
else if ( *((BYTE*)(pInitBuffer + INITBUF_DB_FrontBack)) )
|
|
SetMGALUT(pDevice, (BYTE*)0, *((BYTE*)(pInitBuffer + INITBUF_PWidth)), 0x10);
|
|
else
|
|
SetMGALUT(pDevice, (BYTE*)0, *((BYTE*)(pInitBuffer + INITBUF_PWidth)), 0);
|
|
}
|
|
|
|
|
|
/*** Program the CLOCK GENERATOR ***/
|
|
|
|
switch (Info & (DWORD)Info_Dac_M)
|
|
{
|
|
case (DWORD)Info_Dac_BT482:
|
|
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)), 2);
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)) << 1, 2);
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)) << 1, 2);
|
|
break;
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case (DWORD)Info_Dac_BT485:
|
|
case (DWORD)Info_Dac_PX2085:
|
|
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)) >> 1, 2);
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)) >> 1, 2);
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)), 2);
|
|
break;
|
|
}
|
|
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_ATT2050:
|
|
|
|
switch (*((BYTE*)(pInitBuffer + INITBUF_PWidth)))
|
|
{
|
|
case (BYTE)(TITAN_PWIDTH_PW8 >> TITAN_PWIDTH_A):
|
|
case (BYTE)(TITAN_PWIDTH_PW16 >> TITAN_PWIDTH_A):
|
|
if (pixelClk90Mhz) /* pclk >= 90Mhz */
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)) >> 1, 2);
|
|
else
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)), 2);
|
|
|
|
break;
|
|
|
|
case (BYTE)(TITAN_PWIDTH_PW32 >> TITAN_PWIDTH_A):
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)), 2);
|
|
break;
|
|
}
|
|
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_ViewPoint:
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)) >> 1, 2);
|
|
break;
|
|
|
|
case (DWORD)Info_Dac_TVP3026:
|
|
setTVP3026Freq(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)), 2, *((BYTE*)(pInitBuffer + INITBUF_PWidth)));
|
|
/*** BEN we call it twice because of a bug with setup program for windows at
|
|
1152x882x24 ***/
|
|
setTVP3026Freq(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)), 2, *((BYTE*)(pInitBuffer + INITBUF_PWidth)));
|
|
break;
|
|
|
|
default:
|
|
|
|
setFrequence(pDevice, *((DWORD*)(pVideoBuffer + VIDEOBUF_PCLK)), 2);
|
|
break;
|
|
}
|
|
|
|
|
|
/*** Program the CRTC ***/
|
|
|
|
/*** Select access on 0x3d4 and 0x3d5 ***/
|
|
|
|
mgaReadBYTE(*(pDevice + TITAN_OFFSET + TITAN_MISC_OUT_R), TmpByte);
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_MISC_OUT_W), (TmpByte | (BYTE)0x01));
|
|
|
|
/*** Unprotect registers 0-7 ***/
|
|
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_1_CRTC_ADDR), 0x11);
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_1_CRTC_DATA), 0x40);
|
|
|
|
for (RegisterCount = 0; RegisterCount <= 24; RegisterCount++)
|
|
{
|
|
TmpByte = *((BYTE*)(pVideoBuffer + VIDEOBUF_CRTC + RegisterCount));
|
|
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_1_CRTC_ADDR), (unsigned char)RegisterCount);
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_1_CRTC_DATA), TmpByte);
|
|
}
|
|
|
|
/*** Get extended address register ***/
|
|
|
|
RegisterCount = (DWORD)26;
|
|
TmpByte = *((BYTE*)(pVideoBuffer + VIDEOBUF_CRTC + RegisterCount));
|
|
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_AUX_ADDR), 0x0A);
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_AUX_DATA), TmpByte);
|
|
|
|
RegisterCount = (DWORD)28;
|
|
TmpByte = *((BYTE*)(pVideoBuffer + VIDEOBUF_CRTC + RegisterCount));
|
|
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_AUX_ADDR), 0x0D);
|
|
mgaWriteBYTE(*(pDevice + TITAN_OFFSET + TITAN_AUX_DATA), TmpByte);
|
|
|
|
/*** Get interlace support register ***/
|
|
|
|
|
|
|
|
|
|
/*** ##### DUBIC PATCH ReEnable mouse IRQ ################# ***/
|
|
if ( (*((BYTE*)(pInitBuffer + INITBUF_DubicPresent))) ) /* Dubic Present */
|
|
{
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_NDX_PTR), 0x08);
|
|
mgaWriteBYTE(*(pDevice + DUBIC_OFFSET + DUBIC_DUB_SEL), DUB_SEL);
|
|
}
|
|
|
|
/*** ###################################################### ***/
|
|
}
|
|
|
|
|
|
|