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.
665 lines
24 KiB
665 lines
24 KiB
/************************************************************************/
|
|
/* */
|
|
/* CVTVGA.C */
|
|
/* */
|
|
/* Copyright (c) 1992, ATI Technologies Incorporated. */
|
|
/************************************************************************/
|
|
|
|
/********************** PolyTron RCS Utilities
|
|
|
|
$Revision: 1.9 $
|
|
$Date: 20 Jul 1995 17:53:30 $
|
|
$Author: mgrubac $
|
|
$Log: S:/source/wnt/ms11/miniport/vcs/cvtvga.c $
|
|
*
|
|
* Rev 1.9 20 Jul 1995 17:53:30 mgrubac
|
|
* Added support for VDIF files
|
|
*
|
|
* Rev 1.8 10 Apr 1995 15:55:26 RWOLFF
|
|
* Updated 640x480 72Hz mode table from version 1.2 to version 1.5 of the
|
|
* Programmer's Guide to the Mach 32 Registers, added routine to replace
|
|
* BookValues[] entries where the Mach 64 needs CRT parameters the Mach 8
|
|
* and Mach 32 can't handle (currently, only 640x480 72Hz falls into
|
|
* this category).
|
|
*
|
|
* Rev 1.7 23 Dec 1994 10:47:58 ASHANMUG
|
|
* ALPHA/Chrontel-DAC
|
|
*
|
|
* Rev 1.6 18 Nov 1994 11:39:04 RWOLFF
|
|
* Added comments with function name at the end of each function.
|
|
*
|
|
* Rev 1.5 31 Aug 1994 16:22:42 RWOLFF
|
|
* Added support for 1152x864 and 1600x1200 "canned" mode tables.
|
|
*
|
|
* Rev 1.4 19 Aug 1994 17:09:52 RWOLFF
|
|
* Added support for non-standard pixel clock generators.
|
|
*
|
|
* Rev 1.3 18 May 1994 17:02:58 RWOLFF
|
|
* Interlaced mode tables now report frame rate rather than vertical
|
|
* scan frequency in the refresh rate field.
|
|
*
|
|
* Rev 1.2 12 May 1994 11:13:04 RWOLFF
|
|
* Added refresh rate to entries in BookValues[], re-ordered BookValues[]
|
|
* to allow a single range of indices to cover all desired refresh rates at
|
|
* a given resolution even when the highest nonitnerlaced refresh rates
|
|
* are ignored.
|
|
*
|
|
* Rev 1.1 07 Feb 1994 14:06:06 RWOLFF
|
|
* Added alloc_text() pragmas to allow miniport to be swapped out when
|
|
* not needed.
|
|
*
|
|
* Rev 1.0 31 Jan 1994 11:05:14 RWOLFF
|
|
* Initial revision.
|
|
|
|
Rev 1.4 30 Nov 1993 18:15:02 RWOLFF
|
|
Corrected clock select value for 1280x1024 60Hz noninterlaced.
|
|
|
|
Rev 1.3 08 Oct 1993 15:17:56 RWOLFF
|
|
No longer includes VIDFIND.H
|
|
|
|
Rev 1.2 08 Oct 1993 11:05:14 RWOLFF
|
|
Removed unused "fall back to 56Hz" function for 800x600.
|
|
|
|
Rev 1.1 03 Sep 1993 14:21:52 RWOLFF
|
|
Partway through CX isolation.
|
|
|
|
Rev 1.0 16 Aug 1993 13:22:04 Robert_Wolff
|
|
Initial revision.
|
|
|
|
Rev 1.12 30 Apr 1993 16:39:18 RWOLFF
|
|
640x480 8BPP now stable on 512k Graphics Vantage. Fix is not yet final -
|
|
old code is present but commented out, will remove when fix is final.
|
|
|
|
Rev 1.11 21 Apr 1993 17:17:16 RWOLFF
|
|
Now uses AMACH.H instead of 68800.H/68801.H.
|
|
|
|
Rev 1.10 30 Mar 1993 17:10:28 RWOLFF
|
|
Added 1280x1024 60Hz noninterlaced to resolutions which can be selected
|
|
by BookVgaTable().
|
|
|
|
Rev 1.9 25 Mar 1993 11:12:34 RWOLFF
|
|
Brought comment block in function header into sync with actual code.
|
|
|
|
Rev 1.8 08 Mar 1993 19:28:28 BRADES
|
|
submit to MS NT
|
|
|
|
Rev 1.6 06 Jan 1993 10:57:56 Robert_Wolff
|
|
Added type casts to eliminate compile warnings.
|
|
|
|
Rev 1.5 02 Dec 1992 17:28:58 Robert_Wolff
|
|
Added function FallBack800to56(), which replaces those parameters
|
|
of an 800x600 mode table with the values used by the 56Hz vertical
|
|
frequency mode in Programmer's Guide to the Mach 32 Registers.
|
|
|
|
Rev 1.4 27 Nov 1992 15:18:30 STEPHEN
|
|
No change.
|
|
|
|
Rev 1.3 17 Nov 1992 17:21:02 Robert_Wolff
|
|
Now uses parameters from Appendix D of the Programmer's Guide to
|
|
the Mach 32 Registers rather than values from the EEPROM if the
|
|
CRTC_USAGE bit is clear (clear = use sync polarities only, will
|
|
be clear if card is configured for a predefined monitor rather
|
|
than having CRT parameters written to the EEPROM), fixed calculation
|
|
of parameters for Mach 8 in 800x600 at 60, 70, and 72 Hz noninterlaced
|
|
(other frequencies at 800x600, other resolutions on Mach 8, and all
|
|
resolutions on Mach 32 didn't have this problem).
|
|
|
|
Rev 1.2 13 Nov 1992 17:09:44 Robert_Wolff
|
|
Now includes 68801.H, which consists of the now-obsolete MACH8.H
|
|
and elements moved from VIDFIND.H.
|
|
|
|
Rev 1.1 12 Nov 1992 16:39:38 Robert_Wolff
|
|
Merged source trees for Windows NT driver and VIDEO.EXE test program
|
|
(same source file can be used for both). XlateVgaTable() now takes
|
|
an extra parameter to determine whether to handle data for Mach32
|
|
or Mach8 cards, rather than using the global variable classMACH32.
|
|
|
|
Rev 1.0 05 Nov 1992 13:59:56 Robert_Wolff
|
|
Initial revision.
|
|
|
|
Rev 1.1 09 Oct 1992 15:03:28 Robert_Wolff
|
|
Now assigns values for DISP_CNTL, CLOCK_SEL, VFIFO_16, and VFIFO_24.
|
|
|
|
Rev 1.0 01 Oct 1992 15:31:42 Robert_Wolff
|
|
Initial revision.
|
|
|
|
|
|
End of PolyTron RCS section *****************/
|
|
|
|
#ifdef DOC
|
|
CVTVGA.C - Functions to convert CRT parameter table from VGA
|
|
to 8514 format.
|
|
|
|
#endif
|
|
|
|
#include "miniport.h"
|
|
|
|
#include "ntddvdeo.h"
|
|
#include "video.h"
|
|
|
|
#include "stdtyp.h"
|
|
|
|
#define INCLUDE_CVTVGA
|
|
#include "amach.h"
|
|
#include "amach1.h"
|
|
#include "cvtvga.h"
|
|
#include "atimp.h"
|
|
#include "services.h"
|
|
|
|
/*
|
|
* Arrays of VGA parameter tables used in translating from
|
|
* VGA format to 8514 format. Currently the 800x600 noninterlaced
|
|
* entries have different values for the Mach8 and Mach32
|
|
* engines (Mach 8 is the "else" case with the comment
|
|
* "TESTING ONLY" for 56Hz). Assume that the VFIFO_DEPTH
|
|
* field is 8 entries.
|
|
*/
|
|
static struct st_vga_data VgaParmTable_M32[10] =
|
|
{
|
|
{0x050, 0x000, 0x04F, 0x0DF, 0x0E3, 0x0800, 0x023, 32000000L}, /* Mode 12, VGAP$PS2.ASM */
|
|
{0x064, 0x000, 0x063, 0x057, 0x0E3, 0x0800, 0x023, 36000000L}, /* m800_36m, VGAP$68A.MAC */
|
|
{0x064, 0x000, 0x063, 0x057, 0x0E3, 0x0800, 0x023, 40000000L}, /* m800_40mphip, VGAP$68A.MAC */
|
|
{0x064, 0x000, 0x063, 0x057, 0x0E3, 0x0800, 0x023, 44900000L}, /* m800_45m, VGAP$68A.MAC */
|
|
{0x064, 0x000, 0x063, 0x057, 0x0E3, 0x0800, 0x023, 50350000L}, /* m800_50mvesa, VGAP$68A.MAC */
|
|
{0x064, 0x0C0, 0x063, 0x057, 0x0E3, 0x0800, 0x033, 32500000L}, /* m800_36m8514, VGAP$68A.MAC */
|
|
{0x080, 0x000, 0x07F, 0x0FF, 0x0E3, 0x0800, 0x023, 65000000L}, /* m1024_65m, VGAP$68A.MAC */
|
|
{0x080, 0x000, 0x07F, 0x0FF, 0x0E3, 0x0800, 0x023, 75000000L}, /* m1024_75mvesa, VGAP$68A.MAC */
|
|
{0x080, 0x000, 0x07F, 0x0FF, 0x0E3, 0x0800, 0x023, 75000000L}, /* m1024_75m72Hz, VGAP$68A.MAC */
|
|
{0x080, 0x0C0, 0x07F, 0x0FF, 0x0E3, 0x0800, 0x033, 44900000L} /* m1024_45m, VGAP$68A.MAC */
|
|
};
|
|
|
|
static struct st_vga_data VgaParmTable_M8[10] =
|
|
{
|
|
{0x050, 0x000, 0x04F, 0x0DF, 0x0E3, 0x0800, 0x023, 32000000L}, /* Mode 12, VGAP$PS2.ASM */
|
|
{0x064, 0x000, 0x063, 0x02B, 0x0E7, 0x0800, 0x023, 36000000L}, /* m800_36m, VGAP$68A.MAC */
|
|
{0x064, 0x000, 0x063, 0x02B, 0x0E7, 0x0800, 0x023, 40000000L}, /* m800_40mphip, VGAP$68A.MAC */
|
|
{0x064, 0x000, 0x063, 0x02B, 0x0E7, 0x0800, 0x023, 44900000L}, /* m800_45m, VGAP$68A.MAC */
|
|
{0x064, 0x000, 0x063, 0x02B, 0x0E7, 0x0800, 0x023, 50350000L}, /* m800_50mvesa, VGAP$68A.MAC */
|
|
{0x064, 0x0C0, 0x063, 0x057, 0x0E3, 0x0800, 0x033, 32500000L}, /* m800_36m8514, VGAP$68A.MAC */
|
|
{0x080, 0x000, 0x07F, 0x0FF, 0x0E3, 0x0800, 0x023, 65000000L}, /* m1024_65m, VGAP$68A.MAC */
|
|
{0x080, 0x000, 0x07F, 0x0FF, 0x0E3, 0x0800, 0x023, 75000000L}, /* m1024_75mvesa, VGAP$68A.MAC */
|
|
{0x080, 0x000, 0x07F, 0x0FF, 0x0E3, 0x0800, 0x023, 75000000L}, /* m1024_75m72Hz, VGAP$68A.MAC */
|
|
{0x080, 0x0C0, 0x07F, 0x0FF, 0x0E3, 0x0800, 0x033, 44900000L} /* m1024_45m, VGAP$68A.MAC */
|
|
};
|
|
|
|
/*
|
|
* Pointer to currently-used VGA parameter table
|
|
*/
|
|
static struct st_vga_data *VgaParmTable;
|
|
|
|
|
|
/*
|
|
* Some of the processing of vertical values is handled differently
|
|
* on non-Mach32 cards with 512k of video memory. The routine which
|
|
* behaves differently based on whether or not we have an older card
|
|
* with 512k is called several times, so setting this flag in a higher-
|
|
* level routine will reduce the number of tests required.
|
|
*/
|
|
static BOOL HalfMeg;
|
|
|
|
|
|
static void GetVertOverflow(unsigned char *Value);
|
|
static unsigned short Gen8514V(union SplitWord INPut, short VgaTblEntry);
|
|
|
|
|
|
/*
|
|
* Allow miniport to be swapped out when not needed.
|
|
*/
|
|
#if defined (ALLOC_PRAGMA)
|
|
#pragma alloc_text(PAGE_M, GetVertOverflow)
|
|
#pragma alloc_text(PAGE_M, Gen8514V)
|
|
#pragma alloc_text(PAGE_M, XlateVgaTable)
|
|
#pragma alloc_text(PAGE_M, BookVgaTable)
|
|
#endif
|
|
|
|
|
|
/****************************************************************
|
|
* GetVertOverflow
|
|
*
|
|
* Gets the overflow (2 most significant bits) of a vertical
|
|
* value. On entry, Value will point to a copy of the CRT07
|
|
* register which has been shifted so that bit 8 of the desired
|
|
* value is in bit 0 of *Value, and bit 9 of the desired value
|
|
* is in bit 5 of *Value. On exit, bits 8 and 9 will be in bits
|
|
* 0 and 1 respectively of *Value.
|
|
*
|
|
* INPUT: Value = ptr to raw overflow value
|
|
*
|
|
* RETURN: Value = ptr to processed overflow value
|
|
*
|
|
****************************************************************/
|
|
static void GetVertOverflow(unsigned char *Value)
|
|
{
|
|
unsigned char Scratch; /* Scratchpad variable */
|
|
|
|
Scratch = (*Value >> 4) & 0x02;
|
|
*Value = (*Value & 0x01) | Scratch;
|
|
return;
|
|
|
|
} /* GetVertOverflow() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
* Gen8514V
|
|
*
|
|
* Another stage in the processing of a vertical value. This is
|
|
* taken directly from gen8514v in COMBO$01.ASM.
|
|
*
|
|
* INPUT: INPut = value before processing
|
|
* VgaTblEntry = which set of VGA parameters corresponds
|
|
* to the desired mode
|
|
*
|
|
* RETURN: processed value
|
|
*
|
|
****************************************************************/
|
|
static unsigned short Gen8514V(union SplitWord INPut, short VgaTblEntry)
|
|
{
|
|
union SplitWord Scratch; /* Scratchpad variable */
|
|
|
|
if(VgaParmTable[VgaTblEntry].Mode & WORD_MODE)
|
|
INPut.word <<= 1;
|
|
|
|
INPut.word -= 1;
|
|
Scratch.word = INPut.word;
|
|
Scratch.word <<= 1;
|
|
|
|
// 512k handling not yet final. 640x480 is stable with wrong colours
|
|
// with special case commented out, don't want to delete code until
|
|
// changes are final.
|
|
//
|
|
// if (HalfMeg)
|
|
// {
|
|
// Scratch.word <<= 1;
|
|
// INPut.byte.low &= 0x01;
|
|
// }
|
|
// else{
|
|
INPut.byte.low &= 0x03;
|
|
// }
|
|
|
|
Scratch.byte.low &= 0x0F8;
|
|
INPut.byte.high = Scratch.byte.high;
|
|
INPut.byte.low |= Scratch.byte.low;
|
|
|
|
Scratch.byte.high &= 0x01;
|
|
Scratch.byte.high <<= 2;
|
|
INPut.byte.low |= Scratch.byte.high;
|
|
|
|
return INPut.word;
|
|
|
|
} /* Gen8514V() */
|
|
|
|
|
|
|
|
/*
|
|
* short XlateVgaTable(HwDeviceExtension, TableOffset, pmode, VgaTblEntry,
|
|
* BookTblEntry, ee, IsMach32);
|
|
*
|
|
* PVOID HwDeviceExtension; Hardware extension for Windows NT
|
|
* short TableOffset; Offset of start of desired mode table into EEPROM
|
|
* struct st_mode_table *pmode; Mode table to fill in
|
|
* short VgaTblEntry; Resolution/vertical frequency of desired mode
|
|
* short BookTblEntry; Appendix D entry to use if parameters not in EEPROM
|
|
* struct st_eeprom_data *ee; EEPROM setup description
|
|
* BOOL IsMach32; Indicates whether card is a Mach32 or a Mach8
|
|
*
|
|
* Translates an EEPROM mode table from VGA to 8514 format and
|
|
* fills in the mode table passed in the parameter pmode.
|
|
*
|
|
* RETURN: Nonzero if values filled in
|
|
* Zero if we were unable to find the appropriate
|
|
* VGA parameter table. If this is the case, the
|
|
* value INVALID_WARNING is placed in pmode->m_h_overscan,
|
|
* pmode->m_v_overscan, pmode->m_overscan_8b, and
|
|
* pmode->m_overscan_gr.
|
|
*/
|
|
|
|
short XlateVgaTable(PVOID HwDeviceExtension,
|
|
short TableOffset, struct st_mode_table *pmode,
|
|
short VgaTblEntry, short BookTblEntry,
|
|
struct st_eeprom_data *ee, BOOL IsMach32)
|
|
{
|
|
/*
|
|
* Certain modes on some cards require extra scaling. This variable
|
|
* is set to the scaling factor (zero if no scaling needed). Initially
|
|
* assume that no scaling is needed.
|
|
*/
|
|
short FudgeFactor = 0;
|
|
|
|
union SplitWord ValueRead; /* Value read from the EEPROM */
|
|
|
|
/*
|
|
* Storage for CRT registers 06, 07 and 11. These registers are either
|
|
* used a number of times and would need repeated reads if they weren't
|
|
* saved, or are read before they are needed because they are the
|
|
* other byte of a word which contains a register which is needed
|
|
* at an earlier stage of the calculation.
|
|
*/
|
|
unsigned char Crt06;
|
|
unsigned char Crt07;
|
|
unsigned char Crt11;
|
|
|
|
/*
|
|
* Saved value of the low byte of the vertical sync start.
|
|
*/
|
|
unsigned char VSyncStart;
|
|
|
|
UNREFERENCED_PARAMETER(HwDeviceExtension);
|
|
|
|
/*
|
|
* If this is a mode for which we have no information,
|
|
* set up our warning and return.
|
|
*/
|
|
if (VgaTblEntry == NO_TBL_ENTRY)
|
|
{
|
|
pmode->m_h_overscan = (short) INVALID_WARNING;
|
|
pmode->m_v_overscan = (short) INVALID_WARNING;
|
|
pmode->m_overscan_8b = (short) INVALID_WARNING;
|
|
pmode->m_overscan_gr = (short) INVALID_WARNING;
|
|
return 0;
|
|
}
|
|
|
|
/*
|
|
* Under some circumstances, the CRT parameters will not be
|
|
* properly entered into the EEPROM, so attempting to read
|
|
* them will produce garbage values. If this is the case,
|
|
* the CRTC_USAGE bit in word 0 of the mode table will
|
|
* be clear (use sync polarities only).
|
|
*
|
|
* This case must be detected here, rather than calling
|
|
* BookVgaTable() whenever the USE_STORED_PARMS bit of the
|
|
* mode descriptor word is clear, because adjusting the screen
|
|
* size and position for a custom monitor does not always set
|
|
* this bit, but it will set the CRTC_USAGE bit.
|
|
*
|
|
* For this case, and for modes for which we have the parameters
|
|
* from Appendix D of the Programmer's Guide to the Mach 32
|
|
* Registers but no way to calculate the mode table information
|
|
* based on values read from the EEPROM, fill in the mode table
|
|
* with the book values and return.
|
|
*/
|
|
ValueRead.word = (ee->EEread)((short)(TableOffset+0));
|
|
if ((VgaTblEntry >= USE_BOOK_VALUE) || !(ValueRead.word & CRTC_USAGE))
|
|
{
|
|
BookVgaTable(BookTblEntry, pmode);
|
|
return 1;
|
|
}
|
|
|
|
/*
|
|
* We have VGA parameter tables to allow us to calculate the mode
|
|
* table entries from the EEPROM contents.
|
|
*
|
|
* Initially assume that we have either a Mach32 card or an older
|
|
* card with 1M of video memory.
|
|
*/
|
|
HalfMeg = 0;
|
|
|
|
/*
|
|
* Select the VGA parameter table for the card we are using
|
|
* (Mach8 or Mach32). On Mach8 cards, check if we are using
|
|
* a mode which requires scaling, and if we have only 512k
|
|
* of video memory.
|
|
*/
|
|
if (IsMach32)
|
|
{
|
|
VgaParmTable = VgaParmTable_M32;
|
|
}
|
|
else{
|
|
VgaParmTable = VgaParmTable_M8;
|
|
if (VgaParmTable[VgaTblEntry].Stretch == 0x080)
|
|
FudgeFactor = 1;
|
|
if (!(INP(SUBSYS_STAT) & 0x080))
|
|
HalfMeg = 1;
|
|
}
|
|
|
|
|
|
/*
|
|
* Get the horizontal total first.
|
|
*/
|
|
ValueRead.word = (ee->EEread)((short) (TableOffset+3));
|
|
ValueRead.byte.high = ((ValueRead.byte.high + 5) << FudgeFactor) - 1;
|
|
pmode->m_h_total = ValueRead.byte.high;
|
|
Crt06 = ValueRead.byte.low;
|
|
|
|
|
|
/*
|
|
* Get the horizontal display width.
|
|
*/
|
|
pmode->m_h_disp = VgaParmTable[VgaTblEntry].DisplayWidth;
|
|
pmode->m_x_size = (pmode->m_h_disp + 1) * 8;
|
|
|
|
|
|
/*
|
|
* Get the start of the horizontal sync.
|
|
*/
|
|
ValueRead.word = (ee->EEread)((short) (TableOffset+4));
|
|
pmode->m_h_sync_strt = ((ValueRead.byte.high - 2) << FudgeFactor) + FudgeFactor;
|
|
|
|
|
|
/*
|
|
* Get the horizontal sync width.
|
|
*/
|
|
ValueRead.word &= 0x1F1F;
|
|
ValueRead.byte.low -= ValueRead.byte.high;
|
|
ValueRead.byte.low &= 0x1f;
|
|
ValueRead.byte.low <<= FudgeFactor;
|
|
if (pmode->control & HSYNC_BIT)
|
|
ValueRead.byte.low |= NEG_SYNC_FACTOR;
|
|
pmode->m_h_sync_wid = ValueRead.byte.low;
|
|
|
|
|
|
/*
|
|
* Get the vertical total.
|
|
*/
|
|
ValueRead.word = (ee->EEread)((short) (TableOffset+8));
|
|
Crt07 = ValueRead.byte.high;
|
|
ValueRead.byte.low = Crt06;
|
|
GetVertOverflow(&(ValueRead.byte.high)); /* Overflow in bits 0&5 */
|
|
ValueRead.word += 2;
|
|
|
|
if (VgaParmTable[VgaTblEntry].MiscParms & INTERL)
|
|
ValueRead.word += 4;
|
|
|
|
ValueRead.word = Gen8514V(ValueRead, VgaTblEntry);
|
|
|
|
if (VgaParmTable[VgaTblEntry].MiscParms & INTERL)
|
|
ValueRead.byte.low &= 0x0FE;
|
|
|
|
pmode->m_v_total = ValueRead.word;
|
|
|
|
|
|
/*
|
|
* Get the number of displayed scanlines.
|
|
*/
|
|
ValueRead.byte.low = VgaParmTable[VgaTblEntry].DisplayHgt;
|
|
ValueRead.byte.high = Crt07 >> 1; /* Overflow in bits 1&6 */
|
|
GetVertOverflow(&(ValueRead.byte.high));
|
|
ValueRead.word++;
|
|
pmode->m_v_disp = Gen8514V(ValueRead, VgaTblEntry);
|
|
|
|
/*
|
|
* Y size is derived by removing bit 2.
|
|
*/
|
|
pmode->m_y_size = (((pmode->m_v_disp >> 1) & 0x0FFFC) | (pmode->m_v_disp & 0x03)) + 1;
|
|
|
|
|
|
/*
|
|
* Get the start of the vertical sync.
|
|
*/
|
|
ValueRead.word = (ee->EEread)((short) (TableOffset+5));
|
|
Crt11 = ValueRead.byte.low;
|
|
ValueRead.byte.low = ValueRead.byte.high;
|
|
VSyncStart = ValueRead.byte.high;
|
|
ValueRead.byte.high = Crt07 >> 2; /* Overflow in bits 2&7 */
|
|
GetVertOverflow(&(ValueRead.byte.high));
|
|
|
|
ValueRead.word++;
|
|
pmode->m_v_sync_strt = Gen8514V(ValueRead, VgaTblEntry);
|
|
|
|
|
|
/*
|
|
* Get the vertical sync width.
|
|
*/
|
|
Crt11 -= (VSyncStart & 0x0f);
|
|
if (VgaParmTable[VgaTblEntry].Mode & WORD_MODE)
|
|
Crt11 <<= 1;
|
|
Crt11 &= 0x0f;
|
|
if (pmode->control & VSYNC_BIT)
|
|
Crt11 |= NEG_SYNC_FACTOR;
|
|
pmode->m_v_sync_wid = Crt11;
|
|
|
|
/*
|
|
* Get the clock select and display control values.
|
|
*/
|
|
pmode->m_clock_select = VgaParmTable[VgaTblEntry].ClockSel;
|
|
pmode->ClockFreq = VgaParmTable[VgaTblEntry].ClockFreq;
|
|
pmode->m_disp_cntl = (UCHAR)(VgaParmTable[VgaTblEntry].DispCntl);
|
|
|
|
/*
|
|
* Assume an 8-entry FIFO for 16 and 24 bit colour.
|
|
*/
|
|
pmode->m_vfifo_24 = 8;
|
|
pmode->m_vfifo_16 = 8;
|
|
|
|
/*
|
|
* Some parameters in 8514 format do not have corresponding EEPROM
|
|
* table entries in VGA format. Set the pmode fields for these
|
|
* parameters to zero.
|
|
*/
|
|
pmode->m_h_overscan = 0;
|
|
pmode->m_v_overscan = 0;
|
|
pmode->m_overscan_8b = 0;
|
|
pmode->m_overscan_gr = 0;
|
|
pmode->m_status_flags = 0;
|
|
|
|
|
|
/*
|
|
* Let the caller know that the pmode table is now filled in.
|
|
*/
|
|
return 1;
|
|
|
|
} /* XlateVgaTable() */
|
|
|
|
|
|
/*
|
|
* void BookVgaTable(VgaTblEntry, pmode);
|
|
*
|
|
* short VgaTblEntry; Desired entry in BookValues[]
|
|
* struct st_mode_table *pmode; Mode table to fill in
|
|
*
|
|
* Fills in a mode table using the values in the BookValues[] entry
|
|
* corresponding to the resolution specified by VgaTblEntry.
|
|
*/
|
|
void BookVgaTable(short VgaTblEntry, struct st_mode_table *pmode)
|
|
{
|
|
pmode->m_h_total = BookValues[VgaTblEntry].HTotal;
|
|
pmode->m_h_disp = BookValues[VgaTblEntry].HDisp;
|
|
pmode->m_x_size = (pmode->m_h_disp+1)*8;
|
|
|
|
pmode->m_h_sync_strt = BookValues[VgaTblEntry].HSyncStrt;
|
|
pmode->m_h_sync_wid = BookValues[VgaTblEntry].HSyncWid;
|
|
|
|
pmode->m_v_total = BookValues[VgaTblEntry].VTotal;
|
|
pmode->m_v_disp = BookValues[VgaTblEntry].VDisp;
|
|
/*
|
|
* y_size is derived by removing bit 2
|
|
*/
|
|
pmode->m_y_size = (((pmode->m_v_disp >> 1) & 0x0FFFC) | (pmode->m_v_disp & 0x03)) + 1;
|
|
|
|
pmode->m_v_sync_strt = BookValues[VgaTblEntry].VSyncStrt;
|
|
pmode->m_v_sync_wid = BookValues[VgaTblEntry].VSyncWid;
|
|
pmode->m_disp_cntl = BookValues[VgaTblEntry].DispCntl;
|
|
|
|
pmode->m_clock_select = BookValues[VgaTblEntry].ClockSel;
|
|
pmode->ClockFreq = BookValues[VgaTblEntry].ClockFreq;
|
|
|
|
/*
|
|
* Assume 8 FIFO entries for 16 and 24 bit colour.
|
|
*/
|
|
pmode->m_vfifo_24 = 8;
|
|
pmode->m_vfifo_16 = 8;
|
|
|
|
/*
|
|
* Fill in the refresh rate
|
|
*/
|
|
pmode->Refresh = BookValues[VgaTblEntry].Refresh;
|
|
|
|
/*
|
|
* Clear the values which we don't have data for, then let
|
|
* the caller know that the table is filled in.
|
|
*/
|
|
pmode->m_h_overscan = 0;
|
|
pmode->m_v_overscan = 0;
|
|
pmode->m_overscan_8b = 0;
|
|
pmode->m_overscan_gr = 0;
|
|
pmode->m_status_flags = 0;
|
|
|
|
return;
|
|
|
|
} /* BookVgaTable() */
|
|
|
|
|
|
|
|
/***************************************************************************
|
|
*
|
|
* void SetMach64Tables(void);
|
|
*
|
|
* DESCRIPTION:
|
|
* Replace "canned" mode tables that differ between Mach 64 and
|
|
* Mach 8/Mach 32 parameters with Mach 64 versions. Whenever possible,
|
|
* an update to a VESA-compatible parameter table should be done in
|
|
* BookValues[] - this routine is only for those cases where the
|
|
* Mach 64 requires a pixel clock frequency that the clock generator
|
|
* on the Mach 8 or Mach 32 can't produce.
|
|
*
|
|
* GLOBALS CHANGED:
|
|
* Some entries in BookValues[] table
|
|
*
|
|
* CALLED BY:
|
|
* QueryMach64()
|
|
*
|
|
* AUTHOR:
|
|
* Robert Wolff
|
|
*
|
|
* CHANGE HISTORY:
|
|
*
|
|
* TEST HISTORY:
|
|
*
|
|
***************************************************************************/
|
|
|
|
void SetMach64Tables(void)
|
|
{
|
|
#define NUM_TABLES_TO_SWAP 1
|
|
ULONG TableIndices[NUM_TABLES_TO_SWAP] =
|
|
{
|
|
B640F72
|
|
};
|
|
struct st_book_data NewTables[NUM_TABLES_TO_SWAP] =
|
|
{
|
|
{0x067, 0x04F, 0x052, 0x025, 0x040B, 0x03BF, 0x03D0, 0x023, 0x023, 31200000L, 0x0800, 72} /* 640x480 72Hz NI */
|
|
};
|
|
ULONG LoopCount;
|
|
|
|
/*
|
|
* Go through the list of tables that need to be replaced, setting all
|
|
* the fields to the Mach 64 values.
|
|
*/
|
|
for (LoopCount = 0; LoopCount < NUM_TABLES_TO_SWAP; LoopCount++)
|
|
{
|
|
BookValues[TableIndices[LoopCount]].HTotal = NewTables[LoopCount].HTotal;
|
|
BookValues[TableIndices[LoopCount]].HDisp = NewTables[LoopCount].HDisp;
|
|
BookValues[TableIndices[LoopCount]].HSyncStrt = NewTables[LoopCount].HSyncStrt;
|
|
BookValues[TableIndices[LoopCount]].HSyncWid = NewTables[LoopCount].HSyncWid;
|
|
BookValues[TableIndices[LoopCount]].VTotal = NewTables[LoopCount].VTotal;
|
|
BookValues[TableIndices[LoopCount]].VDisp = NewTables[LoopCount].VDisp;
|
|
BookValues[TableIndices[LoopCount]].VSyncStrt = NewTables[LoopCount].VSyncStrt;
|
|
BookValues[TableIndices[LoopCount]].VSyncWid = NewTables[LoopCount].VSyncWid;
|
|
BookValues[TableIndices[LoopCount]].DispCntl = NewTables[LoopCount].DispCntl;
|
|
BookValues[TableIndices[LoopCount]].ClockFreq = NewTables[LoopCount].ClockFreq;
|
|
BookValues[TableIndices[LoopCount]].ClockSel = NewTables[LoopCount].ClockSel;
|
|
BookValues[TableIndices[LoopCount]].Refresh = NewTables[LoopCount].Refresh;
|
|
}
|
|
|
|
return;
|
|
|
|
} /* SetMach64Tables() */
|