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.
236 lines
11 KiB
236 lines
11 KiB
;---------------------------Module-Header------------------------------;
|
|
; Module Name: driver.inc
|
|
;
|
|
; Contains prototypes for the 256 colour VGA driver.
|
|
;
|
|
; NOTE: Must mirror driver.h!
|
|
;
|
|
; Copyright (c) 1992 Microsoft Corporation
|
|
;-----------------------------------------------------------------------;
|
|
|
|
; Sizes assumed for 1-window and 2 RW-window banks.
|
|
|
|
BANK_SIZE_1_WINDOW equ 10000h
|
|
BANK_SIZE_2RW_WINDOW equ 8000h
|
|
|
|
; Specifies desired justification for requestion scan line within bank window
|
|
|
|
JustifyTop equ 0
|
|
JustifyBottom equ 1
|
|
|
|
; Specifies which window is to be mapped by two-window bank handler.
|
|
|
|
MapSourceBank equ 0
|
|
MapDestBank equ 1
|
|
|
|
;------------------------------------------------------------------------;
|
|
|
|
; Miscellaneous driver flags
|
|
|
|
DRIVER_PLANAR_CAPABLE equ 1
|
|
DRIVER_OFFSCREEN_REFRESHED equ 2
|
|
DRIVER_HAS_OFFSCREEN equ 4
|
|
|
|
; Bank status flags
|
|
|
|
BANK_BROKEN_RASTER1 equ 1 ; If bank1 or read bank has broken raster
|
|
BANK_BROKEN_RASTER2 equ 2 ; If bank2 or write bank has broken raster
|
|
BANK_BROKEN_RASTERS equ (BANK_BROKEN_RASTER1 + BANK_BROKEN_RASTER2)
|
|
|
|
;------------------------------------------------------------------------;
|
|
; Structures for maintaining a realized brush:
|
|
|
|
RBRUSH_BLACKWHITE equ 001h ; Black and white brush
|
|
RBRUSH_2COLOR equ 002h ; 2 color brush
|
|
RBRUSH_NCOLOR equ 004h ; n color brush
|
|
RBRUSH_4PELS_WIDE equ 008h ; Brush is 4xN
|
|
|
|
BRUSH_SIZE equ 64 ; An 8x8 8bpp brush needs 64 bytes
|
|
|
|
RBRUSH struc
|
|
rb_fl dd ? ; Flags
|
|
rb_xBrush dd ? ; Realized brush's x brush origin
|
|
; Pattern in planar format
|
|
rb_ulFgColor dd ? ; Foreground color for 2-color
|
|
rb_ulBkColor dd ? ; Background color for 2-color
|
|
rb_cy dd ? ; Height of pattern
|
|
rb_cyLog2 dd ? ; log2 of height
|
|
rb_iCache dd ? ; Cache entry index; 0 not valid
|
|
rb_aulPattern dd (BRUSH_SIZE / 4) dup (?)
|
|
RBRUSH ends
|
|
|
|
BRUSHCACHEENTRY struc
|
|
bce_prbVerifyRealization dd ? ; For verifying cache entry valid
|
|
bce_yCache dd ? ; Scan where entry's bits live
|
|
bce_ulCache dd ? ; Planar (!) offset to cache entry
|
|
BRUSHCACHEENTRY ends
|
|
|
|
;------------------------------------------------------------------------;
|
|
; The Physical Device data structure.
|
|
|
|
PDEV struc
|
|
pdev_fl dd ? ; Driver flags
|
|
pdev_hDriver dd ? ; Handle to \Device\Screen
|
|
pdev_hdevEng dd ? ; Engine's handle to PDEV
|
|
pdev_hsurfEng dd ? ; Engine's handle to surface
|
|
pdev_hsurfBm dd ? ; Handle to the "punt" surface
|
|
pdev_pSurfObj dd ? ; Pointer to the locked "punt" surface
|
|
|
|
pdev_hpalDefault dd ? ; Handle to the default palette for device.
|
|
|
|
pdev_pjScreen dd ? ; This is pointer to base screen address
|
|
pdev_cxScreen dd ? ; Visible screen width
|
|
pdev_cyScreen dd ? ; Visible screen height
|
|
pdev_ulMode dd ? ; Mode in which the mini-port driver is
|
|
pdev_lDeltaScreen dd ? ; Distance from one scan to the next
|
|
|
|
pdev_flRed dd ? ; For bitfields device, Red Mask
|
|
pdev_flGreen dd ? ; For bitfields device, Green Mask
|
|
pdev_flBlue dd ? ; For bitfields device, Blue Mask
|
|
pdev_cPaletteShift dd ? ; Number of bits the palette must be shifted by
|
|
pdev_ulBitCount dd ? ; # of bits per pel 8,16 are only supported
|
|
|
|
pdev_ulrm0_wmX dd ? ; Values to set GC5 to to select read mode
|
|
; 0 together with write modes 0-3
|
|
|
|
pdev_pjGlyphFlipTableBase dd ? ; Base allocated address for flip table;
|
|
; the pointer we use is this pointer
|
|
; rounded up to the nearest 256-byte
|
|
; boundary
|
|
pdev_pjGlyphFlipTable dd ? ; Pointer to table used to flip glyph bits
|
|
; 0-3 and 4-7
|
|
|
|
pdev_pPal dd ? ; If this is pal managed, this is the pal
|
|
|
|
; Off Screen Save Stuff:
|
|
|
|
pdev_hbmTmp dd ? ; Handle to temporary buffer
|
|
pdev_psoTmp dd ? ; Temporary surface
|
|
|
|
; DCI:
|
|
|
|
pdev_bSupportDCI dd ? ; Does miniport support DCI?
|
|
|
|
; Brush cache:
|
|
|
|
pdev_iCache dd ? ; Index for last brush to be allocated
|
|
pdev_iCacheLast dd ? ; Last valid cache index
|
|
pdev_pbceCache dd ? ; Pointer to allocated cache
|
|
|
|
; Saved screen bits stuff
|
|
pdev_rclSavedBitsRight dd ?,?,?,? ; right rect of vga memory that's unused
|
|
pdev_rclSavedBitsBottom dd ?,?,?,? ; bottom rect of vga memory that's unused
|
|
pdev_bBitsSaved dd ? ; TRUE if bits are currently saved
|
|
|
|
; Bank manager stuff common between planar and non-planar modes:
|
|
|
|
pdev_cTotalScans dd ? ; Number of usable on & off screen scans
|
|
pdev_pBankInfo dd ? ; Bank info for current mode
|
|
pdev_flBank dd ? ; Flags for current bank state
|
|
pdev_ulBitmapSize dd ? ; Length of bitmap if there were no
|
|
; banking, in CPU addressable bytes
|
|
|
|
pdev_ulWindowBank dd ?,? ; Current banks mapped into windows
|
|
; 0 & 1 (used in 2 window mode only)
|
|
|
|
pdev_pvBitmapStart dd ? ; Single-window bitmap start pointer
|
|
; (adjusted as necessary to make
|
|
; window map in at proper offset)
|
|
pdev_pvBitmapStart2Window dd ?,? ; Double-window window 0 and 1 bitmap
|
|
; start
|
|
|
|
; Non-planar mode specific bank management control stuff:
|
|
|
|
pdev_vbtBankingType dd ? ; Type of banking
|
|
pdev_pfnBankSwitchCode dd ? ; Pointer to bank switch code
|
|
pdev_lNextScan dd ? ; Offset to next bank in bytes
|
|
pdev_pjJustifyTopBank dd ? ; Pointer to lookup table for
|
|
; converting scans to banks
|
|
pdev_pbiBankInfo dd ? ; Pointer to array of bank clip info
|
|
pdev_ulJustifyBottomOffset dd ? ; Number of scans from top to bottom
|
|
; of bank, for bottom justifying
|
|
pdev_iLastBank dd ? ; Index of last valid bank in
|
|
pdev_ulBank2RWSkip dd ? ; Offset from one bank index to next
|
|
; to make two 32K banks appear to be
|
|
; one seamless 64K bank
|
|
|
|
pdev_pfnBankControl dd ? ; Pointer to bank control function
|
|
pdev_pfnBankControl2Window dd ? ; Pointer to double-window bank
|
|
; control function
|
|
|
|
pdev_pfnBankNext dd ? ; Pointer to next bank function
|
|
pdev_pfnBankNext2Window dd ? ; Pointer to double-window next bank
|
|
; function
|
|
pdev_rcl1WindowClip db (size RECTL) dup (?)
|
|
; Single-window banking clip rect
|
|
pdev_rcl2WindowClip db (2*(size RECTL)) dup (?)
|
|
; Double-window banking clip rects for
|
|
; windows 0 & 1
|
|
|
|
; Planar mode specific bank management control stuff:
|
|
|
|
pdev_vbtPlanarType dd ? ; Type of planar banking
|
|
pdev_pfnPlanarSwitchCode dd ? ; Pointer to planar bank switch code
|
|
pdev_lPlanarNextScan dd ? ; Offset to next planar bank in bytes
|
|
pdev_pjJustifyTopPlanar dd ? ; Pointer to lookup table for
|
|
; converting scans to planar banks
|
|
pdev_pbiPlanarInfo dd ? ; Pointer to array of bank clip info
|
|
pdev_ulPlanarBottomOffset dd ? ; Number of scans from top to bottom
|
|
; of bank, for bottom justifying
|
|
pdev_iLastPlanar dd ? ; Index of last valid bank in
|
|
pdev_ulPlanar2RWSkip dd ? ; Offset from one bank index to next
|
|
; to make two 32K banks appear to be
|
|
; one seamless 64K bank
|
|
|
|
pdev_pfnPlanarControl dd ? ; Pointer to bank control function
|
|
pdev_pfnPlanarControl2 dd ? ; Pointer to double-window bank
|
|
; control function
|
|
|
|
pdev_pfnPlanarNext dd ? ; Pointer to next bank function
|
|
pdev_pfnPlanarNext2 dd ? ; Pointer to double-window next bank
|
|
; function
|
|
pdev_rcl1PlanarClip db (size RECTL) dup (?)
|
|
; Single-window banking clip rect
|
|
pdev_rcl2PlanarClip db (2*(size RECTL)) dup (?)
|
|
; Double-window banking clip rects for
|
|
|
|
pdev_pfnPlanarEnable dd ? ; Function to enable planar mode
|
|
pdev_pfnPlanarDisable dd ? ; Function to disable planar mode
|
|
|
|
; Smart bank management stuff:
|
|
|
|
pdev_iLastScan dd ? ; Last scan we want to enumerate
|
|
pdev_pvScanScan0 dd ? ; Surface's original pvScan0
|
|
pdev_rclSaveBounds db (size RECTL) dup (?)
|
|
; Clip object's original bounds
|
|
pdev_pcoNull dd ? ; Pointer to empty clip object
|
|
pdev_iSaveDComplexity db ? ; Clip object's original complexity
|
|
pdev_fjSaveOptions db ? ; Clip object's original flags
|
|
pdev_ajFiller db ?,? ; Pack to dword alignment
|
|
|
|
pdev_pvTmpBuf dd ? ; Ptr to buffer attached to pdev
|
|
PDEV ends
|
|
|
|
pdev_rcl2WindowClipS equ (pdev_rcl2WindowClip)
|
|
pdev_rcl2WindowClipD equ (pdev_rcl2WindowClip + (size RECTL))
|
|
|
|
pdev_rcl2PlanarClipS equ (pdev_rcl2PlanarClip)
|
|
pdev_rcl2PlanarClipD equ (pdev_rcl2PlanarClip + (size RECTL))
|
|
|
|
pdev_pvBitmapStart2WindowS equ (pdev_pvBitmapStart2Window)
|
|
pdev_pvBitmapStart2WindowD equ (pdev_pvBitmapStart2Window + dword)
|
|
|
|
;------------------------------------------------------------------------;
|
|
|
|
; Macro to do a simple RET, with no stack stuff, in a proc.
|
|
|
|
PLAIN_RET macro
|
|
db 0c3h
|
|
endm
|
|
|
|
; Macro to replace a CALL followed immediately by a JMP:
|
|
|
|
CALL_AND_JUMP macro CALL_ADDR,JUMP_ADDR
|
|
push offset JUMP_ADDR
|
|
jmp CALL_ADDR
|
|
endm
|