Leaked source code of windows server 2003
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.
|
|
;---------------------------- Include File Header ---------------------------; ; Module Name: hw.inc ; ; All the hardware specific driver file stuff. Mirrors some of 'hw.h'. ; ; Copyright (c) 1993-1994 Microsoft Corporation ;----------------------------------------------------------------------------;
; ////////////////////////////////////////////////////////////////////////
; // Chip equates:
STATUS_1 equ 03DAh VSY_NOT equ 08h
CRTC_INDEX equ 03D4h CRTC_DATA equ 03D5h
S3R8 equ 038h S3R9 equ 039h S3R1 equ 031h S3R5 equ 035h
CR39 equ 039h CR4C equ 04Ch CR4D equ 04Dh
HGC_MODE equ 045h HGC_ENABLE equ 001h HGC_DISABLE equ 000h
HGC_ORGX_LSB equ 047h HGC_ORGX_MSB equ 046h HGC_ORGY_LSB equ 049h HGC_ORGY_MSB equ 048h
HGC_DX equ 04Eh HGC_DY equ 04Fh
REG_UNLOCK_1 equ 048h CPUA_BASE equ 001h
SYSCTL_UNLOCK equ 0A0h SYSCTL_LOCK equ 000h
SYS_CNFG equ 040h LAW_CTL equ 058h EX_SCTL_2 equ 051h EX_DAC_CT equ 055h
MISC_1 equ 03Ah
; Command types:
DRAW_LINE equ 02000h RECTANGLE_FILL equ 04000h BITBLT equ 0C000h PATTERN_FILL equ 0E000h
BYTE_SWAP equ 01000h BUS_SIZE_16 equ 00200h BUS_SIZE_8 equ 00000h WAIT_CPU equ 00100h
; Drawing directions (radial):
DRAWING_DIRECTION_0 equ 0000h DRAWING_DIRECTION_45 equ 0020h DRAWING_DIRECTION_90 equ 0040h DRAWING_DIRECTION_135 equ 0060h DRAWING_DIRECTION_180 equ 0080h DRAWING_DIRECTION_225 equ 00A0h DRAWING_DIRECTION_270 equ 00C0h DRAWING_DIRECTION_315 equ 00E0h
; Drawing directions (x/y):
DRAWING_DIR_BTRLXM equ 0000h DRAWING_DIR_BTLRXM equ 0020h DRAWING_DIR_BTRLYM equ 0040h DRAWING_DIR_BTLRYM equ 0060h DRAWING_DIR_TBRLXM equ 0080h DRAWING_DIR_TBLRXM equ 00A0h DRAWING_DIR_TBRLYM equ 00C0h DRAWING_DIR_TBLRYM equ 00E0h
; Drawing direction bits:
PLUS_X equ 0020h PLUS_Y equ 0080h MAJOR_Y equ 0040h
; Draw:
DRAW equ 0010h
; Direction type:
DIR_TYPE_RADIAL equ 0008h DIR_TYPE_XY equ 0000h
; Last pixel:
LAST_PIXEL_OFF equ 0004h LAST_PIXEL_ON equ 0000h
; Pixel mode:
MULTIPLE_PIXELS equ 0002h SINGLE_PIXEL equ 0000h
; Read/write:
READ equ 0000h WRITE equ 0001h
; Graphics processor status:
HARDWARE_BUSY equ 0200h READ_DATA_AVAILABLE equ 0100h GP_ALL_EMPTY equ 0400h
; Fifo status in terms of empty entries:
FIFO_1_EMPTY equ 0080h FIFO_2_EMPTY equ 0040h FIFO_3_EMPTY equ 0020h FIFO_4_EMPTY equ 0010h FIFO_5_EMPTY equ 0008h FIFO_6_EMPTY equ 0004h FIFO_7_EMPTY equ 0002h FIFO_8_EMPTY equ 0001h
; These are the defines for the multifunction control register. ; The 4 MSBs define the function of the register.
RECT_HEIGHT equ 00000h
CLIP_TOP equ 01000h CLIP_LEFT equ 02000h CLIP_BOTTOM equ 03000h CLIP_RIGHT equ 04000h
DATA_EXTENSION equ 0A000h MULT_MISC_INDEX equ 0E000h READ_SEL_INDEX equ 0F000h
ALL_ONES equ 00000h CPU_DATA equ 00080h DISPLAY_MEMORY equ 000C0h
; Colour source:
BACKGROUND_COLOR equ 000h FOREGROUND_COLOR equ 020h SRC_CPU_DATA equ 040h SRC_DISPLAY_MEMORY equ 060h
; Mix modes:
NOT_SCREEN equ 00h LOGICAL_0 equ 01h LOGICAL_1 equ 02h LEAVE_ALONE equ 03h NOT_NEW equ 04h SCREEN_XOR_NEW equ 05h NOT_SCREEN_XOR_NEW equ 06h OVERPAINT equ 07h NOT_SCREEN_OR_NOT_NEW equ 08h SCREEN_OR_NOT_NEW equ 09h NOT_SCREEN_OR_NEW equ 0Ah SCREEN_OR_NEW equ 0Bh SCREEN_AND_NEW equ 0Ch NOT_SCREEN_AND_NEW equ 0Dh SCREEN_AND_NOT_NEW equ 0Eh NOT_SCREEN_AND_NOT_NEW equ 0Fh
; When one of the following bits is set in a hardware mix, it means ; that a pattern is needed (i.e., is none of NOT_SCREEN, LOGICAL_0, ; LOGICAL_1 or LEAVE_ALONE):
MIX_NEEDSPATTERN equ 0Ch
; ////////////////////////////////////////////////////////////////////
; // S3 port control
; ////////////////////////////////////////////////////////////////////
; Accelerator port addresses:
CUR_Y equ 082E8h CUR_X equ 086E8h DEST_Y equ 08AE8h DEST_X equ 08EE8h AXSTP equ 08AE8h DIASTP equ 08EE8h ERR_TERM equ 092E8h MAJ_AXIS_PCNT equ 096E8h CMD equ 09AE8h SHORT_STROKE equ 09EE8h BKGD_COLOR equ 0A2E8h FRGD_COLOR equ 0A6E8h WRT_MASK equ 0AAE8h RD_MASK equ 0AEE8h COLOR_CMP equ 0B2E8h BKGD_MIX equ 0B6E8h FRGD_MIX equ 0BAE8h MULTIFUNC_CNTL equ 0BEE8h MIN_AXIS_PCNT equ 0BEE8h SCISSORS_T equ 0BEE8h SCISSORS_L equ 0BEE8h SCISSORS_B equ 0BEE8h SCISSORS_R equ 0BEE8h PIX_CNTL equ 0BEE8h PIX_TRANS equ 0E2E8h
|