ddraw: Move the DDSD_LPSURFACE fixups from CreateSurface() to ddraw_surface_create_texture().
This commit is contained in:
parent
f2e9854483
commit
06f393dc7d
|
@ -2842,19 +2842,6 @@ static HRESULT CreateSurface(struct ddraw *ddraw, DDSURFACEDESC2 *DDSD,
|
|||
DDSD->dwFlags |= DDSD_CAPS;
|
||||
}
|
||||
|
||||
if (DDSD->ddsCaps.dwCaps & DDSCAPS_ALLOCONLOAD)
|
||||
{
|
||||
/* If the surface is of the 'alloconload' type, ignore the LPSURFACE field */
|
||||
DDSD->dwFlags &= ~DDSD_LPSURFACE;
|
||||
}
|
||||
|
||||
if ((DDSD->dwFlags & DDSD_LPSURFACE) && (DDSD->lpSurface == NULL))
|
||||
{
|
||||
/* Frank Herbert's Dune specifies a null pointer for the surface, ignore the LPSURFACE field */
|
||||
WARN("(%p) Null surface pointer specified, ignore it!\n", ddraw);
|
||||
DDSD->dwFlags &= ~DDSD_LPSURFACE;
|
||||
}
|
||||
|
||||
/* Modify some flags */
|
||||
copy_to_surfacedesc2(&desc2, DDSD);
|
||||
|
||||
|
|
|
@ -5608,6 +5608,11 @@ HRESULT ddraw_surface_create_texture(struct ddraw *ddraw, DDSURFACEDESC2 *desc,
|
|||
DDRAW_dump_surface_desc(desc);
|
||||
}
|
||||
|
||||
/* If the surface is of the 'ALLOCONLOAD' type, ignore the LPSURFACE
|
||||
* field. Frank Herbert's Dune specifies a NULL pointer for lpSurface. */
|
||||
if ((desc->ddsCaps.dwCaps & DDSCAPS_ALLOCONLOAD) || !desc->lpSurface)
|
||||
desc->dwFlags &= ~DDSD_LPSURFACE;
|
||||
|
||||
if ((desc->ddsCaps.dwCaps & (DDSCAPS_FLIP | DDSCAPS_PRIMARYSURFACE))
|
||||
== (DDSCAPS_FLIP | DDSCAPS_PRIMARYSURFACE)
|
||||
&& !(ddraw->cooperative_level & DDSCL_EXCLUSIVE))
|
||||
|
|
Loading…
Reference in New Issue