//************************************************************************* //** ** //** AMACH1.H ** //** ** //** Copyright (c) 1993, 1995 ATI Technologies Inc. ** //************************************************************************* // // Supplemental definitions and data structures which are independent // of the ATI accelerator family being used. Mach 8/Mach32 specific // definitions and structures are in AMACH.H, while Mach 64 specific // definitions and structures are in AMACHCX.H. // // Created the 68800.inc file which includes equates, macros, etc // from the following include files: // 8514vesa.inc, vga1regs.inc, m32regs.inc, 8514.inc // // supplement structures and values to the 68800 Family. // // This is a "C" only file and is NOT derived from any Assembler INC files. /********************** PolyTron RCS Utilities $Revision: 1.14 $ $Date: 23 Apr 1996 17:15:20 $ $Author: RWolff $ $Log: S:/source/wnt/ms11/miniport/archive/amach1.h_v $ * * Rev 1.14 23 Apr 1996 17:15:20 RWolff * Added new memory types (used by ?T) to memory type enumeration. * * Rev 1.13 22 Dec 1995 14:51:10 RWolff * Added support for Mach 64 GT internal DAC. * * Rev 1.12 08 Sep 1995 16:36:00 RWolff * Added support for AT&T 408 DAC (STG1703 equivalent). * * Rev 1.11 28 Jul 1995 14:39:24 RWolff * Added support for the Mach 64 VT (CT equivalent with video overlay). * * Rev 1.10 30 Jan 1995 11:56:54 RWOLFF * Added support for CT internal DAC. * * Rev 1.9 18 Jan 1995 15:38:02 RWOLFF * Added Chrontel CH8398 to DAC type enumeration. * * Rev 1.8 23 Dec 1994 10:48:40 ASHANMUG * ALPHA/Chrontel-DAC * * Rev 1.7 18 Nov 1994 11:49:16 RWOLFF * Added new DAC type DAC_STG1703. This DAC is equivalent to the STG1702, * but has its own clock generator. The STG1702/1703 in native mode are * programmed differently in 24BPP than when they are strapped for * STG1700 emulation. * * Rev 1.6 14 Sep 1994 15:25:54 RWOLFF * Added "most desirable colour ordering" field to query structure, * changed RGB_ definitions from enumeration to flags * that can be used in this field. * * Rev 1.5 31 Aug 1994 16:09:02 RWOLFF * Added support for TVP3026 DAC and 1152x864, removed dead code. * * Rev 1.4 19 Aug 1994 17:03:30 RWOLFF * Added support for Graphics Wonder, SC15026 DAC, and pixel clock * generator independence. * * Rev 1.3 20 May 1994 13:56:42 RWOLFF * Ajith's change: added field for bus type reported by NT to * the query structure. * * Rev 1.2 12 May 1994 11:15:04 RWOLFF * Removed redundant definition, added refresh rate to mode table structure. * * Rev 1.1 04 May 1994 19:22:58 RWOLFF * Fix for block write test corrupting the screen when running display applet * * Rev 1.0 31 Jan 1994 11:26:48 RWOLFF * Initial revision. * * Rev 1.5 14 Jan 1994 15:17:00 RWOLFF * Added flag for 1600x1200 mode. * * Rev 1.4 15 Dec 1993 15:24:34 RWOLFF * Added support for SC15021 DAC. * * Rev 1.3 30 Nov 1993 18:08:58 RWOLFF * Renamed definition for Mach 64. * * Rev 1.2 05 Nov 1993 13:21:10 RWOLFF * Added new DAC types and memory sizes. * * Rev 1.1 08 Oct 1993 10:59:28 RWOLFF * Added colour ordering field to mode table. * * Rev 1.0 03 Sep 1993 14:26:18 RWOLFF * Initial revision. End of PolyTron RCS section *****************/ #ifndef BYTE typedef unsigned char BYTE; #endif /* BYTE */ #ifndef WORD typedef unsigned short WORD; #endif /* WORD */ #ifndef DWORD typedef unsigned long DWORD; #endif /* DWORD */ #ifndef UCHAR typedef unsigned char UCHAR; /* At least 8 bits, unsigned */ #endif /* UCHAR */ #ifndef BOOL typedef int BOOL; /* Most efficient Boolean, compare against zero only! */ #endif /* BOOL */ #ifndef VOID #define VOID void #endif /* VOID */ #ifndef PVOID typedef void *PVOID; /* Generic untyped pointer */ #endif /* PVOID */ // the eeprom i/o port bits are in different locations depending upon // what bus and what class of accelerator. This does NOT cover VGA class. struct st_eeprom_data { WORD iop_out; // I/O port for output WORD iop_in; // I/O port for input WORD clock; // clock bit to send data WORD select; // select eeprom WORD chipselect; // chip select WORD addr_size; // Address size (fudge for VGA style) WORD data_out; WORD data_in; VOID (*EEcmd)(); // function to write command to eeprom WORD (*EEread)(short); // function to read eeprom }; //----------------------------------------------------------------------- struct st_crt_mach8_table { // CRT Parameter Tables 11 Words long WORD control; // NOT in table, is 7,8,9, or 10 WORD info; // VGA or 8514 parm format, clock etc. BYTE vmode_sel_2; BYTE vmode_sel_1; BYTE vmode_sel_4; BYTE vmode_sel_3; BYTE h_disp; BYTE h_total; BYTE h_sync_wid; BYTE h_sync_strt; WORD v_total; WORD v_disp; WORD v_sync_strt; BYTE disp_cntl; BYTE v_sync_wid; WORD clock_sel; WORD resvd; }; // EEprom layout for the 8514/Ultra adapters. 64 words by 16 bits = 1K size struct st_ee_8514Ultra { WORD page_3_2; WORD page_2_0; WORD monitor; WORD vfifo; WORD clock; WORD shadow; WORD display_cntl; // shadow sets 1,2 WORD v_sync_width; // shadow sets 1,2 WORD v_sync_strt2; WORD v_sync_strt1; WORD v_display2; WORD v_display1; WORD v_total2; WORD v_total1; WORD h_sync_width; // shadow sets 1,2 WORD h_sync_strt; WORD h_display; WORD h_total; WORD crc; // Updated 8514/Ultra adds 800 and 1280 resolutions WORD ext_vfifo; // 800 and 1280 resolutions WORD ext_clock; WORD ext_shadow; WORD ext_display; WORD ext_v_sync_width; WORD v_sync_strt_800; WORD v_display_800; WORD v_total_800; WORD ext_h_sync_width; // shadow sets for 800 and 1280 WORD ext_h_sync_strt; WORD ext_h_display; WORD ext_h_total; WORD custom_mode; WORD monitor_name[17]; // words 32-48 WORD v_sync_strt_1280; // word 49 WORD v_display_1280; // word 50 WORD v_total_1280; // word 51 }; //----------------------------------------------------------------------- // EEprom layout for the Graphics Ultra adapters. 64 words by 16 bits = 1K size // This is the brute forcing of the VGA Wonder and the 8514 chips // both residing on the same board. struct st_ee_GraphicsUltra { WORD eeprom_counter; WORD mouse; WORD powerup_mode; WORD resvd1[2]; // word 3,4 WORD monitor; WORD resvd2; // word 6 WORD hz640_72; WORD hz800; // word 8 WORD hz1024; WORD hz1280; WORD resvd3[2]; // word 11,12 struct st_crt_mach8_table r640; // CRT parm Table 0 - 640x480 mode struct st_crt_mach8_table r800; // CRT parm Table 1 - 640x480 mode struct st_crt_mach8_table r1024; // CRT parm Table 2 - 640x480 mode struct st_crt_mach8_table r1280; // Table 3 - 1280 OR 132 column text mode }; //----------------------------------------------------------------------- // EEprom layout for the 68800 adapters. 128 words by 16 bits = 2K size struct st_crt_mach32_table { // CRT Parameter Tables 15 Words long WORD info; // VGA or 8514 parm format, clock etc. BYTE vmode_sel_2; BYTE vmode_sel_1; BYTE vmode_sel_4; BYTE vmode_sel_3; BYTE h_disp; BYTE h_total; BYTE h_sync_wid; BYTE h_sync_strt; WORD v_total; WORD v_disp; WORD v_sync_strt; BYTE disp_cntl; BYTE v_sync_wid; WORD clock_sel; // same as st_crt_mach8 to here. WORD mode_size; // word 10 WORD horz_ovscan; WORD vert_ovscan; WORD ov_col_blue; // word 13 WORD ov_col_grn_red; // word 14 }; struct st_ee_68800 { WORD eeprom_counter; WORD mouse; WORD powerup_mode; WORD ee_rev; // word 3 WORD cm_indices; // word 4 WORD monitor; WORD aperture; // word 6 WORD hz640_72; WORD hz800; // word 8 WORD hz1024; WORD hz1280; WORD hz1150; // word 11 WORD resvd3; // word 12 // example crt tables, there are many for each resolution // struct st_crt_mach32_table r640; // CRT parm Table 0 - 640x480 mode // struct st_crt_mach32_table r800; // CRT parm Table 1 - 640x480 mode // struct st_crt_mach32_table r1024; // CRT parm Table 2 - 640x480 mode // struct st_crt_mach32_table r1280; // Table 3 - 1280 OR 132 column text mode }; //----------------------------------------------------------------------- //--------------- as defined in \68800\test\services.asm #define QUERY_GET_SIZE 0 // return query structure size (varying modes) #define QUERY_LONG 1 // return query structure filled in #define QUERY_SHORT 2 // return short query struct query_structure { short q_sizeof_struct; // size of structure in bytes (including mode tables) UCHAR q_structure_rev; // structure revision number UCHAR q_number_modes; // total number of installed modes short q_mode_offset; // offset to 1st mode table UCHAR q_sizeof_mode; // size of mode table in bytes UCHAR q_asic_rev; // gate array revision number UCHAR q_status_flags; // status flags UCHAR q_VGA_type; // VGA type (enabled or disabled for now) UCHAR q_VGA_boundary; // VGA boundary UCHAR q_memory_size; // total memory size (VGA + accelerator) UCHAR q_DAC_type; // DAC type UCHAR q_memory_type; // memory type UCHAR q_bus_type; // bus type UCHAR q_monitor_alias; // monitor alias and monitor alias enable short q_shadow_1; // shadow set 1 state short q_shadow_2; // shadow set 2 state short q_aperture_addr; // aperture address UCHAR q_aperture_cfg; // aperture size UCHAR q_mouse_cfg; // mouse configuration UCHAR q_reserved; short q_desire_x; // selected screen resolution X value short q_desire_y; short q_pix_depth; // selected bits per pixel BYTE far *q_bios; // Base address of the BIOS BOOL q_eeprom; // TRUE if eeprom present BOOL q_ext_bios_fcn; // TRUE if ATI Extended BIOS fcns present BOOL q_ignore1280; // TRUE if ignore 1280 table in Mach8 cards BOOL q_m32_aper_calc; // TRUE if mach32 aperture addr needs Extra Bits. BOOL q_GraphicsWonder; /* TRUE if this is a Graphics Wonder (restricted Mach 32) */ short q_screen_pitch; // Pixels per display line UCHAR q_BlockWrite; /* Whether or not block write mode is available */ ULONG q_system_bus_type; // bus type reported by NT USHORT q_HiColourSupport; /* Colour orders supported for non-paletted modes */ }; // Matches BIOS mode table query function up to and including m_overscan_gr struct st_mode_table { short m_x_size; // horizontal screen resolution short m_y_size; // vertical screen resolution UCHAR m_pixel_depth; // maximum pixel depth UCHAR m_status_flags; // status flags // bit 0: if set, non-linear Y addressing // bit 1: if set, MUX mode // bit 2: if set, PCLK/2 short m_reserved; UCHAR m_vfifo_16; // 16 bpp vfifo depth UCHAR m_vfifo_24; // 24 bpp vfifo depth short m_clock_select; // clock select UCHAR m_h_total; // horizontal total UCHAR m_h_disp; // horizontal displayed UCHAR m_h_sync_strt; // horizontal sync start UCHAR m_disp_cntl; // display control UCHAR m_h_sync_wid; // horizontal sync width UCHAR m_v_sync_wid; // vertical sync width short m_v_total; // vertical total short m_v_disp; // vertical displayed short m_v_sync_strt; // vertical sync start short m_h_overscan; // horizontal overscan configuration short m_v_overscan; // vertical overscan configuration short m_overscan_8b; // overscan color for 8 bit and blue short m_overscan_gr; // overscan color green and red short enabled; // what frequency is enabled (eeprom 7,8,9,10 or 11) short control; // clock and control values (CRT table 0) ULONG ClockFreq; /* Clock frequency (in Hertz) */ short m_screen_pitch; // pixels per display line WORD ColourDepthInfo; /* Information about colour depth being used */ short Refresh; /* Refresh rate, in hertz */ }; /* * Masks and flags for the m_clock_select field. * All the flags will be stripped out when the field * is ANDed with CLOCK_SEL_STRIP. */ #define CLOCK_SEL_STRIP 0xFF83 /* AND to remove clock selector/divisor */ #define CLOCK_SEL_MUX 0x0004 /* Use mux mode (2x 8bit pixels in 16 bit path) */ #define CLOCK_SEL_DIVIDED 0x0008 /* Clock frequency for mux mode already divided by 2 */ /* * Flags to put in query_structure.q_HiColourSupport to show that * the corresponding colour order is supported. */ #define RGB16_555 0x0001 #define RGB16_565 0x0002 #define RGB16_655 0x0004 #define RGB16_664 0x0008 #define RGB24_RGB 0x0010 #define RGB24_BGR 0x0020 #define RGB32_RGBx 0x0040 #define RGB32_xRGB 0x0080 #define RGB32_BGRx 0x0100 #define RGB32_xBGR 0x0200 //----- Video Memory details enum { VMEM_DRAM_256Kx4 = 0, VMEM_VRAM_256Kx4_SER512, VMEM_VRAM_256Kx4_SER256, /* 68800-3 only */ VMEM_DRAM_256Kx16, VMEM_DRAM_256Kx4_GRAP, /* This and following types on 68800-6 only */ VMEM_VRAM_256Kx4_SPLIT512, VMEM_VRAM_256Kx16_SPLIT256, VMEM_GENERIC_DRAM, /* This and following types are for Mach 64 ?T only */ VMEM_EDO_DRAM, VMEM_BRRAM, VMEM_SDRAM }; #define VMEM_VRAM_256Kx16_SER256 VMEM_VRAM_256Kx4_SER256 /* 68800-6 only */ //----- BUS types matches the 68800 CONFIG_STATUS_1.BUS_TYPE enum { BUS_ISA_16, BUS_EISA, BUS_MC_16, BUS_MC_32, BUS_LB_386SX, BUS_LB_386DX, BUS_LB_486, BUS_PCI, BUS_ISA_8 }; //----- RAM DAC details, matches CONFIG_STATUS_1.DACTYPE field enum { DAC_ATI_68830, DAC_SIERRA, DAC_TI34075, DAC_BT47x, DAC_BT48x, DAC_ATI_68860, DAC_STG1700, DAC_SC15021, /* * DAC types below are for cases where incompatible DAC types * report the same code in CONFIG_STATUS_1. Since the DAC type * field is 3 bits and can't grow (bits immediately above and * below are already assigned), DAC types 8 and above will * not conflict with reported DAC types but are still legal * in the query structure's DAC type field (8 bit unsigned integer). */ DAC_ATT491, DAC_ATT498, DAC_SC15026, /* * DAC types below are not used on 8514/A-compatible accelerators. * Subsequent additions must be made AFTER DAC_SC15026. */ DAC_TVP3026, DAC_IBM514, /* * This DAC is more advanced than the STG1700. */ DAC_STG1702, /* * DAC is equivalent to STG1702, but it has its own clock * generator which is programmed differently from the one * normally used on the Mach 64. */ DAC_STG1703, /* * DAC with equivalent capabilities to STG1703, but not a * drop-in replacement. */ DAC_CH8398, /* * Yet another DAC which is equivalent to STG1703 but which * is not a drop-in replacement. */ DAC_ATT408, /* * Internal DAC on Mach 64 CT ASIC. */ DAC_INTERNAL_CT, /* * Internal DAC on Mach 64 GT ASIC. This is a CT equivalent * with built-in multimedia and games functionality. */ DAC_INTERNAL_GT, /* * Internal DAC on Mach 64 VT ASIC. This is a CT equivalent * with built-in video overlay circuitry. */ DAC_INTERNAL_VT, /* * Size definition for arrays indexed by DAC type (assumes enumerated * types are zero-based). This must be the LAST entry in the * DAC type enumeration. */ HOW_MANY_DACs }; /* * Size definition for 8514/A-compatible accelerator arrays indexed by * DAC type. */ #define MAX_OLD_DAC DAC_TVP3026 /* * Possible knowledge states for block write capability. */ enum {BLOCK_WRITE_UNKNOWN, BLOCK_WRITE_NO, BLOCK_WRITE_YES }; //Monitor Descriptions are in IBM style #define MONITOR_ID_8514 0x000A #define MONITOR_ID_8515 0x000B #define MONITOR_ID_VGA8503 0x000D #define MONITOR_ID_VGA8513 0x000E #define MONITOR_ID_VGA8512 0x000E #define MONITOR_ID_8604 0x0009 #define MONITOR_ID_8507 0x0009 #define MONITOR_ID_NOMON 0x000F /* * Give identifiers for the different ATI 8514 Products, * as used in the ModelNumber field of the HW_DEVICE_EXTENSION * structure and returned by Mach8_detect(). */ enum { _8514_ULTRA = 1, GRAPHICS_ULTRA, MACH32_ULTRA, MACH64_ULTRA, IBM_VGA, WONDER, IBM_8514, IBM_XGA, NO_ATI_ACCEL // No ATI accelerator available }; /* * Number of ATI 8514 products available. */ #define HOW_MANY_8514_PRODS (NO_ATI_ACCEL - _8514_ULTRA) + 1 /* * Amount of Video RAM installed. The q_memory_size * field of the query_structure uses these definitions * rather than holding a count of the number of bytes. */ enum { VRAM_256k=1, VRAM_512k, VRAM_768k, VRAM_1mb, VRAM_1_25mb, VRAM_1_50mb, VRAM_2mb=8, VRAM_4mb=16, VRAM_6mb=24, VRAM_8mb=32, VRAM_12mb=48, VRAM_16mb=64 }; /* * Define bits for resolutions. The q_status_flags field * of the query_structure uses these. */ #define VRES_640x480 0x0001 #define VRES_800x600 0x0002 #define VRES_1024x768 0x0004 #define VRES_1280x1024 0x0008 #define VRES_ALT_1 0x0010 /* Usually 1152x900, 1120x750 */ #define VRES_1152x864 VRES_ALT_1 #define VRES_RESERVED_6 0x0020 #define VRES_RESERVED_7 0x0040 #define VRES_RESERVED_8 0x0080 #define VRES_1600x1200 VRES_ALT_1 /* * Predefined Video Resolution Modes */ enum { VRES_UNDEFINED, VRES_640x480x4, VRES_640x480x8, VRES_640x480x16, VRES_640x480x24, VRES_640x480x32, VRES_800x600x4, VRES_800x600x8, VRES_800x600x16, VRES_800x600x24, VRES_800x600x32, VRES_1024x768x4, VRES_1024x768x8, VRES_1024x768x16, VRES_1024x768x24, VRES_1024x768x32, VRES_1280x1024x4, VRES_1280x1024x8, VRES_1280x1024x16, VRES_1280x1024x24, VRES_1280x1024x32, VRES_ALTERNATEx4, VRES_ALTERNATEx8, VRES_ALTERNATEx16, VRES_ALTERNATEx24, VRES_ALTERNATEx32 }; /* * Number of predefined video resolution modes. */ #define HOW_MANY_RES_MODES (VRES_ALTERNATEx32 - VRES_UNDEFINED) + 1 /* * Numbers used in memory calculations. */ #define ONE_MEG 1048576L #define HALF_MEG 524288L #define QUARTER_MEG 262144L /* * Definitions with an underscore in their name will read or write * a portion of a larger register other than the least significant * byte or word. Due to limitations in the Lio routines, * it is not possible to do this by calling (for example) LioInp(port+1). * * _HBLW Access the high byte of the low word (16 and 32 bit registers) * _LBHW Access the low byte of the high word (32 bit registers only) * _HBHW Access the high byte of the high word (32 bit registers only) * _HW Access the high word (32 bit registers only) */ #define INP(port) LioInp(port, 0) #define INP_HBLW(port) LioInp(port, 1) #define INP_LBHW(port) LioInp(port, 2) #define INP_HBHW(port) LioInp(port, 3) #define INPW(port) LioInpw(port, 0) #define INPW_HW(port) LioInpw(port, 2) #define INPD(port) LioInpd(port) #define OUTP(port, val) LioOutp(port, val, 0) #define OUTP_HBLW(port, val) LioOutp(port, val, 1) #define OUTP_LBHW(port, val) LioOutp(port, val, 2) #define OUTP_HBHW(port, val) LioOutp(port, val, 3) #define OUTPW(port, val) LioOutpw(port, val, 0) #define OUTPW_HW(port, val) LioOutpw(port, val, 2) #define OUTPD(port, val) LioOutpd(port, val) //********************** end of AMACH1.H ****************************