Number of surface Lock/Unlocks must NOT match, so do NOT use it for
reference counting.
This commit is contained in:
parent
f561aadffc
commit
b7ed6df279
|
@ -31,8 +31,13 @@ HRESULT WINAPI IDirectDrawSurface4Impl_Lock(
|
||||||
LPDIRECTDRAWSURFACE4 iface,LPRECT lprect,LPDDSURFACEDESC lpddsd,DWORD flags, HANDLE hnd
|
LPDIRECTDRAWSURFACE4 iface,LPRECT lprect,LPDDSURFACEDESC lpddsd,DWORD flags, HANDLE hnd
|
||||||
) {
|
) {
|
||||||
ICOM_THIS(IDirectDrawSurface4Impl,iface);
|
ICOM_THIS(IDirectDrawSurface4Impl,iface);
|
||||||
|
|
||||||
TRACE("(%p)->Lock(%p,%p,%08lx,%08lx)\n",
|
TRACE("(%p)->Lock(%p,%p,%08lx,%08lx)\n",
|
||||||
This,lprect,lpddsd,flags,(DWORD)hnd);
|
This,lprect,lpddsd,flags,(DWORD)hnd);
|
||||||
|
|
||||||
|
/* DO NOT AddRef the surface! Lock/Unlock must not come in matched pairs
|
||||||
|
* -Marcus Meissner 20000509
|
||||||
|
*/
|
||||||
if (flags & ~(DDLOCK_WAIT|DDLOCK_READONLY|DDLOCK_WRITEONLY))
|
if (flags & ~(DDLOCK_WAIT|DDLOCK_READONLY|DDLOCK_WRITEONLY))
|
||||||
WARN("(%p)->Lock(%p,%p,%08lx,%08lx)\n",
|
WARN("(%p)->Lock(%p,%p,%08lx,%08lx)\n",
|
||||||
This,lprect,lpddsd,flags,(DWORD)hnd);
|
This,lprect,lpddsd,flags,(DWORD)hnd);
|
||||||
|
@ -68,6 +73,10 @@ HRESULT WINAPI IDirectDrawSurface4Impl_Unlock(
|
||||||
LPDIRECTDRAWSURFACE4 iface,LPVOID surface
|
LPDIRECTDRAWSURFACE4 iface,LPVOID surface
|
||||||
) {
|
) {
|
||||||
ICOM_THIS(IDirectDrawSurface4Impl,iface);
|
ICOM_THIS(IDirectDrawSurface4Impl,iface);
|
||||||
|
|
||||||
|
/* DO NOT Release the surface! Lock/Unlock MUST NOT come in matched pairs
|
||||||
|
* Marcus Meissner 20000509
|
||||||
|
*/
|
||||||
TRACE("(%p)->Unlock(%p)\n",This,surface);
|
TRACE("(%p)->Unlock(%p)\n",This,surface);
|
||||||
return DD_OK;
|
return DD_OK;
|
||||||
}
|
}
|
||||||
|
@ -170,11 +179,6 @@ HRESULT WINAPI IDirectDrawSurface4Impl_Blt(
|
||||||
if (src) IDirectDrawSurface4_Lock(src, NULL, &sdesc, 0, 0);
|
if (src) IDirectDrawSurface4_Lock(src, NULL, &sdesc, 0, 0);
|
||||||
IDirectDrawSurface4_Lock(iface,NULL,&ddesc,0,0);
|
IDirectDrawSurface4_Lock(iface,NULL,&ddesc,0,0);
|
||||||
|
|
||||||
if (src && sdesc.ddsCaps.dwCaps & DDSCAPS_PRIMARYSURFACE)
|
|
||||||
ERR("blitting FROM a primary surface? Hello?\n");
|
|
||||||
if (!(ddesc.ddsCaps.dwCaps & DDSCAPS_PRIMARYSURFACE))
|
|
||||||
ERR("NOT blitting into a primary surface? Hello?\n");
|
|
||||||
|
|
||||||
if (TRACE_ON(ddraw)) {
|
if (TRACE_ON(ddraw)) {
|
||||||
if (rdst) TRACE("\tdestrect :%dx%d-%dx%d\n",rdst->left,rdst->top,rdst->right,rdst->bottom);
|
if (rdst) TRACE("\tdestrect :%dx%d-%dx%d\n",rdst->left,rdst->top,rdst->right,rdst->bottom);
|
||||||
if (rsrc) TRACE("\tsrcrect :%dx%d-%dx%d\n",rsrc->left,rsrc->top,rsrc->right,rsrc->bottom);
|
if (rsrc) TRACE("\tsrcrect :%dx%d-%dx%d\n",rsrc->left,rsrc->top,rsrc->right,rsrc->bottom);
|
||||||
|
|
|
@ -86,8 +86,8 @@ HRESULT WINAPI Xlib_IDirectDrawSurface4Impl_Lock(
|
||||||
DSPRIVATE(This);
|
DSPRIVATE(This);
|
||||||
DDPRIVATE(This->s.ddraw);
|
DDPRIVATE(This->s.ddraw);
|
||||||
|
|
||||||
IDirectDrawSurface4_AddRef(iface);
|
/* DO NOT AddRef the surface! Lock/Unlock are NOT guaranteed to come in
|
||||||
|
* matched pairs! - Marcus Meissner 20000509 */
|
||||||
TRACE("(%p)->Lock(%p,%p,%08lx,%08lx)\n",This,lprect,lpddsd,flags,(DWORD)hnd);
|
TRACE("(%p)->Lock(%p,%p,%08lx,%08lx)\n",This,lprect,lpddsd,flags,(DWORD)hnd);
|
||||||
if (flags & ~(DDLOCK_WAIT|DDLOCK_READONLY|DDLOCK_WRITEONLY))
|
if (flags & ~(DDLOCK_WAIT|DDLOCK_READONLY|DDLOCK_WRITEONLY))
|
||||||
WARN("(%p)->Lock(%p,%p,%08lx,%08lx)\n",
|
WARN("(%p)->Lock(%p,%p,%08lx,%08lx)\n",
|
||||||
|
@ -193,7 +193,8 @@ HRESULT WINAPI Xlib_IDirectDrawSurface4Impl_Unlock(
|
||||||
TSXSetWindowColormap(display,ddpriv->drawable,dppriv->cm);
|
TSXSetWindowColormap(display,ddpriv->drawable,dppriv->cm);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
IDirectDrawSurface4_Release(iface);
|
/* DO NOT Release the surface! Lock/Unlock are NOT guaranteed to come in
|
||||||
|
* matched pairs! - Marcus Meissner 20000509 */
|
||||||
return DD_OK;
|
return DD_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue