ddraw: Create textures for swapchain surfaces.

This commit is contained in:
Henri Verbeet 2013-11-13 10:12:06 +01:00 committed by Alexandre Julliard
parent 56a6500721
commit d6f12fcdc8
1 changed files with 26 additions and 6 deletions

View File

@ -5143,14 +5143,23 @@ static HRESULT CDECL device_parent_create_texture_surface(struct wined3d_device_
DWORD flags, struct wined3d_surface **surface) DWORD flags, struct wined3d_surface **surface)
{ {
struct ddraw *ddraw = ddraw_from_device_parent(device_parent); struct ddraw *ddraw = ddraw_from_device_parent(device_parent);
struct ddraw_texture *texture = container_parent;
DDSURFACEDESC2 desc = texture->surface_desc;
struct ddraw_surface *ddraw_surface; struct ddraw_surface *ddraw_surface;
struct ddraw_texture *texture;
DDSURFACEDESC2 desc;
HRESULT hr; HRESULT hr;
TRACE("device_parent %p, container_parent %p, wined3d_desc %p, sub_resource_idx %u, flags %#x, surface %p.\n", TRACE("device_parent %p, container_parent %p, wined3d_desc %p, sub_resource_idx %u, flags %#x, surface %p.\n",
device_parent, container_parent, wined3d_desc, sub_resource_idx, flags, surface); device_parent, container_parent, wined3d_desc, sub_resource_idx, flags, surface);
/* We have a swapchain texture. */
if (container_parent == ddraw)
return wined3d_surface_create(ddraw->wined3d_device, wined3d_desc->width, wined3d_desc->height,
wined3d_desc->format, wined3d_desc->usage, wined3d_desc->pool, wined3d_desc->multisample_type,
wined3d_desc->multisample_quality, WINED3D_SURFACE_MAPPABLE, NULL,
&ddraw_null_wined3d_parent_ops, surface);
texture = container_parent;
desc = texture->surface_desc;
desc.dwWidth = wined3d_desc->width; desc.dwWidth = wined3d_desc->width;
desc.dwHeight = wined3d_desc->height; desc.dwHeight = wined3d_desc->height;
@ -5179,6 +5188,8 @@ static HRESULT CDECL device_parent_create_swapchain_surface(struct wined3d_devic
void *container_parent, const struct wined3d_resource_desc *desc, struct wined3d_surface **surface) void *container_parent, const struct wined3d_resource_desc *desc, struct wined3d_surface **surface)
{ {
struct ddraw *ddraw = ddraw_from_device_parent(device_parent); struct ddraw *ddraw = ddraw_from_device_parent(device_parent);
struct wined3d_resource_desc texture_desc;
struct wined3d_texture *texture;
HRESULT hr; HRESULT hr;
TRACE("device_parent %p, container_parent %p, desc %p, surface %p.\n", TRACE("device_parent %p, container_parent %p, desc %p, surface %p.\n",
@ -5190,10 +5201,19 @@ static HRESULT CDECL device_parent_create_swapchain_surface(struct wined3d_devic
return E_FAIL; return E_FAIL;
} }
if (SUCCEEDED(hr = wined3d_surface_create(ddraw->wined3d_device, desc->width, desc->height, desc->format, texture_desc = *desc;
desc->usage, desc->pool, desc->multisample_type, desc->multisample_quality, WINED3D_SURFACE_MAPPABLE, texture_desc.resource_type = WINED3D_RTYPE_TEXTURE;
ddraw, &ddraw_frontbuffer_parent_ops, surface))) if (FAILED(hr = wined3d_texture_create_2d(ddraw->wined3d_device, &texture_desc, 1,
WINED3D_SURFACE_MAPPABLE, ddraw, &ddraw_frontbuffer_parent_ops, &texture)))
{
WARN("Failed to create texture, hr %#x.\n", hr);
return hr;
}
*surface = wined3d_surface_from_resource(wined3d_texture_get_sub_resource(texture, 0));
ddraw->wined3d_frontbuffer = *surface; ddraw->wined3d_frontbuffer = *surface;
wined3d_surface_incref(*surface);
wined3d_texture_decref(texture);
return hr; return hr;
} }