Source code of Windows XP (NT5)
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.
|
|
/****************************************************************************
DVA surface provider for Chicago DIBENG
***************************************************************************/
#include <windows.h>
#include "dva.h"
#include "dibeng.inc"
#include "lockbm.h"
#define RP_TYPE 0x5250 // 'RP'
// stuff in DVAVGA.C
extern HDC hdcScreen; extern BOOL FAR PASCAL _loadds vga_open_surface(LPVOID pv); extern void FAR PASCAL _loadds vga_close_surface(LPVOID pv);
/****************************************************************************
***************************************************************************/
BOOL CALLBACK dib_open_surface(LPVOID pv) { return TRUE; }
/****************************************************************************
***************************************************************************/
void CALLBACK dib_close_surface(LPVOID pv) { }
/****************************************************************************
***************************************************************************/
BOOL CALLBACK dib_begin_access(LPVOID pv, int x, int y, int AccessDX, int AccessDY) { //
// on some SVGAs with 8514 like accelerators, a command Que may need to
// be flushed before touching video memory.
//
// mini drivers should not need this "handholding" but the S3 driver
// does
//
if (hdcScreen) GetPixel(hdcScreen, x, y);
_asm { push ds ; push si ; push di
lds bx,pv
xor ax,ax test [bx].deFlags,DISABLED jnz exit
mov cx,x mov dx,y mov si,cx add si,AccessDX mov di,y add di,AccessDY call dword ptr [bx].deCursorExclude mov ax,1 exit: ; pop di ; pop si pop ds } }
/****************************************************************************
***************************************************************************/
void FAR PASCAL dib_end_access(LPVOID pv) { _asm { push ds lds bx,pv call dword ptr [bx].deCursorUnexclude pop ds } }
/****************************************************************************
***************************************************************************/
BOOL dib_get_surface(HDC hdc, int nSurface, DVASURFACEINFO FAR *pdva) { DIBENGINE FAR *pde; LPBITMAPINFOHEADER lpbi;
if (nSurface != 0) return FALSE;
pde = (DIBENGINE FAR *)GetPDevice(hdc);
if (pde == NULL || pde->deType != RP_TYPE || pde->dePlanes != 1 || pde->deVersion != 0x0400) return FALSE;
lpbi = &pdva->BitmapInfo;
hmemcpy(lpbi, pde->deBitmapInfo, sizeof(BITMAPINFOHEADER));
if (lpbi->biCompression != 0 && lpbi->biCompression != BI_BITFIELDS) return FALSE;
pdva->selSurface = pde->deBitsSelector; pdva->offSurface = pde->deBitsOffset; pdva->Flags = 0; pdva->Version = 0x0100; pdva->lpSurface = (LPVOID)pde; (FARPROC)pdva->OpenSurface = (FARPROC)vga_open_surface; (FARPROC)pdva->CloseSurface = (FARPROC)vga_close_surface; (FARPROC)pdva->BeginAccess = (FARPROC)dib_begin_access; (FARPROC)pdva->EndAccess = (FARPROC)dib_end_access; (FARPROC)pdva->ShowSurface = (FARPROC)NULL;
if (!(pde->deFlags & CURSOREXCLUDE)) { pdva->BeginAccess = NULL; pdva->EndAccess = NULL; }
if (pde->deDeltaScan > 0) { lpbi->biWidth = (int)pde->deDeltaScan * 8 / (int)pde->deBitsPixel; lpbi->biHeight =-(int)pde->deHeight; lpbi->biSizeImage = pde->deDeltaScan * pde->deHeight; } else { lpbi->biWidth = -(int)pde->deDeltaScan * 8 / (int)pde->deBitsPixel; lpbi->biHeight = (int)pde->deHeight; lpbi->biSizeImage = -(int)pde->deDeltaScan * pde->deHeight;
pdva->offSurface += (long)pde->deDeltaScan * (long)pde->deHeight-1; }
//
// mark the surface as 16:32 pointer access ONLY!
//
if (pde->deFlags & BANKEDVRAM) pdva->Flags |= DVAF_1632_ACCESS;
return TRUE; }
|