windows-nt/Source/XPSP1/NT/multimedia/media/avi/drawdib/dva/dvadib.c

155 lines
4 KiB
C
Raw Permalink Normal View History

2020-09-26 03:20:57 -05:00
/****************************************************************************
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;
}