Commit c2c0743c authored by Henri Verbeet's avatar Henri Verbeet Committed by Alexandre Julliard

wined3d: Properly retrieve the display mode in wined3d_device_set_cursor_properties().

parent 70008999
...@@ -4800,7 +4800,9 @@ HRESULT CDECL wined3d_device_set_cursor_properties(struct wined3d_device *device ...@@ -4800,7 +4800,9 @@ HRESULT CDECL wined3d_device_set_cursor_properties(struct wined3d_device *device
if (cursor_image) if (cursor_image)
{ {
struct wined3d_display_mode mode;
struct wined3d_map_desc map_desc; struct wined3d_map_desc map_desc;
HRESULT hr;
/* MSDN: Cursor must be A8R8G8B8 */ /* MSDN: Cursor must be A8R8G8B8 */
if (cursor_image->resource.format->id != WINED3DFMT_B8G8R8A8_UNORM) if (cursor_image->resource.format->id != WINED3DFMT_B8G8R8A8_UNORM)
...@@ -4809,13 +4811,18 @@ HRESULT CDECL wined3d_device_set_cursor_properties(struct wined3d_device *device ...@@ -4809,13 +4811,18 @@ HRESULT CDECL wined3d_device_set_cursor_properties(struct wined3d_device *device
return WINED3DERR_INVALIDCALL; return WINED3DERR_INVALIDCALL;
} }
if (FAILED(hr = wined3d_get_adapter_display_mode(device->wined3d, device->adapter->ordinal, &mode)))
{
ERR("Failed to get display mode, hr %#x.\n", hr);
return WINED3DERR_INVALIDCALL;
}
/* MSDN: Cursor must be smaller than the display mode */ /* MSDN: Cursor must be smaller than the display mode */
if (cursor_image->resource.width > device->adapter->screen_size.cx if (cursor_image->resource.width > mode.width || cursor_image->resource.height > mode.height)
|| cursor_image->resource.height > device->adapter->screen_size.cy)
{ {
WARN("Surface %p dimensions are %ux%u, but screen dimensions are %ux%u.\n", WARN("Surface %p dimensions are %ux%u, but screen dimensions are %ux%u.\n",
cursor_image, cursor_image->resource.width, cursor_image->resource.height, cursor_image, cursor_image->resource.width, cursor_image->resource.height,
device->adapter->screen_size.cx, device->adapter->screen_size.cy); mode.width, mode.height);
return WINED3DERR_INVALIDCALL; return WINED3DERR_INVALIDCALL;
} }
...@@ -5694,8 +5701,6 @@ HRESULT device_init(struct wined3d_device *device, struct wined3d *wined3d, ...@@ -5694,8 +5701,6 @@ HRESULT device_init(struct wined3d_device *device, struct wined3d *wined3d,
wined3d_decref(device->wined3d); wined3d_decref(device->wined3d);
return hr; return hr;
} }
adapter->screen_size.cx = mode.width;
adapter->screen_size.cy = mode.height;
adapter->screen_format = mode.format_id; adapter->screen_format = mode.format_id;
/* Save the creation parameters. */ /* Save the creation parameters. */
......
...@@ -3136,8 +3136,6 @@ HRESULT CDECL wined3d_set_adapter_display_mode(struct wined3d *wined3d, ...@@ -3136,8 +3136,6 @@ HRESULT CDECL wined3d_set_adapter_display_mode(struct wined3d *wined3d,
} }
/* Store the new values. */ /* Store the new values. */
adapter->screen_size.cx = mode->width;
adapter->screen_size.cy = mode->height;
adapter->screen_format = mode->format_id; adapter->screen_format = mode->format_id;
/* And finally clip mouse to our screen. */ /* And finally clip mouse to our screen. */
......
...@@ -1543,7 +1543,6 @@ struct wined3d_adapter ...@@ -1543,7 +1543,6 @@ struct wined3d_adapter
BOOL opengl; BOOL opengl;
POINT monitorPoint; POINT monitorPoint;
SIZE screen_size;
enum wined3d_format_id screen_format; enum wined3d_format_id screen_format;
struct wined3d_gl_info gl_info; struct wined3d_gl_info gl_info;
......
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