Commit 035012d5 authored by Stefan Dösinger's avatar Stefan Dösinger Committed by Alexandre Julliard

wined3d: Load textures from dib without copying to sysmem first.

parent 42927d0e
...@@ -36,6 +36,9 @@ WINE_DECLARE_DEBUG_CHANNEL(d3d); ...@@ -36,6 +36,9 @@ WINE_DECLARE_DEBUG_CHANNEL(d3d);
#define MAXLOCKCOUNT 50 /* After this amount of locks do not free the sysmem copy. */ #define MAXLOCKCOUNT 50 /* After this amount of locks do not free the sysmem copy. */
static const DWORD surface_simple_locations =
SFLAG_INDIB | SFLAG_INUSERMEM | SFLAG_INSYSMEM;
static void surface_cleanup(struct wined3d_surface *surface) static void surface_cleanup(struct wined3d_surface *surface)
{ {
struct wined3d_surface *overlay, *cur; struct wined3d_surface *overlay, *cur;
...@@ -4941,10 +4944,7 @@ static void surface_copy_simple_location(struct wined3d_surface *surface, DWORD ...@@ -4941,10 +4944,7 @@ static void surface_copy_simple_location(struct wined3d_surface *surface, DWORD
static void surface_load_sysmem(struct wined3d_surface *surface, static void surface_load_sysmem(struct wined3d_surface *surface,
const struct wined3d_gl_info *gl_info, DWORD dst_location) const struct wined3d_gl_info *gl_info, DWORD dst_location)
{ {
static const DWORD simple_locations = if (surface->flags & surface_simple_locations)
SFLAG_INDIB | SFLAG_INUSERMEM | SFLAG_INSYSMEM;
if (surface->flags & simple_locations)
{ {
surface_copy_simple_location(surface, dst_location); surface_copy_simple_location(surface, dst_location);
return; return;
...@@ -5079,9 +5079,9 @@ static HRESULT surface_load_texture(struct wined3d_surface *surface, ...@@ -5079,9 +5079,9 @@ static HRESULT surface_load_texture(struct wined3d_surface *surface,
} }
} }
if (!(surface->flags & SFLAG_INSYSMEM)) if (!(surface->flags & surface_simple_locations))
{ {
WARN("Trying to load a texture from sysmem, but SFLAG_INSYSMEM is not set.\n"); WARN("Trying to load a texture from sysmem, but no simple location is valid.\n");
/* Lets hope we get it from somewhere... */ /* Lets hope we get it from somewhere... */
surface_prepare_system_memory(surface); surface_prepare_system_memory(surface);
surface_load_location(surface, SFLAG_INSYSMEM); surface_load_location(surface, SFLAG_INSYSMEM);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment