mirror of
https://github.com/reactos/reactos.git
synced 2025-05-14 14:56:44 +00:00
- update EDD_DIRECTDRAW_LOCAL, EDD_SURFACE and EDD_DIRECTDRAW_GLOBAL structures
- initial implementation of DxDdCreateD3DBuffer and DxDdCreateSurfaceObject CORE-4490 svn path=/trunk/; revision=75189
This commit is contained in:
parent
292f51e33a
commit
9cb674f17f
6 changed files with 211 additions and 54 deletions
|
@ -15,9 +15,9 @@ typedef struct _EDD_DIRECTDRAW_LOCAL
|
|||
//
|
||||
/* 0x00 */ DD_BASEOBJECT pobj; // verified to match Windows XP
|
||||
/* 0x10 */ struct _EDD_DIRECTDRAW_GLOBAL * peDirectDrawGlobal; // verified to match Windows XP
|
||||
/* 0x14 */ struct _EDD_SURFACE * peSurface_DdList;
|
||||
/* 0x18 */ ULONG unk_018;
|
||||
/* 0x1C */ ULONG unk_01c;
|
||||
/* 0x14 */ ULONG hRefCount;
|
||||
/* 0x18 */ struct _EDD_SURFACE * peSurface_DdList;
|
||||
/* 0x1C */ ULONG hSurface;
|
||||
/* 0x20 */ ULONG unk_020;
|
||||
/* 0x24 */ struct _EDD_DIRECTDRAW_GLOBAL * peDirectDrawGlobal2; // verified to match Windows XP
|
||||
/* 0x28 */ FLATPTR fpProcess;
|
||||
|
@ -26,9 +26,9 @@ typedef struct _EDD_DIRECTDRAW_LOCAL
|
|||
// points to the old DDLocal when new handle is created.
|
||||
/* 0x34 */ FLATPTR fpProcess2; // surface memory address returned by graphic driver
|
||||
/* 0x38 */ ULONG isMemoryMapped; // surface memory mapped?
|
||||
/* 0x3C */ HANDLE UniqueProcess;
|
||||
/* 0x3C */ HANDLE hCreatorProcess;
|
||||
/* 0x40 */ PEPROCESS Process;
|
||||
/* 0x44 */ VOID *unk_044;
|
||||
/* 0x44 */ VOID *heapList;
|
||||
/* 0x48 */ ULONG unk_048;
|
||||
/* 0x4C */ ULONG unk_04C;
|
||||
/* 0x50 */ ULONG unk_050;
|
||||
|
@ -68,13 +68,9 @@ typedef struct _EDD_SURFACE
|
|||
// Private Direct Draw Data
|
||||
//
|
||||
struct _EDD_DIRECTDRAW_GLOBAL* peDirectDrawGlobal;
|
||||
struct _EDD_DIRECTDRAW_GLOBAL* peDirectDrawGlobalNext;
|
||||
struct _EDD_DIRECTDRAW_LOCAL* peDirectDrawLocal;
|
||||
|
||||
//
|
||||
// Flags
|
||||
//
|
||||
FLONG fl;
|
||||
|
||||
//
|
||||
// Surface Attributes
|
||||
//
|
||||
|
@ -84,17 +80,23 @@ typedef struct _EDD_SURFACE
|
|||
HANDLE hSecure;
|
||||
HANDLE hdc;
|
||||
HBITMAP hbmGdi;
|
||||
|
||||
//
|
||||
// Unknown
|
||||
//
|
||||
ULONG field_E8;
|
||||
HANDLE hGdiSurface;
|
||||
|
||||
//
|
||||
// Surface Lock
|
||||
//
|
||||
RECTL rclLock;
|
||||
ULONG field_FC[2];
|
||||
ULONG field_FC;
|
||||
ULONG field_100;
|
||||
ULONG field_104;
|
||||
ULONG field_108;
|
||||
ULONG field_10C;
|
||||
|
||||
ULONG ldev;
|
||||
struct _EDD_DIRECTDRAW_GLOBAL* peDirectDrawGlobal3;
|
||||
ULONG gdev;
|
||||
ULONG wWidth;
|
||||
ULONG wHeight;
|
||||
} EDD_SURFACE, *PEDD_SURFACE;
|
||||
|
||||
|
||||
|
@ -118,7 +120,9 @@ typedef struct _EDD_DIRECTDRAW_GLOBAL
|
|||
/* 0x000 */ PVOID dhpdev; // 0x000 <-- verified to match Windows XP, dhpdev, the drv hPDev -->
|
||||
/* 0x004 */ DWORD dwReserved1;
|
||||
/* 0x008 */ DWORD dwReserved2;
|
||||
/* 0x00C */ ULONG unk_000c[3];
|
||||
/* 0x00C */ LPDDVIDEOPORTCAPS lpDDVideoPortCaps; // 0x00C <-- verified to match Win2k3
|
||||
/* 0x010 */ ULONG unk_010;
|
||||
/* 0x014 */ ULONG unk_014;
|
||||
/* 0x018 */ LONG cDriverReferences;
|
||||
/* 0x01C */ ULONG unk_01c;
|
||||
/* 0x020 */ DWORD dwCallbackFlags; /* 0x020 <-- verified to match Windows XP, dwCallbackFlags
|
||||
|
|
|
@ -37,3 +37,89 @@ DxDdCanCreateD3DBuffer(
|
|||
|
||||
return RetVal;
|
||||
}
|
||||
|
||||
DWORD
|
||||
FASTCALL
|
||||
intDdCreateSurfaceOrBuffer(HANDLE hDirectDrawLocal,
|
||||
PEDD_SURFACE pDdSurfList, DDSURFACEDESC2 *a3,
|
||||
DD_SURFACE_GLOBAL *pDdSurfGlob,
|
||||
DD_SURFACE_LOCAL *pDdSurfLoc,
|
||||
DD_SURFACE_MORE *pDdSurfMore,
|
||||
DD_CREATESURFACEDATA *pDdCreateSurfaceData,
|
||||
PVOID Address)
|
||||
{
|
||||
PEDD_DIRECTDRAW_LOCAL peDdL = NULL;
|
||||
PEDD_DIRECTDRAW_GLOBAL peDdGl = NULL;
|
||||
DD_SURFACE_LOCAL *pCurSurfLocal;
|
||||
DD_SURFACE_GLOBAL *pCurSurfGlobal;
|
||||
DD_SURFACE_MORE *pCurSurfMore;
|
||||
PEDD_SURFACE pCurSurf;
|
||||
|
||||
ULONG CurSurf;
|
||||
|
||||
if (!pDdCreateSurfaceData)
|
||||
return FALSE;
|
||||
|
||||
if (!pDdCreateSurfaceData->dwSCnt)
|
||||
{
|
||||
pDdCreateSurfaceData->ddRVal = E_FAIL;
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
peDdL = (PEDD_DIRECTDRAW_LOCAL)DdHmgLock(hDirectDrawLocal, ObjType_DDLOCAL_TYPE, FALSE);
|
||||
if (!peDdL)
|
||||
return FALSE;
|
||||
|
||||
peDdGl = peDdL->peDirectDrawGlobal2;
|
||||
|
||||
if (!(pDdSurfLoc->ddsCaps.dwCaps & DDSCAPS_VISIBLE) && !(peDdGl->ddCallbacks.dwFlags & DDHAL_CB32_CREATESURFACE))
|
||||
{
|
||||
pDdCreateSurfaceData->ddRVal = E_FAIL;
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
pDdSurfList = (PEDD_SURFACE)EngAllocMem(FL_ZERO_MEMORY, pDdCreateSurfaceData->dwSCnt * sizeof(EDD_SURFACE), TAG_GDDP);
|
||||
pDdSurfGlob = (DD_SURFACE_GLOBAL *)EngAllocMem(FL_ZERO_MEMORY, pDdCreateSurfaceData->dwSCnt * sizeof(DD_SURFACE_GLOBAL), TAG_GDDP);
|
||||
pDdSurfLoc = (DD_SURFACE_LOCAL *)EngAllocMem(FL_ZERO_MEMORY, pDdCreateSurfaceData->dwSCnt * sizeof(DD_SURFACE_LOCAL), TAG_GDDP);
|
||||
pDdSurfMore = (DD_SURFACE_MORE *)EngAllocMem(FL_ZERO_MEMORY, pDdCreateSurfaceData->dwSCnt * sizeof(DD_SURFACE_MORE), TAG_GDDP);
|
||||
|
||||
gpEngFuncs.DxEngLockShareSem();
|
||||
gpEngFuncs.DxEngLockHdev(peDdGl->hDev);
|
||||
|
||||
// create all surface objects
|
||||
for (CurSurf = 0; CurSurf < pDdCreateSurfaceData->dwSCnt; CurSurf++)
|
||||
{
|
||||
pCurSurf = &pDdSurfList[CurSurf];
|
||||
pCurSurfLocal = &pDdSurfLoc[CurSurf];
|
||||
pCurSurfGlobal = &pDdSurfGlob[CurSurf];
|
||||
pCurSurfMore = &pDdSurfMore[CurSurf];
|
||||
|
||||
pCurSurf = intDdCreateNewSurfaceObject(
|
||||
peDdL,
|
||||
pCurSurf,
|
||||
pCurSurfGlobal,
|
||||
pCurSurfLocal,
|
||||
pCurSurfMore);
|
||||
Address = pCurSurf;
|
||||
}
|
||||
|
||||
gpEngFuncs.DxEngUnlockHdev(peDdGl->hDev);
|
||||
gpEngFuncs.DxEngUnlockShareSem();
|
||||
|
||||
return DDHAL_DRIVER_HANDLED;
|
||||
}
|
||||
|
||||
DWORD
|
||||
NTAPI
|
||||
DxDdCreateD3DBuffer(
|
||||
HANDLE hDirectDrawLocal,
|
||||
PEDD_SURFACE pDdSurfList,
|
||||
DDSURFACEDESC2 *a3,
|
||||
DD_SURFACE_GLOBAL *pDdSurfGlob,
|
||||
DD_SURFACE_LOCAL *pDdSurfLoc,
|
||||
DD_SURFACE_MORE *pDdSurfMore,
|
||||
DD_CREATESURFACEDATA *pDdCreateSurfaceData,
|
||||
PVOID Address)
|
||||
{
|
||||
return intDdCreateSurfaceOrBuffer(hDirectDrawLocal, pDdSurfList, a3, pDdSurfGlob, pDdSurfLoc, pDdSurfMore, pDdCreateSurfaceData, Address);
|
||||
}
|
||||
|
|
|
@ -223,7 +223,7 @@ intDdCreateDirectDrawLocal(HDEV hDev)
|
|||
|
||||
/* initialize DIRECTDRAW_LOCAL */
|
||||
peDdL->peDirectDrawLocal_prev = peDdGl->peDirectDrawLocalList;
|
||||
peDdL->UniqueProcess = PsGetCurrentThreadProcessId();
|
||||
peDdL->hCreatorProcess = PsGetCurrentThreadProcessId();
|
||||
peDdL->Process = PsGetCurrentProcess();
|
||||
|
||||
// link DirectDrawGlobal and DirectDrawLocal
|
||||
|
@ -233,7 +233,7 @@ intDdCreateDirectDrawLocal(HDEV hDev)
|
|||
|
||||
gpEngFuncs.DxEngReferenceHdev(hDev);
|
||||
|
||||
InterlockedExchangeAdd((LONG*)&peDdL->pobj.cExclusiveLock, 0xFFFFFFFF);
|
||||
InterlockedDecrement((VOID*)&peDdL->pobj.cExclusiveLock);
|
||||
|
||||
return peDdL->pobj.hHmgr;
|
||||
}
|
||||
|
@ -331,7 +331,7 @@ DxDdGetDriverInfo(HANDLE DdHandle, PDD_GETDRIVERINFODATA drvInfoData)
|
|||
}
|
||||
if (InlineIsEqualGUID(&drvInfoData->guidInfo, &GUID_VideoPortCaps))
|
||||
{
|
||||
pInfo = (VOID*)peDdGl->unk_000c[0];
|
||||
pInfo = (VOID*)peDdGl->lpDDVideoPortCaps;
|
||||
dwInfoSize = 72 * peDdGl->ddHalInfo.ddCaps.dwMaxVideoPorts;
|
||||
}
|
||||
if (InlineIsEqualGUID(&drvInfoData->guidInfo, &GUID_D3DCallbacks3))
|
||||
|
@ -462,13 +462,13 @@ DxDdQueryDirectDrawObject(
|
|||
*(DWORD*)((ULONG)pCallBackFlags + 8) = peDdGl->ddPaletteCallbacks.dwFlags;
|
||||
}
|
||||
|
||||
if ( pd3dNtHalCallbacks )
|
||||
if (pd3dNtHalCallbacks)
|
||||
memcpy(pd3dNtHalCallbacks, &peDdGl->d3dNtHalCallbacks, sizeof(peDdGl->d3dNtHalCallbacks));
|
||||
|
||||
if ( pd3dNtGlobalDriverData )
|
||||
if (pd3dNtGlobalDriverData)
|
||||
memcpy(pd3dNtGlobalDriverData, &peDdGl->d3dNtGlobalDriverData, sizeof(peDdGl->d3dNtGlobalDriverData));
|
||||
|
||||
if ( pd3dBufCallbacks )
|
||||
if (pd3dBufCallbacks)
|
||||
memcpy(pd3dBufCallbacks, &peDdGl->d3dBufCallbacks, sizeof(peDdGl->d3dBufCallbacks));
|
||||
|
||||
if (pTextureFormats)
|
||||
|
@ -581,3 +581,95 @@ DxDdReenableDirectDrawObject(
|
|||
|
||||
return RetVal;
|
||||
}
|
||||
|
||||
PEDD_SURFACE
|
||||
NTAPI
|
||||
intDdCreateNewSurfaceObject(PEDD_DIRECTDRAW_LOCAL peDdL, HANDLE hDirectDrawLocal, PDD_SURFACE_GLOBAL pDdSurfGlob, PDD_SURFACE_LOCAL pDdSurfLoc, PDD_SURFACE_MORE pDdSurfMore)
|
||||
{
|
||||
PEDD_SURFACE pSurface = NULL;
|
||||
|
||||
// first check if we can assign it from current ddHandle
|
||||
if (hDirectDrawLocal)
|
||||
{
|
||||
pSurface = (PEDD_SURFACE)DdHmgLock(hDirectDrawLocal, ObjType_DDSURFACE_TYPE, FALSE);
|
||||
// check if surface is locked and belongs to correct DirectDrawLocal
|
||||
if ((pSurface)&&((pSurface->peDirectDrawLocal != peDdL)||(!pSurface->hSecure)))
|
||||
{
|
||||
InterlockedDecrement((VOID*)&peDdL->pobj.cExclusiveLock);
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
// if surface not found from ddHandle or ddHandle not provided
|
||||
if (!pSurface)
|
||||
{
|
||||
// create new surface object
|
||||
pSurface = (PEDD_SURFACE)DdHmgAlloc(sizeof(EDD_SURFACE), ObjType_DDSURFACE_TYPE, TRUE);
|
||||
if (pSurface)
|
||||
{
|
||||
pSurface->ddsSurfaceLocal.lpGbl = &pSurface->ddsSurfaceGlobal;
|
||||
pSurface->ddsSurfaceLocal.lpSurfMore = &pSurface->ddsSurfaceMore;
|
||||
pSurface->ddsSurfaceInt.lpLcl = &pSurface->ddsSurfaceLocal;
|
||||
pSurface->peDirectDrawLocal = peDdL;
|
||||
pSurface->peDirectDrawGlobalNext = peDdL->peDirectDrawGlobal2;
|
||||
pSurface->ldev = gpEngFuncs.DxEngGetHdevData(pSurface->peDirectDrawGlobalNext->hDev, DxEGShDevData_ldev);
|
||||
pSurface->gdev = gpEngFuncs.DxEngGetHdevData(pSurface->peDirectDrawGlobalNext->hDev, DxEGShDevData_GDev);
|
||||
pSurface->hSecure = (VOID*)1;
|
||||
}
|
||||
}
|
||||
|
||||
if (pSurface)
|
||||
{
|
||||
pSurface->ddsSurfaceGlobal.fpVidMem = pDdSurfGlob->fpVidMem;
|
||||
pSurface->ddsSurfaceGlobal.lPitch = pDdSurfGlob->lPitch;
|
||||
pSurface->ddsSurfaceGlobal.wWidth = pDdSurfGlob->wWidth;
|
||||
pSurface->ddsSurfaceGlobal.wHeight = pDdSurfGlob->wHeight;
|
||||
pSurface->wWidth = pDdSurfGlob->wWidth;
|
||||
pSurface->wHeight = pDdSurfGlob->wHeight;
|
||||
memcpy(&pSurface->ddsSurfaceGlobal.ddpfSurface, &pDdSurfGlob->ddpfSurface, sizeof(pSurface->ddsSurfaceGlobal.ddpfSurface));
|
||||
pSurface->ddsSurfaceLocal.ddsCaps.dwCaps = pDdSurfLoc->ddsCaps.dwCaps;
|
||||
pSurface->ddsSurfaceMore.ddsCapsEx.dwCaps2 = pDdSurfMore->ddsCapsEx.dwCaps2;
|
||||
pSurface->ddsSurfaceMore.ddsCapsEx.dwCaps3 = pDdSurfMore->ddsCapsEx.dwCaps3;
|
||||
pSurface->ddsSurfaceMore.ddsCapsEx.dwCaps4 = pDdSurfMore->ddsCapsEx.dwCaps4;
|
||||
pSurface->ddsSurfaceMore.dwSurfaceHandle = pDdSurfMore->dwSurfaceHandle;
|
||||
pSurface->hSecure = (VOID*)1;
|
||||
|
||||
peDdL->peSurface_DdList = pSurface;
|
||||
peDdL->hSurface = (ULONG)pSurface->pobj.hHmgr;
|
||||
}
|
||||
|
||||
return pSurface;
|
||||
}
|
||||
|
||||
HANDLE
|
||||
NTAPI
|
||||
DxDdCreateSurfaceObject(HANDLE hDirectDrawLocal,
|
||||
HANDLE hSurface,
|
||||
PDD_SURFACE_LOCAL puSurfaceLocal,
|
||||
PDD_SURFACE_MORE puSurfaceMore,
|
||||
PDD_SURFACE_GLOBAL puSurfaceGlobal,
|
||||
BOOL bComplete)
|
||||
{
|
||||
HANDLE RetVal = FALSE;
|
||||
PEDD_DIRECTDRAW_LOCAL peDdL = NULL;
|
||||
PEDD_SURFACE pDdSurface = NULL;
|
||||
|
||||
peDdL = (PEDD_DIRECTDRAW_LOCAL)DdHmgLock(hDirectDrawLocal, ObjType_DDLOCAL_TYPE, FALSE);
|
||||
|
||||
if (!peDdL)
|
||||
return RetVal;
|
||||
|
||||
pDdSurface = intDdCreateNewSurfaceObject(peDdL, hSurface, puSurfaceGlobal, puSurfaceLocal, puSurfaceMore);
|
||||
if (!pDdSurface)
|
||||
{
|
||||
InterlockedDecrement((VOID*)&peDdL->pobj.cExclusiveLock);
|
||||
return RetVal;
|
||||
}
|
||||
|
||||
RetVal = pDdSurface->pobj.hHmgr;
|
||||
|
||||
InterlockedDecrement((VOID*)&pDdSurface->pobj.cExclusiveLock);
|
||||
InterlockedDecrement((VOID*)&peDdL->pobj.cExclusiveLock);
|
||||
|
||||
return RetVal;
|
||||
}
|
||||
|
|
|
@ -129,22 +129,6 @@ DxDdColorControl(
|
|||
return 0;
|
||||
}
|
||||
|
||||
DWORD
|
||||
NTAPI
|
||||
DxDdCreateD3DBuffer(
|
||||
PVOID p1,
|
||||
PVOID p2,
|
||||
PVOID p3,
|
||||
PVOID p4,
|
||||
PVOID p5,
|
||||
PVOID p6,
|
||||
PVOID p7,
|
||||
PVOID p8)
|
||||
{
|
||||
TRACE();
|
||||
return 0;
|
||||
}
|
||||
|
||||
DWORD
|
||||
NTAPI
|
||||
DxDdCreateMoComp(
|
||||
|
@ -154,20 +138,6 @@ DxDdCreateMoComp(
|
|||
return 0;
|
||||
}
|
||||
|
||||
DWORD
|
||||
NTAPI
|
||||
DxDdCreateSurfaceObject(
|
||||
PVOID p1,
|
||||
PVOID p2,
|
||||
PVOID p3,
|
||||
PVOID p4,
|
||||
PVOID p5,
|
||||
PVOID p6)
|
||||
{
|
||||
TRACE();
|
||||
return 0;
|
||||
}
|
||||
|
||||
DWORD
|
||||
NTAPI
|
||||
DxDdDeleteDirectDrawObject(
|
||||
|
|
|
@ -202,8 +202,11 @@ BOOL NTAPI DxDdQueryDirectDrawObject(HANDLE DdHandle, DD_HALINFO* pDdHalInfo, DW
|
|||
DWORD NTAPI DxDdReenableDirectDrawObject(HANDLE DdHandle, PVOID p2);
|
||||
DWORD NTAPI DxDdCanCreateSurface(HANDLE DdHandle, PDD_CANCREATESURFACEDATA SurfaceData);
|
||||
DWORD NTAPI DxDdCanCreateD3DBuffer(HANDLE DdHandle, PDD_CANCREATESURFACEDATA SurfaceData);
|
||||
DWORD NTAPI DxDdCreateD3DBuffer(HANDLE hDirectDrawLocal, PEDD_SURFACE pDdSurfList, DDSURFACEDESC2 *a3, DD_SURFACE_GLOBAL *pDdSurfGlob, DD_SURFACE_LOCAL *pDdSurfLoc,
|
||||
DD_SURFACE_MORE *pDdSurfMore, DD_CREATESURFACEDATA *pDdCreateSurfaceData, PVOID Address);
|
||||
DWORD NTAPI DxDdLock(HANDLE hSurface, PDD_LOCKDATA puLockData, HDC hdcClip);
|
||||
DWORD NTAPI DxDdUnlock(HANDLE hSurface, PDD_UNLOCKDATA puUnlockData);
|
||||
HANDLE NTAPI DxDdCreateSurfaceObject(HANDLE hDirectDrawLocal, HANDLE hSurface, PDD_SURFACE_LOCAL puSurfaceLocal, PDD_SURFACE_MORE puSurfaceMore, PDD_SURFACE_GLOBAL puSurfaceGlobal, BOOL bComplete);
|
||||
|
||||
|
||||
/* Internal functions */
|
||||
|
@ -212,6 +215,7 @@ BOOL FASTCALL DdHmgCreate(VOID);
|
|||
BOOL FASTCALL DdHmgDestroy(VOID);
|
||||
PVOID FASTCALL DdHmgLock(HANDLE DdHandle, UCHAR ObjectType, BOOLEAN LockOwned);
|
||||
HANDLE FASTCALL DdHmgAlloc(ULONG objSize, CHAR objType, BOOLEAN objLock);
|
||||
|
||||
PEDD_SURFACE NTAPI intDdCreateNewSurfaceObject(PEDD_DIRECTDRAW_LOCAL peDdL, HANDLE hDirectDrawLocal,
|
||||
PDD_SURFACE_GLOBAL pDdSurfGlob, PDD_SURFACE_LOCAL pDdSurfLoc, PDD_SURFACE_MORE pDdSurfMore);
|
||||
|
||||
#endif /* _DXG_PCH_ */
|
||||
|
|
|
@ -2,4 +2,5 @@
|
|||
#define TAG_GINI 'iniG'
|
||||
#define TAG_GDDV 'vddG'
|
||||
#define TAG_GDDF 'fddG'
|
||||
#define TAG_GDDP 'pddG'
|
||||
#define TAG_DH_0 '0 hD'
|
||||
|
|
Loading…
Reference in a new issue