1145 lines
42 KiB
C
1145 lines
42 KiB
C
/******************************Module*Header*******************************\
|
|
* Module Name: hw.h
|
|
*
|
|
* All the hardware specific driver file stuff. Parts are mirrored in
|
|
* 'hw.inc'.
|
|
*
|
|
* Copyright (c) 1992-1995 Microsoft Corporation
|
|
*
|
|
\**************************************************************************/
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
// Alpha and PowerPC considerations
|
|
//
|
|
// Both the Alpha and the PowerPC do not guarantee that I/O to
|
|
// separate addresses will be executed in order. The Alpha and
|
|
// PowerPC differ, however, in that the PowerPC guarantees that
|
|
// output to the same address will be executed in order, while the
|
|
// Alpha may cache and 'collapse' consecutive output to become only
|
|
// one output.
|
|
//
|
|
// Consequently, we use the following synchronization macros. They
|
|
// are relatively expensive in terms of performance, so we try to avoid
|
|
// them whereever possible.
|
|
//
|
|
// CP_EIEIO() 'Ensure In-order Execution of I/O'
|
|
// - Used to flush any pending I/O in situations where we wish to
|
|
// avoid out-of-order execution of I/O to separate addresses.
|
|
//
|
|
// CP_MEMORY_BARRIER()
|
|
// - Used to flush any pending I/O in situations where we wish to
|
|
// avoid out-of-order execution or 'collapsing' of I/O to
|
|
// the same address. On the PowerPC, this will be defined as
|
|
// a null operation.
|
|
|
|
#if defined(_PPC_)
|
|
|
|
// On PowerPC, CP_MEMORY_BARRIER doesn't do anything.
|
|
|
|
#define CP_EIEIO() MEMORY_BARRIER()
|
|
#define CP_MEMORY_BARRIER()
|
|
|
|
#else
|
|
|
|
// On Alpha, CP_EIEIO is the same thing as a CP_MEMORY_BARRIER.
|
|
// On other systems, both CP_EIEIO and CP_MEMORY_BARRIER don't do anything.
|
|
|
|
#define CP_EIEIO() MEMORY_BARRIER()
|
|
#define CP_MEMORY_BARRIER() MEMORY_BARRIER()
|
|
|
|
#endif
|
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
// Mach32 Equates
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
#define NOT_SCREEN 0x00
|
|
#define LOGICAL_0 0x01
|
|
#define LOGICAL_1 0x02
|
|
#define LEAVE_ALONE 0x03
|
|
#define NOT_NEW 0x04
|
|
#define SCREEN_XOR_NEW 0x05
|
|
#define NOT_SCREEN_XOR_NEW 0x06
|
|
#define OVERPAINT 0x07
|
|
#define NOT_SCREEN_OR_NOT_NEW 0x08
|
|
#define SCREEN_OR_NOT_NEW 0x09
|
|
#define NOT_SCREEN_OR_NEW 0x0A
|
|
#define SCREEN_OR_NEW 0x0B
|
|
#define SCREEN_AND_NEW 0x0C
|
|
#define NOT_SCREEN_AND_NEW 0x0D
|
|
#define SCREEN_AND_NOT_NEW 0x0E
|
|
#define NOT_SCREEN_AND_NOT_NEW 0x0F
|
|
|
|
#define SETUP_ID1 0x0100 // Setup Mode Identification (Byte 1)
|
|
#define SETUP_ID2 0x0101 // Setup Mode Identification (Byte 2)
|
|
#define SETUP_OPT 0x0102 // Setup Mode Option Select
|
|
#define ROM_SETUP 0x0103 //
|
|
#define SETUP_1 0x0104 //
|
|
#define SETUP_2 0x0105 //
|
|
#define DISP_STATUS 0x02E8 // Display Status
|
|
#define H_TOTAL 0x02E8 // Horizontal Total
|
|
#define DAC_MASK 0x02EA // DAC Mask
|
|
#define DAC_R_INDEX 0x02EB // DAC Read Index
|
|
#define DAC_W_INDEX 0x02EC // DAC Write Index
|
|
#define DAC_DATA 0x02ED // DAC Data
|
|
#define OVERSCAN_COLOR_8 0x02EE
|
|
#define OVERSCAN_BLUE_24 0x02EF
|
|
#define H_DISP 0x06E8 // Horizontal Displayed
|
|
#define OVERSCAN_GREEN_24 0x06EE
|
|
#define OVERSCAN_RED_24 0x06EF
|
|
#define H_SYNC_STRT 0x0AE8 // Horizontal Sync Start
|
|
#define CURSOR_OFFSET_LO 0x0AEE
|
|
#define H_SYNC_WID 0x0EE8 // Horizontal Sync Width
|
|
#define CURSOR_OFFSET_HI 0x0EEE
|
|
#define V_TOTAL 0x12E8 // Vertical Total
|
|
#define CONFIG_STATUS_1 0x12EE // Read only equivalent to HORZ_CURSOR_POSN
|
|
#define HORZ_CURSOR_POSN 0x12EE
|
|
#define V_DISP 0x16E8 // Vertical Displayed
|
|
#define CONFIG_STATUS_2 0x16EE // Read only equivalent to VERT_CURSOR_POSN
|
|
#define VERT_CURSOR_POSN 0x16EE
|
|
#define V_SYNC_STRT 0x1AE8 // Vertical Sync Start
|
|
#define CURSOR_COLOR_0 0x1AEE
|
|
#define FIFO_TEST_DATA 0x1AEE
|
|
#define CURSOR_COLOR_1 0x1AEF
|
|
#define V_SYNC_WID 0x1EE8 // Vertical Sync Width
|
|
#define HORZ_CURSOR_OFFSET 0x1EEE
|
|
#define VERT_CURSOR_OFFSET 0x1EEF
|
|
#define DISP_CNTL 0x22E8 // Display Control
|
|
#define CRT_PITCH 0x26EE
|
|
#define CRT_OFFSET_LO 0x2AEE
|
|
#define CRT_OFFSET_HI 0x2EEE
|
|
#define LOCAL_CONTROL 0x32EE
|
|
#define FIFO_OPT 0x36EE
|
|
#define MISC_OPTIONS 0x36EE
|
|
#define EXT_CURSOR_COLOR_0 0x3AEE
|
|
#define FIFO_TEST_TAG 0x3AEE
|
|
#define EXT_CURSOR_COLOR_1 0x3EEE
|
|
#define SUBSYS_CNTL 0x42E8 // Subsystem Control
|
|
#define SUBSYS_STAT 0x42E8 // Subsystem Status
|
|
#define MEM_BNDRY 0x42EE
|
|
#define SHADOW_CTL 0x46EE
|
|
#define ROM_PAGE_SEL 0x46E8 // ROM Page Select (not in manual)
|
|
#define ADVFUNC_CNTL 0x4AE8 // Advanced Function Control
|
|
#define CLOCK_SEL 0x4AEE
|
|
#define SCRATCH_PAD_0 0x52EE
|
|
#define SCRATCH_PAD_1 0x56EE
|
|
#define SHADOW_SET 0x5AEE
|
|
#define MEM_CFG 0x5EEE
|
|
#define EXT_GE_STATUS 0x62EE
|
|
#define HORZ_OVERSCAN 0x62EE
|
|
#define VERT_OVERSCAN 0x66EE
|
|
#define MAX_WAITSTATES 0x6AEE
|
|
#define GE_OFFSET_LO 0x6EEE
|
|
#define BOUNDS_LEFT 0x72EE
|
|
#define GE_OFFSET_HI 0x72EE
|
|
#define BOUNDS_TOP 0x76EE
|
|
#define GE_PITCH 0x76EE
|
|
#define BOUNDS_RIGHT 0x7AEE
|
|
#define EXT_GE_CONFIG 0x7AEE
|
|
#define BOUNDS_BOTTOM 0x7EEE
|
|
#define MISC_CNTL 0x7EEE
|
|
#define CUR_Y 0x82E8 // Current Y Position
|
|
#define PATT_DATA_INDEX 0x82EE
|
|
#define CUR_X 0x86E8 // Current X Position
|
|
#define M32_SRC_Y 0x8AE8 //
|
|
#define DEST_Y 0x8AE8 //
|
|
#define AXSTP 0x8AE8 // Destination Y Position
|
|
// Axial Step Constant
|
|
#define M32_SRC_X 0x8EE8 //
|
|
#define DEST_X 0x8EE8 //
|
|
#define DIASTP 0x8EE8 // Destination X Position
|
|
// Diagonial Step Constant
|
|
#define PATT_DATA 0x8EEE
|
|
#define R_EXT_GE_CONFIG 0x8EEE
|
|
#define ERR_TERM 0x92E8 // Error Term
|
|
#define R_MISC_CNTL 0x92EE
|
|
#define MAJ_AXIS_PCNT 0x96E8 // Major Axis Pixel Count
|
|
#define BRES_COUNT 0x96EE
|
|
#define CMD 0x9AE8 // Command
|
|
#define GE_STAT 0x9AE8 // Graphics Processor Status
|
|
#define EXT_FIFO_STATUS 0x9AEE
|
|
#define LINEDRAW_INDEX 0x9AEE
|
|
#define SHORT_STROKE 0x9EE8 // Short Stroke Vector Transfer
|
|
#define BKGD_COLOR 0xA2E8 // Background Color
|
|
#define LINEDRAW_OPT 0xA2EE
|
|
#define FRGD_COLOR 0xA6E8 // Foreground Color
|
|
#define DEST_X_START 0xA6EE
|
|
#define WRT_MASK 0xAAE8 // Write Mask
|
|
#define DEST_X_END 0xAAEE
|
|
#define RD_MASK 0xAEE8 // Read Mask
|
|
#define DEST_Y_END 0xAEEE
|
|
#define CMP_COLOR 0xB2E8 // Compare Color
|
|
#define R_H_TOTAL 0xB2EE
|
|
#define R_H_DISP 0xB2EE
|
|
#define M32_SRC_X_START 0xB2EE
|
|
#define BKGD_MIX 0xB6E8 // Background Mix
|
|
#define ALU_BG_FN 0xB6EE
|
|
#define R_H_SYNC_STRT 0xB6EE
|
|
#define FRGD_MIX 0xBAE8 // Foreground Mix
|
|
#define ALU_FG_FN 0xBAEE
|
|
#define R_H_SYNC_WID 0xBAEE
|
|
#define MULTIFUNC_CNTL 0xBEE8 // Multi-Function Control (mach 8) !!!!!! Requires MB
|
|
#define MIN_AXIS_PCNT 0xBEE8
|
|
#define SCISSOR_T 0xBEE8
|
|
#define SCISSOR_L 0xBEE8
|
|
#define SCISSOR_B 0xBEE8
|
|
#define SCISSOR_R 0xBEE8
|
|
#define M32_MEM_CNTL 0xBEE8
|
|
#define PATTERN_L 0xBEE8
|
|
#define PATTERN_H 0xBEE8
|
|
#define PIXEL_CNTL 0xBEE8
|
|
#define M32_SRC_X_END 0xBEEE
|
|
#define SRC_Y_DIR 0xC2EE
|
|
#define R_V_TOTAL 0xC2EE
|
|
#define EXT_SSV 0xC6EE // (used for MACH 8)
|
|
#define EXT_SHORT_STROKE 0xC6EE
|
|
#define R_V_DISP 0xC6EE
|
|
#define SCAN_X 0xCAEE
|
|
#define R_V_SYNC_STRT 0xCAEE
|
|
#define DP_CONFIG 0xCEEE
|
|
#define VERT_LINE_CNTR 0xCEEE
|
|
#define PATT_LENGTH 0xD2EE
|
|
#define R_V_SYNC_WID 0xD2EE
|
|
#define PATT_INDEX 0xD6EE
|
|
#define EXT_SCISSOR_L 0xDAEE // "extended" left scissor (12 bits precision)
|
|
#define R_SRC_X 0xDAEE
|
|
#define EXT_SCISSOR_T 0xDEEE // "extended" top scissor (12 bits precision)
|
|
#define R_SRC_Y 0xDEEE
|
|
#define PIX_TRANS 0xE2E8 // Pixel Data Transfer
|
|
#define PIX_TRANS_LO 0xE2E8
|
|
#define PIX_TRANS_HI 0xE2E9
|
|
#define EXT_SCISSOR_R 0xE2EE // "extended" right scissor (12 bits precision)
|
|
#define EXT_SCISSOR_B 0xE6EE // "extended" bottom scissor (12 bits precision)
|
|
#define SRC_CMP_COLOR 0xEAEE // (used for MACH 8)
|
|
#define DEST_CMP_FN 0xEEEE
|
|
#define LINEDRAW 0xFEEE // !!!!!! Requires MB
|
|
|
|
//---------------------------------------------------------
|
|
// macros (from 8514.inc)
|
|
//
|
|
// I/O macros:
|
|
//
|
|
//mov if port NOT = to DX
|
|
//
|
|
//mov if port NOT = to DX
|
|
//
|
|
//
|
|
//
|
|
//Following are the FIFO checking macros:
|
|
//
|
|
//
|
|
//
|
|
//FIFO space check macro:
|
|
//
|
|
#define ONE_WORD 0x8000
|
|
#define TWO_WORDS 0xC000
|
|
#define THREE_WORDS 0xE000
|
|
#define FOUR_WORDS 0xF000
|
|
#define FIVE_WORDS 0xF800
|
|
#define SIX_WORDS 0xFC00
|
|
#define SEVEN_WORDS 0xFE00
|
|
#define EIGHT_WORDS 0xFF00
|
|
#define NINE_WORDS 0xFF80
|
|
#define TEN_WORDS 0xFFC0
|
|
#define ELEVEN_WORDS 0xFFE0
|
|
#define TWELVE_WORDS 0xFFF0
|
|
#define THIRTEEN_WORDS 0xFFF8
|
|
#define FOURTEEN_WORDS 0xFFFC
|
|
#define FIFTEEN_WORDS 0xFFFE
|
|
#define SIXTEEN_WORDS 0xFFFF
|
|
//
|
|
//
|
|
//
|
|
//---------------------------------------
|
|
//
|
|
//
|
|
// Draw Command (DRAW_COMMAND) (from 8514regs.inc)
|
|
// note: required by m32poly.asm
|
|
//
|
|
// opcode field
|
|
#define OP_CODE 0xE000
|
|
#define SHIFT_op_code 0x000D
|
|
#define DRAW_SETUP 0x0000
|
|
#define DRAW_LINE 0x2000
|
|
#define FILL_RECT_H1H4 0x4000
|
|
#define FILL_RECT_V1V2 0x6000
|
|
#define FILL_RECT_V1H4 0x8000
|
|
#define DRAW_POLY_LINE 0xA000
|
|
#define BITBLT_OP 0xC000
|
|
#define DRAW_FOREVER 0xE000
|
|
// swap field
|
|
#define LSB_FIRST 0x1000
|
|
// data width field
|
|
#define DATA_WIDTH 0x0200
|
|
#define BIT16 0x0200
|
|
#define BIT8 0x0000
|
|
// CPU wait field
|
|
#define CPU_WAIT 0x0100
|
|
// octant field
|
|
#define OCTANT 0x00E0
|
|
#define SHIFT_octant 0x0005
|
|
#define YPOSITIVE 0x0080
|
|
#define YMAJOR 0x0040
|
|
#define XPOSITIVE 0x0020
|
|
// draw field
|
|
#define DRAW 0x0010
|
|
// direction field
|
|
#define DIR_TYPE 0x0008
|
|
#define DEGREE 0x0008
|
|
#define XY 0x0000
|
|
#define RECT_RIGHT_AND_DOWN 0x00E0 // quadrant 3
|
|
#define RECT_LEFT_AND_UP 0x0000 // quadrant 1
|
|
// last pel off field
|
|
#define SHIFT_last_pel_off 0x0002
|
|
#define LAST_PEL_OFF 0x0004
|
|
#define LAST_PEL_ON 0x0000
|
|
// pixel mode
|
|
#define PIXEL_MODE 0x0002
|
|
#define MULTI 0x0002
|
|
#define SINGLE 0x0000
|
|
// read/write
|
|
#define RW 0x0001
|
|
#define WRITE 0x0001
|
|
#define READ 0x0000
|
|
//
|
|
// ---------------------------------------------------------
|
|
// 8514 register definitions (from vga1regs.inc)
|
|
//
|
|
// Internal registers (read only, for test purposes only)
|
|
#define _PAR_FIFO_DATA 0x1AEE
|
|
#define _PAR_FIFO_ADDR 0x3AEE
|
|
#define _MAJOR_DEST_CNT 0x42EE
|
|
#define _MAJOR_SRC_CNT 0x5EEE
|
|
#define _MINOR_DEST_CNT 0x66EE
|
|
#define _MINOR_SRC_CNT 0x8AEE
|
|
#define _HW_TEST 0x32EE
|
|
//
|
|
// Extended Graphics Engine Status (EXT_GE_STATUS)
|
|
// -rn- used in mach32.asm
|
|
//
|
|
#define POINTS_INSIDE 0x8000
|
|
#define EE_DATA_IN 0x4000
|
|
#define GE_ACTIVE 0x2000
|
|
#define CLIP_ABOVE 0x1000
|
|
#define CLIP_BELOW 0x0800
|
|
#define CLIP_LEFT 0x0400
|
|
#define CLIP_RIGHT 0x0200
|
|
#define CLIP_FLAGS 0x1E00
|
|
#define CLIP_INSIDE 0x0100
|
|
#define EE_CRC_VALID 0x0080
|
|
#define CLIP_OVERRUN 0x000F
|
|
//
|
|
// Datapath Configuration Register (DP_CONFIG)
|
|
// note: some of the EQU is needed in m32poly.asm
|
|
#define FG_COLOR_SRC 0xE000
|
|
#define SHIFT_fg_color_src 0x000D
|
|
#define DATA_ORDER 0x1000
|
|
#define DATA_WIDTH 0x0200
|
|
#define BG_COLOR_SRC 0x0180
|
|
#define SHIFT_bg_color_src 0x0007
|
|
#define EXT_MONO_SRC 0x0060
|
|
#define SHIFT_ext_mono_src 0x0005
|
|
#define DRAW 0x0010
|
|
#define READ_MODE 0x0004
|
|
#define POLY_FILL_MODE 0x0002
|
|
#define WRITE 0x0001
|
|
#define SRC_SWAP 0x0800
|
|
//
|
|
#define FG_COLOR_SRC_BG 0x0000 // Background Color Register
|
|
#define FG_COLOR_SRC_FG 0x2000 // Foreground Color Register
|
|
#define FG_COLOR_SRC_HOST 0x4000 // CPU Data Transfer Reg
|
|
#define FG_COLOR_SRC_BLIT 0x6000 // VRAM blit source
|
|
#define FG_COLOR_SRC_GS 0x8000 // Grey-scale mono blit
|
|
#define FG_COLOR_SRC_PATT 0xA000 // Color Pattern Shift Reg
|
|
#define FG_COLOR_SRC_CLUH 0xC000 // Color lookup of Host Data
|
|
#define FG_COLOR_SRC_CLUB 0xE000 // Color lookup of blit src
|
|
//
|
|
#define BG_COLOR_SRC_BG 0x0000 // Background Color Reg
|
|
#define BG_COLOR_SRC_FG 0x0080 // Foreground Color Reg
|
|
#define BG_COLOR_SRC_HOST 0x0100 // CPU Data Transfer Reg
|
|
#define BG_COLOR_SRC_BLIT 0x0180 // VRAM blit source
|
|
//
|
|
// Note that "EXT_MONO_SRC" and "MONO_SRC" are mutually destructive, but that
|
|
// "EXT_MONO_SRC" selects the ATI pattern registers.
|
|
//
|
|
#define EXT_MONO_SRC_ONE 0x0000 // Always '1'
|
|
#define EXT_MONO_SRC_PATT 0x0020 // ATI Mono Pattern Regs
|
|
#define EXT_MONO_SRC_HOST 0x0040 // CPU Data Transfer Reg
|
|
#define EXT_MONO_SRC_BLIT 0x0060 // VRAM Blit source plane
|
|
//
|
|
// Linedraw Options Register (LINEDRAW_OPT)
|
|
//
|
|
// note: some of the EQUS are needed in m32poly.asm
|
|
#define CLIP_MODE 0x0600
|
|
#define SHIFT_clip_mode 0x0009
|
|
#define CLIP_MODE_DIS 0x0000
|
|
#define CLIP_MODE_LINE 0x0200
|
|
#define CLIP_MODE_PLINE 0x0400
|
|
#define CLIP_MODE_PATT 0x0600
|
|
#define BOUNDS_RESET 0x0100
|
|
#define OCTANT 0x00E0
|
|
#define SHIFT_ldo_octant 0x0005
|
|
#define YDIR 0x0080
|
|
#define XMAJOR 0x0040
|
|
#define XDIR 0x0020
|
|
#define DIR_TYPE 0x0008
|
|
#define DIR_TYPE_DEGREE 0x0008
|
|
#define DIR_TYPE_OCTANT 0x0000
|
|
#define LAST_PEL_OFF 0x0004
|
|
#define POLY_MODE 0x0002
|
|
//
|
|
#define FOREGROUND_COLOR 0x20
|
|
#define DATA_EXTENSION 0xA000
|
|
#define ALL_ONES 0x0000
|
|
#define CPU_DATA 0x0080
|
|
#define DISPLAY_MEMORY 0x00C0
|
|
//
|
|
// Blt defines
|
|
//
|
|
#define GE_BUSY 0x0200
|
|
|
|
#define LOAD_SOURCE_AND_DEST 0
|
|
#define LOAD_DEST 1
|
|
#define LOAD_SOURCE 2
|
|
#define TOP_TO_BOTTOM 1
|
|
#define BOTTOM_TO_TOP 0
|
|
#define VID_MEM_BLT 0x6211
|
|
#define COLOR_FIL_BLT 0x2211
|
|
#define MIX_FN_D 3 // page 8-24
|
|
#define MIX_FN_S 7 // page 8-24
|
|
|
|
#define PIXEL_CTRL 0xa000 // page 8-46
|
|
#define DEST_NOT_EQ_COLOR_CMP 0x0020
|
|
#define DEST_ALWAY_OVERWRITE 0
|
|
|
|
//
|
|
//
|
|
// ------------------------------------------------------------
|
|
// Mach32 register equates (from m32regs.inc)
|
|
//
|
|
#define REVISION 0x0000
|
|
//HORIZONTAL_OVERSCAN equ 062EEh
|
|
//VERTICAL_OVERSCAN equ 066EEh
|
|
|
|
#define FL_MM_REGS 0x80000000 /* Memory Mapped registers are available */
|
|
|
|
#define M32_MAX_SCISSOR 2047 /* Maximum scissors value */
|
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
// Mach32 Port Access
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
#if !(defined(ALPHA) || defined(_AXP64_) || defined(AXP64) )
|
|
|
|
#define M32_IB_DIRECT(pbase,port) \
|
|
READ_REGISTER_UCHAR((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))))
|
|
|
|
#define M32_IW_DIRECT(pbase,port) \
|
|
READ_REGISTER_USHORT((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))))
|
|
|
|
#define M32_OB_DIRECT(pbase,port,val) \
|
|
WRITE_REGISTER_UCHAR((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))), \
|
|
(UCHAR) (val))
|
|
|
|
#define M32_OW_DIRECT(pbase,port,val) \
|
|
WRITE_REGISTER_USHORT((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))), \
|
|
(USHORT) (val))
|
|
|
|
#else
|
|
|
|
extern BOOL isDense;
|
|
|
|
#define M32_IB_DIRECT(pbase,port) \
|
|
(isDense? \
|
|
*((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1)))) : \
|
|
READ_REGISTER_UCHAR((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1)))))
|
|
|
|
#define M32_IW_DIRECT(pbase,port) \
|
|
(isDense? \
|
|
*((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1)))) : \
|
|
READ_REGISTER_USHORT((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1)))))
|
|
|
|
#define M32_OB_DIRECT(pbase,port,val) \
|
|
{ \
|
|
if (isDense) \
|
|
*((UCHAR*) ((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))))) \
|
|
= (UCHAR) (val); \
|
|
else { \
|
|
WRITE_REGISTER_UCHAR((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))), \
|
|
(UCHAR) (val)); } \
|
|
CP_MEMORY_BARRIER(); \
|
|
}
|
|
|
|
#define M32_OW_DIRECT(pbase,port,val) \
|
|
{ \
|
|
if (isDense) \
|
|
*((USHORT*) ((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))))) \
|
|
= (USHORT) (val); \
|
|
else { \
|
|
WRITE_REGISTER_USHORT((((port) & 0xFE) == 0xE8) \
|
|
? ((BYTE*) pbase + 0x3FFE00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))) \
|
|
: ((BYTE*) pbase + 0x3FFF00 + ((((port) & 0xFC00) >> 8) | ((port) & 0x1))), \
|
|
(USHORT) (val)); } \
|
|
CP_MEMORY_BARRIER(); \
|
|
}
|
|
|
|
#endif
|
|
|
|
#if defined(_X86_) || defined(_IA64_)
|
|
|
|
#define I32_IB_DIRECT(pbase,port) \
|
|
READ_PORT_UCHAR((BYTE*)port)
|
|
|
|
#define I32_IW_DIRECT(pbase,port) \
|
|
READ_PORT_USHORT((BYTE*)port)
|
|
|
|
#define I32_OB_DIRECT(pbase,port,val) \
|
|
WRITE_PORT_UCHAR((BYTE*)port, val)
|
|
|
|
#define I32_OW_DIRECT(pbase,port,val) \
|
|
WRITE_PORT_USHORT((BYTE*)port, (USHORT)(val))
|
|
|
|
#else
|
|
|
|
#define I32_IB_DIRECT(pbase,port) \
|
|
READ_PORT_UCHAR((BYTE*) pbase + (port))
|
|
|
|
#define I32_IW_DIRECT(pbase,port) \
|
|
READ_PORT_USHORT((BYTE*) pbase + (port))
|
|
|
|
#define I32_OB_DIRECT(pbase,port,val) \
|
|
WRITE_PORT_UCHAR((BYTE*) pbase + (port), val)
|
|
|
|
#define I32_OW_DIRECT(pbase,port,val) \
|
|
WRITE_PORT_USHORT((BYTE*) pbase + (port), val)
|
|
|
|
#endif
|
|
|
|
/////////////////////////////////////////////////////////////////////////
|
|
// Mach32 FIFO access
|
|
//
|
|
// The following macros should be used for all accesses to FIFO registers.
|
|
// On checked builds, they enforce proper FIFO usage protocol; on free
|
|
// builds, they incur no overhead.
|
|
|
|
#define M32_IB(pbase,port) (M32_IB_DIRECT(pbase,port))
|
|
#define M32_IW(pbase,port) (M32_IW_DIRECT(pbase,port))
|
|
#define M32_OB(pbase,port,val) {CHECK_FIFO_WRITE(); M32_OB_DIRECT(pbase,port,val);}
|
|
#define M32_OW(pbase,port,val) {CHECK_FIFO_WRITE(); M32_OW_DIRECT(pbase,port,val);}
|
|
#define I32_IB(pbase,port) (I32_IB_DIRECT(pbase,port))
|
|
#define I32_IW(pbase,port) (I32_IW_DIRECT(pbase,port))
|
|
#define I32_OB(pbase,port,val) {CHECK_FIFO_WRITE(); I32_OB_DIRECT(pbase,port,val);}
|
|
#define I32_OW(pbase,port,val) {CHECK_FIFO_WRITE(); I32_OW_DIRECT(pbase,port,val);}
|
|
|
|
#if DBG
|
|
|
|
VOID vCheckWriteFifo();
|
|
VOID vI32CheckFifoSpace(PDEV*, VOID*, LONG);
|
|
VOID vM32CheckFifoSpace(PDEV*, VOID*, LONG);
|
|
|
|
#define CHECK_FIFO_WRITE() \
|
|
vCheckFifoWrite()
|
|
|
|
#define M32_CHECK_FIFO_SPACE(ppdev, pbase, level) \
|
|
vM32CheckFifoSpace(ppdev, pbase, level)
|
|
|
|
#define I32_CHECK_FIFO_SPACE(ppdev, pbase, level) \
|
|
vI32CheckFifoSpace(ppdev, pbase, level)
|
|
|
|
#else
|
|
|
|
#define M32_CHECK_FIFO_SPACE(ppdev, pbase, level) \
|
|
{ \
|
|
while (M32_IW(pbase, EXT_FIFO_STATUS) & (0x10000L >> (level))) \
|
|
; \
|
|
}
|
|
|
|
#define I32_CHECK_FIFO_SPACE(ppdev, pbase, level) \
|
|
{ \
|
|
while (I32_IW(pbase, EXT_FIFO_STATUS) & (0x10000L >> (level))) \
|
|
; \
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
// Mach64 Equates
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// CRTC IO Registers
|
|
#define ioCRTC_H_TOTAL_DISP 0x02EC
|
|
#define ioBASE ioCRTC_H_TOTAL_DISP
|
|
|
|
#define ioCRTC_H_SYNC_STRT_WID 0x06EC
|
|
#define ioCRTC_V_TOTAL_DISP 0x0AEC
|
|
#define ioCRTC_V_SYNC_STRT_WID 0x0EEC
|
|
#define ioCRTC_CRNT_VLINE 0x12EC
|
|
#define ioCRTC_OFF_PITCH 0x16EC
|
|
#define ioCRTC_INT_CNTL 0x1AEC
|
|
#define ioCRTC_GEN_CNTL 0x1EEC
|
|
|
|
#define ioOVR_CLR 0x22EC
|
|
#define ioOVR_WID_LEFT_RIGHT 0x26EC
|
|
#define ioOVR_WID_TOP_BOTTOM 0x2AEC
|
|
|
|
#define ioCUR_CLR0 0x2EEC
|
|
#define ioCUR_CLR1 0x32EC
|
|
#define ioCUR_OFFSET 0x36EC
|
|
#define ioCUR_HORZ_VERT_POSN 0x3AEC
|
|
#define ioCUR_HORZ_VERT_OFF 0x3EEC
|
|
|
|
#define ioSCRATCH0 0x42EC
|
|
#define ioSCRATCH1 0x46EC
|
|
|
|
#define ioCLOCK_SEL_CNTL 0x4AEC
|
|
|
|
#define ioBUS_CNTL 0x4EEC
|
|
|
|
#define ioMEM_CNTL 0x52EC
|
|
#define ioMEM_VGA_WP_SEL 0x56EC
|
|
#define ioMEM_VGA_RP_SEL 0x5AEC
|
|
|
|
#define ioDAC_REGS 0x5EEC
|
|
|
|
#define ioDAC_CNTL 0x62EC
|
|
|
|
#define ioGEN_TEST_CNTL 0x66EC
|
|
|
|
#define ioCONFIG_CNTL 0x6AEC
|
|
#define ioCONFIG_CHIP_ID 0x6EEC
|
|
#define ioCONFIG_STAT 0x72EC
|
|
|
|
|
|
// CRTC MEM Registers
|
|
|
|
|
|
#define CRTC_H_TOTAL_DISP 0x0000
|
|
#define CRTC_H_SYNC_STRT_WID 0x0001
|
|
#define CRTC_V_TOTAL_DISP 0x0002
|
|
#define CRTC_V_SYNC_STRT_WID 0x0003
|
|
#define CRTC_CRNT_VLINE 0x0004
|
|
#define CRTC_OFF_PITCH 0x0005
|
|
#define CRTC_INT_CNTL 0x0006
|
|
#define CRTC_GEN_CNTL 0x0007
|
|
|
|
#define OVR_CLR 0x0010
|
|
#define OVR_WID_LEFT_RIGHT 0x0011
|
|
#define OVR_WID_TOP_BOTTOM 0x0012
|
|
|
|
#define CUR_CLR0 0x0018
|
|
#define CUR_CLR1 0x0019
|
|
#define CUR_OFFSET 0x001A
|
|
#define CUR_HORZ_VERT_POSN 0x001B
|
|
#define CUR_HORZ_VERT_OFF 0x001C
|
|
|
|
#define SCRATCH0 0x0020
|
|
#define SCRATCH1 0x0021
|
|
|
|
#define CLOCK_SEL_CNTL 0x0024
|
|
|
|
#define BUS_CNTL 0x0028
|
|
#define BUS_CNTL_FifoErrInt 0x00200000
|
|
#define BUS_CNTL_FifoErrAk 0x00200000
|
|
#define BUS_CNTL_HostErrInt 0x00800000
|
|
#define BUS_CNTL_HostErrAk 0x00800000
|
|
|
|
#define M64_MEM_CNTL 0x002C
|
|
#define MEM_CNTL_MemBndryMsk 0x00070000
|
|
#define MEM_CNTL_MemBndryEn 0x00040000
|
|
#define MEM_CNTL_MemBndry256k 0x00040000
|
|
#define MEM_CNTL_MemBndry512k 0x00050000
|
|
#define MEM_CNTL_MemBndry768k 0x00060000
|
|
#define MEM_CNTL_MemBndry1Mb 0x00070000
|
|
|
|
#define MEM_VGA_WP_SEL 0x002D
|
|
#define MEM_VGA_RP_SEL 0x002E
|
|
|
|
#define DAC_REGS 0x0030
|
|
#define DAC_CNTL 0x0031
|
|
|
|
#define GEN_TEST_CNTL 0x0034
|
|
#define GEN_TEST_CNTL_CursorEna 0x00000080
|
|
#define GEN_TEST_CNTL_GuiEna 0x00000100
|
|
#define GEN_TEST_CNTL_TestFifoEna 0x00010000
|
|
#define GEN_TEST_CNTL_GuiRegEna 0x00020000
|
|
#define GEN_TEST_CNTL_TestMode 0x00700000
|
|
#define GEN_TEST_CNTL_TestMode0 0x00000000
|
|
#define GEN_TEST_CNTL_TestMode1 0x00100000
|
|
#define GEN_TEST_CNTL_TestMode2 0x00200000
|
|
#define GEN_TEST_CNTL_TestMode3 0x00300000
|
|
#define GEN_TEST_CNTL_TestMode4 0x00400000
|
|
#define GEN_TEST_CNTL_MemWR 0x01000000
|
|
#define GEN_TEST_CNTL_MemStrobe 0x02000000
|
|
#define GEN_TEST_CNTL_DstSSEna 0x04000000
|
|
#define GEN_TEST_CNTL_DstSSStrobe 0x08000000
|
|
#define GEN_TEST_CNTL_SrcSSEna 0x10000000
|
|
#define GEN_TEST_CNTL_SrcSSStrobe 0x20000000
|
|
|
|
#define CONFIG_CHIP_ID 0x0038
|
|
#define CONFIG_STAT 0x0039
|
|
|
|
|
|
#define DST_OFF_PITCH 0x0040
|
|
#define DST_X 0x0041
|
|
#define DST_Y 0x0042
|
|
#define DST_Y_X 0x0043
|
|
#define DST_WIDTH 0x0044
|
|
#define DST_WIDTH_Disable 0x80000000
|
|
#define DST_HEIGHT 0x0045
|
|
#define DST_HEIGHT_WIDTH 0x0046
|
|
#define DST_X_WIDTH 0x0047
|
|
#define DST_BRES_LNTH 0x0048
|
|
#define DST_BRES_ERR 0x0049
|
|
#define DST_BRES_INC 0x004A
|
|
#define DST_BRES_DEC 0x004B
|
|
#define DST_CNTL 0x004C
|
|
#define DST_CNTL_XDir 0x00000001
|
|
#define DST_CNTL_YDir 0x00000002
|
|
#define DST_CNTL_YMajor 0x00000004
|
|
#define DST_CNTL_XTile 0x00000008
|
|
#define DST_CNTL_YTile 0x00000010
|
|
#define DST_CNTL_LastPel 0x00000020
|
|
#define DST_CNTL_PolyEna 0x00000040
|
|
#define DST_CNTL_24_RotEna 0x00000080
|
|
#define DST_CNTL_24_Rot 0x00000700
|
|
|
|
#define SRC_OFF_PITCH 0x0060
|
|
#define M64_SRC_X 0x0061
|
|
#define M64_SRC_Y 0x0062
|
|
#define SRC_Y_X 0x0063
|
|
#define SRC_WIDTH1 0x0064
|
|
#define SRC_HEIGHT1 0x0065
|
|
#define SRC_HEIGHT1_WIDTH1 0x0066
|
|
#define M64_SRC_X_START 0x0067
|
|
#define SRC_Y_START 0x0068
|
|
#define SRC_Y_X_START 0x0069
|
|
#define SRC_WIDTH2 0x006A
|
|
#define SRC_HEIGHT2 0x006B
|
|
#define SRC_HEIGHT2_WIDTH2 0x006C
|
|
#define SRC_CNTL 0x006D
|
|
#define SRC_CNTL_PatEna 0x0001
|
|
#define SRC_CNTL_PatRotEna 0x0002
|
|
#define SRC_CNTL_LinearEna 0x0004
|
|
#define SRC_CNTL_ByteAlign 0x0008
|
|
#define SRC_CNTL_LineXDir 0x0010
|
|
|
|
#define HOST_DATA0 0x0080
|
|
#define HOST_DATA1 0x0081
|
|
#define HOST_DATA2 0x0082
|
|
#define HOST_DATA3 0x0083
|
|
#define HOST_DATA4 0x0084
|
|
#define HOST_DATA5 0x0085
|
|
#define HOST_DATA6 0x0086
|
|
#define HOST_DATA7 0x0087
|
|
#define HOST_DATA8 0x0088
|
|
#define HOST_DATA9 0x0089
|
|
#define HOST_DATAA 0x008A
|
|
#define HOST_DATAB 0x008B
|
|
#define HOST_DATAC 0x008C
|
|
#define HOST_DATAD 0x008D
|
|
#define HOST_DATAE 0x008E
|
|
#define HOST_DATAF 0x008F
|
|
#define HOST_CNTL 0x0090
|
|
#define HOST_CNTL_ByteAlign 0x0001
|
|
|
|
#define PAT_REG0 0x00A0
|
|
#define PAT_REG1 0x00A1
|
|
#define PAT_CNTL 0x00A2
|
|
#define PAT_CNTL_MonoEna 0x0001
|
|
#define PAT_CNTL_Clr4x2Ena 0x0002
|
|
#define PAT_CNTL_Clr8x1Ena 0x0004
|
|
|
|
#define SC_LEFT 0x00A8
|
|
#define SC_RIGHT 0x00A9
|
|
#define SC_LEFT_RIGHT 0x00AA
|
|
#define SC_TOP 0x00AB
|
|
#define SC_BOTTOM 0x00AC
|
|
#define SC_TOP_BOTTOM 0x00AD
|
|
|
|
#define DP_BKGD_CLR 0x00B0
|
|
#define DP_FRGD_CLR 0x00B1
|
|
#define DP_WRITE_MASK 0x00B2
|
|
#define DP_CHAIN_MASK 0x00B3
|
|
#define DP_PIX_WIDTH 0x00B4
|
|
#define DP_PIX_WIDTH_Mono 0x00000000
|
|
#define DP_PIX_WIDTH_4bpp 0x00000001
|
|
#define DP_PIX_WIDTH_8bpp 0x00000002
|
|
#define DP_PIX_WIDTH_15bpp 0x00000003
|
|
#define DP_PIX_WIDTH_16bpp 0x00000004
|
|
#define DP_PIX_WIDTH_32bpp 0x00000006
|
|
#define DP_PIX_WIDTH_NibbleSwap 0x01000000
|
|
#define DP_MIX 0x00B5
|
|
#define DP_SRC 0x00B6
|
|
#define DP_SRC_BkgdClr 0x0000
|
|
#define DP_SRC_FrgdClr 0x0001
|
|
#define DP_SRC_Host 0x0002
|
|
#define DP_SRC_Blit 0x0003
|
|
#define DP_SRC_Pattern 0x0004
|
|
#define DP_SRC_Always1 0x00000000
|
|
#define DP_SRC_MonoPattern 0x00010000
|
|
#define DP_SRC_MonoHost 0x00020000
|
|
#define DP_SRC_MonoBlit 0x00030000
|
|
|
|
#define CLR_CMP_CLR 0x00C0
|
|
#define CLR_CMP_MSK 0x00C1
|
|
#define CLR_CMP_CNTL 0x00C2
|
|
#define CLR_CMP_CNTL_Source 0x01000000
|
|
|
|
#define FIFO_STAT 0x00C4
|
|
|
|
#define CONTEXT_MASK 0x00C8
|
|
#define CONTEXT_SAVE_CNTL 0x00CA
|
|
#define CONTEXT_LOAD_CNTL 0x00CB
|
|
#define CONTEXT_LOAD_Cmd 0x00030000
|
|
#define CONTEXT_LOAD_CmdLoad 0x00010000
|
|
#define CONTEXT_LOAD_CmdBlt 0x00020000
|
|
#define CONTEXT_LOAD_CmdLine 0x00030000
|
|
#define CONTEXT_LOAD_Disable 0x80000000
|
|
|
|
#define GUI_TRAJ_CNTL 0x00CC
|
|
#define GUI_STAT 0x00CE
|
|
|
|
// DDraw MACH 64 stuff
|
|
//
|
|
// GUI_STAT
|
|
#define GUI_ACTIVE 0x00000001L
|
|
#define DSTX_LT_SCISSOR_LEFT 0x00000100L
|
|
#define DSTX_GT_SCISSOR_RIGHT 0x00000200L
|
|
#define DSTY_LT_SCISSOR_TOP 0x00000400L
|
|
#define DSTY_GT_SCISSOR_BOTTOM 0x00000800L
|
|
// DST Shifts
|
|
#define SHIFT_DST_PITCH 22 // DST_OFF_PITCH
|
|
#define SHIFT_DST_X 16 // DST_Y_X
|
|
#define SHIFT_DST_WIDTH 16 // DST_HEIGHT_WIDTH DST_X_WIDTH
|
|
// DST_WIDTH
|
|
#define DST_WIDTH_FILL_DIS 0x80000000L
|
|
// SC Shifts
|
|
#define SHIFT_SC_RIGHT 16
|
|
#define SHIFT_SC_BOTTOM 16
|
|
// DP_PIX_WIDTH
|
|
#define DP_DST_PIX_WIDTH 0x00000007L
|
|
#define DP_SRC_PIX_WIDTH 0x00000700L
|
|
#define DP_HOST_PIX_WIDTH 0x00070000L
|
|
#define DP_BYTE_PIX_ORDER 0x01000000L
|
|
|
|
#define DP_PIX_WIDTH_MONO 0x00000000L
|
|
#define DP_PIX_WIDTH_4BPP 0x00010101L
|
|
#define DP_PIX_WIDTH_8BPP 0x00020202L
|
|
#define DP_PIX_WIDTH_15BPP 0x00030303L
|
|
#define DP_PIX_WIDTH_16BPP 0x00040404L
|
|
#define DP_PIX_WIDTH_24BPP 0x00020202L
|
|
#define DP_PIX_WIDTH_32BPP 0x00060606L
|
|
// DP_MIX
|
|
#define DP_BKGD_MIX 0x0000001FL
|
|
#define DP_FRGD_MIX 0x001F0000L
|
|
|
|
#define DP_MIX_Dn 0x00000000L
|
|
#define DP_MIX_0 0x00010001L
|
|
#define DP_MIX_1 0x00020002L
|
|
#define DP_MIX_D 0x00030003L
|
|
#define DP_MIX_Sn 0x00040004L
|
|
#define DP_MIX_DSx 0x00050005L
|
|
#define DP_MIX_DSxn 0x00060006L
|
|
#define DP_MIX_S 0x00070007L
|
|
#define DP_MIX_DSan 0x00080008L
|
|
#define DP_MIX_DSno 0x00090009L
|
|
#define DP_MIX_SDno 0x000A000AL
|
|
#define DP_MIX_DSo 0x000B000BL
|
|
#define DP_MIX_DSa 0x000C000CL
|
|
#define DP_MIX_SDna 0x000D000DL
|
|
#define DP_MIX_DSna 0x000E000EL
|
|
#define DP_MIX_DSon 0x000F000FL
|
|
#define DP_MIX_0x17 0x00170017L
|
|
// DP_SRC
|
|
#define DP_BKGD_SRC 0x00000007L
|
|
#define DP_FRGD_SRC 0x00000700L
|
|
#define DP_MONO_SRC 0x00030000L
|
|
|
|
#define DP_SRC_BKGD 0x00000000L
|
|
#define DP_SRC_FRGD 0x00000101L
|
|
#define DP_SRC_HOST 0x00020202L
|
|
#define DP_SRC_VRAM 0x00030303L
|
|
#define DP_SRC_PATT 0x00010404L
|
|
// CLR_CMP_CNTL
|
|
#define CLR_CMP_FCN 0x00000007L
|
|
#define CLR_CMP_SRC 0x01000000L
|
|
|
|
#define CLR_CMP_FCN_FALSE 0x00000000L
|
|
#define CLR_CMP_FCN_TRUE 0x00000001L
|
|
#define CLR_CMP_FCN_NE 0x00000004L
|
|
#define CLR_CMP_FCN_EQ 0x00000005L
|
|
// DST_CNTL
|
|
#define DST_X_DIR 0x00000001L
|
|
#define DST_Y_DIR 0x00000002L
|
|
#define DST_Y_MAJOR 0x00000004L
|
|
#define DST_X_TILE 0x00000008L
|
|
#define DST_Y_TILE 0x00000010L
|
|
#define DST_LAST_PEL 0x00000020L
|
|
#define DST_POLYGON_EN 0x00000040L
|
|
#define DST_24_ROT_EN 0x00000080L
|
|
#define DST_24_ROT 0x00000700L
|
|
#define DST_BRES_SIGN 0x00000800L
|
|
// SRC Shifts
|
|
#define SHIFT_SRC_PITCH 22
|
|
#define SHIFT_SRC_X 16
|
|
#define SHIFT_SRC_WIDTH1 16
|
|
#define SHIFT_SRC_X_START 16
|
|
#define SHIFT_SRC_WIDTH2 16
|
|
// SRC_CNTL
|
|
#define SRC_PATT_EN 0x00000001L
|
|
#define SRC_PATT_ROT_EN 0x00000002L
|
|
#define SRC_LINEAR_EN 0x00000004L
|
|
#define SRC_BYTE_ALIGN 0x00000008L
|
|
|
|
#define ONE_WORD 0x8000
|
|
#define TWO_WORDS 0xC000
|
|
#define THREE_WORDS 0xE000
|
|
#define FOUR_WORDS 0xF000
|
|
#define FIVE_WORDS 0xF800
|
|
#define SIX_WORDS 0xFC00
|
|
#define SEVEN_WORDS 0xFE00
|
|
#define EIGHT_WORDS 0xFF00
|
|
#define NINE_WORDS 0xFF80
|
|
#define TEN_WORDS 0xFFC0
|
|
#define ELEVEN_WORDS 0xFFE0
|
|
#define TWELVE_WORDS 0xFFF0
|
|
#define THIRTEEN_WORDS 0xFFF8
|
|
#define FOURTEEN_WORDS 0xFFFC
|
|
#define FIFTEEN_WORDS 0xFFFE
|
|
#define SIXTEEN_WORDS 0xFFFF
|
|
|
|
#define REG_W 0 // DAC REGS offset for Write
|
|
#define REG_D 1 // DAC REGS offset for Data
|
|
#define REG_M 2 // DAC REGS offset for Mask
|
|
#define REG_R 3 // DAC REGS offset for Read
|
|
#define MAX_NEGX 4096
|
|
|
|
#define M64_MAX_SCISSOR_R 4095 /* Maximum right scissors value */
|
|
#define M64_MAX_SCISSOR_B 16383 /* Maximum bottom scissors value */
|
|
|
|
#define CRTC_VBLANK 0x00000001L
|
|
#define MUL24 3
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
// Mach64 Port Access
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// NOTE: This macro must not be used if 'y' can be negative:
|
|
|
|
#define PACKXY(x, y) (((x) << 16) | ((y) & 0xffff))
|
|
#define PACKXY_FAST(x, y) (((x) << 16) | ((y) & 0xffff))
|
|
//#define PACKXY_FAST(x, y) (((x) << 16) | (y))
|
|
#define PACKPAIR(a, b) (((b) << 16) | (a))
|
|
|
|
#if !( defined(ALPHA) || defined(_AXP64_) || defined(AXP64) )
|
|
|
|
#define M64_ID_DIRECT(pbase,port) \
|
|
READ_REGISTER_ULONG((ULONG*) pbase + (port))
|
|
|
|
#define M64_OD_DIRECT(pbase,port,val) \
|
|
WRITE_REGISTER_ULONG((ULONG*) pbase + (port), (val)); \
|
|
CP_EIEIO()
|
|
|
|
#else
|
|
|
|
extern BOOL isDense;
|
|
|
|
#define M64_ID_DIRECT(pbase,port) \
|
|
(isDense? *((ULONG*) pbase + \
|
|
(port)):READ_REGISTER_ULONG((ULONG*) pbase + (port)))
|
|
|
|
#define M64_OD_DIRECT(pbase,port,val) \
|
|
{ \
|
|
if (isDense) \
|
|
*((ULONG*) pbase + (port)) = (ULONG) (val); \
|
|
else { \
|
|
WRITE_REGISTER_ULONG((ULONG*) pbase + (port), (val)); } \
|
|
CP_MEMORY_BARRIER(); \
|
|
}
|
|
|
|
#endif
|
|
|
|
VOID vM64DataPortOutB(PDEV *ppdev, PBYTE pb, UINT count);
|
|
|
|
/////////////////////////////////////////////////////////////////////////
|
|
// Mach64 FIFO access
|
|
//
|
|
// The following macros should be used for all accesses to FIFO registers.
|
|
// On checked builds, they enforce proper FIFO usage protocol; on free
|
|
// builds, they incur no overhead.
|
|
|
|
#define M64_ID(pbase,port) (M64_ID_DIRECT(pbase,port))
|
|
#define M64_OD(pbase,port,val) {CHECK_FIFO_WRITE(); M64_OD_DIRECT(pbase,port,val);}
|
|
|
|
#if DBG
|
|
|
|
VOID vCheckFifoWrite();
|
|
VOID vM64CheckFifoSpace(PDEV*, VOID*, LONG);
|
|
ULONG ulM64FastFifoCheck(PDEV*, VOID*, LONG, ULONG);
|
|
|
|
#define CHECK_FIFO_WRITE() \
|
|
vCheckFifoWrite()
|
|
|
|
#define M64_CHECK_FIFO_SPACE(ppdev, pbase, level) \
|
|
vM64CheckFifoSpace(ppdev, pbase, level)
|
|
|
|
#define M64_FAST_FIFO_CHECK(ppdev, pbase, level, ulFifo) \
|
|
(ulFifo) = ulM64FastFifoCheck(ppdev, pbase, level, ulFifo)
|
|
|
|
#define I32_FIFO_SPACE_AVAIL(ppdev, pbase, level) \
|
|
(I32_IW((pbase), EXT_FIFO_STATUS) & (0x10000L >> (level))) \
|
|
|
|
#define M32_FIFO_SPACE_AVAIL(ppdev, pbase, level) \
|
|
(M32_IW((pbase), EXT_FIFO_STATUS) & (0x10000L >> (level))) \
|
|
|
|
#define M64_FIFO_SPACE_AVAIL(ppdev, pbase, level) \
|
|
(M64_ID((pbase), FIFO_STAT) & (0x10000L >> (level))) \
|
|
|
|
|
|
#else
|
|
|
|
#define CHECK_FIFO_WRITE()
|
|
|
|
#define M64_CHECK_FIFO_SPACE(ppdev, pbase, level) \
|
|
{ \
|
|
while (M64_ID((pbase), FIFO_STAT) & (0x10000L >> (level))) \
|
|
; \
|
|
}
|
|
|
|
// This handy little macro is useful for amortizing the read cost of
|
|
// the status register:
|
|
|
|
#define M64_FAST_FIFO_CHECK(ppdev, pbase, level, ulFifo) \
|
|
{ \
|
|
while (!((ulFifo) & (0x10000L >> (level)))) \
|
|
{ \
|
|
(ulFifo) = ~M64_ID((pbase), FIFO_STAT); /* Invert bits */ \
|
|
} \
|
|
(ulFifo) <<= (level); \
|
|
}
|
|
|
|
#define M64_FIFO_SPACE_AVAIL(ppdev, pbase, level) \
|
|
(M64_ID((pbase), FIFO_STAT) & (0x10000L >> (level))) \
|
|
|
|
#define I32_FIFO_SPACE_AVAIL(ppdev, pbase, level) \
|
|
(I32_IW((pbase), EXT_FIFO_STATUS) & (0x10000L >> (level))) \
|
|
|
|
#define M32_FIFO_SPACE_AVAIL(ppdev, pbase, level) \
|
|
(M32_IW((pbase), EXT_FIFO_STATUS) & (0x10000L >> (level))) \
|
|
|
|
#endif
|
|
|
|
|
|
// Wait for engine idle. These macros are used to work around timing
|
|
// problems due to flakey hardware.
|
|
|
|
#define vM64QuietDown(ppdev,pjBase) \
|
|
{ \
|
|
M64_CHECK_FIFO_SPACE(ppdev, pjBase, 16); \
|
|
CP_EIEIO(); \
|
|
do {} while (M64_ID(pjBase, GUI_STAT) & 1); \
|
|
}
|
|
|
|
#define vM32QuietDown(ppdev,pjBase) \
|
|
{ \
|
|
M32_CHECK_FIFO_SPACE(ppdev, pjBase, 16); \
|
|
do {} while (M32_IW(pjBase, EXT_GE_STATUS) & GE_ACTIVE); \
|
|
}
|
|
|
|
#define vI32QuietDown(ppdev,pjBase) \
|
|
{ \
|
|
I32_CHECK_FIFO_SPACE(ppdev, pjBase, 16); \
|
|
do {} while (I32_IW(pjBase, EXT_GE_STATUS) & GE_ACTIVE); \
|
|
}
|
|
|
|
// DDraw macros
|
|
|
|
#define IN_VBLANK_64( pjMmBase )(M64_ID (pjMmBase, CRTC_INT_CNTL ) & CRTC_VBLANK)
|
|
#define CURRENT_VLINE_64( pjMmBase)((WORD)(M64_ID(pjMmBase,CRTC_CRNT_VLINE)>>16))
|
|
#define DRAW_ENGINE_BUSY_64( ppdev, pjMmBase) (((M64_FIFO_SPACE_AVAIL(ppdev,pjMmBase, 16 )) || ((M64_ID(pjMmBase, GUI_STAT)) & GUI_ACTIVE)))
|
|
|
|
// the next define is for overlay support
|
|
#define DD_WriteVTReg(port,val) { \
|
|
WRITE_REGISTER_ULONG((ULONG*) ppdev->pjMmBase_Ext + (port), (val)); \
|
|
CP_MEMORY_BARRIER(); \
|
|
}
|
|
|
|
// Special I/O routines to read DAC regs on the mach64 (for relocatable I/O)
|
|
|
|
#define rioIB(port) READ_PORT_UCHAR((port))
|
|
#define rioOB(port, val) WRITE_PORT_UCHAR((port), (val))
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
// Context Stuff
|
|
//
|
|
// Default context used to initialize the hardware before graphics operations.
|
|
// Certain registers, such as DP_WRITE_MASK and CLR_CMP_CNTL, need to be reset
|
|
// because they fail to latch properly after a blit operation. Mach64 only.
|
|
|
|
VOID vSetDefaultContext(PDEV * ppdev);
|
|
VOID vEnableContexts(PDEV * ppdev);
|
|
|
|
// For overlay support
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// DirectDraw stuff
|
|
|
|
#define IS_RGB15_R(flRed) \
|
|
(flRed == 0x7c00)
|
|
|
|
#define IS_RGB15(this) \
|
|
(((this)->dwRBitMask == 0x7c00) && \
|
|
((this)->dwGBitMask == 0x03e0) && \
|
|
((this)->dwBBitMask == 0x001f))
|
|
|
|
#define IS_RGB16(this) \
|
|
(((this)->dwRBitMask == 0xf800) && \
|
|
((this)->dwGBitMask == 0x07e0) && \
|
|
((this)->dwBBitMask == 0x001f))
|
|
|
|
#define IS_RGB24(this) \
|
|
(((this)->dwRBitMask == 0x00ff0000) && \
|
|
((this)->dwGBitMask == 0x0000ff00) && \
|
|
((this)->dwBBitMask == 0x000000ff))
|
|
|
|
#define IS_RGB32(this) \
|
|
(((this)->dwRBitMask == 0x00ff0000) && \
|
|
((this)->dwGBitMask == 0x0000ff00) && \
|
|
((this)->dwBBitMask == 0x000000ff))
|
|
|
|
#define RGB15to32(c) \
|
|
(((c & 0x7c00) << 9) | \
|
|
((c & 0x03e0) << 6) | \
|
|
((c & 0x001f) << 3))
|
|
|
|
#define RGB16to32(c) \
|
|
(((c & 0xf800) << 8) | \
|
|
((c & 0x07e0) << 5) | \
|
|
((c & 0x001f) << 3))
|
|
// end macros for overlay support
|
|
|
|
|