From 8b13aac9666951bade6ac5fff9eb7c45a7d2748a Mon Sep 17 00:00:00 2001 From: Andre Heider Date: Thu, 11 Apr 2019 08:42:47 +0200 Subject: st/nine: skip position checks in SetCursorPosition() For HW cursors, "cursor.pos" doesn't hold the current position of the pointer, just the position of the last call to SetCursorPosition(). Skip the check against stale values and bump the d3dadapter9 drm version to expose this change of behaviour. Signed-off-by: Andre Heider Reviewed-by: Axel Davy --- src/gallium/state_trackers/nine/device9.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) (limited to 'src/gallium/state_trackers/nine/device9.c') diff --git a/src/gallium/state_trackers/nine/device9.c b/src/gallium/state_trackers/nine/device9.c index db1c3a1d23d..0b1fe59cb70 100644 --- a/src/gallium/state_trackers/nine/device9.c +++ b/src/gallium/state_trackers/nine/device9.c @@ -793,9 +793,11 @@ NineDevice9_SetCursorPosition( struct NineDevice9 *This, DBG("This=%p X=%d Y=%d Flags=%d\n", This, X, Y, Flags); - if (This->cursor.pos.x == X && - This->cursor.pos.y == Y) - return; + /* present >= v1.4 handles this itself */ + if (This->minor_version_num < 4) { + if (This->cursor.pos.x == X && This->cursor.pos.y == Y) + return; + } This->cursor.pos.x = X; This->cursor.pos.y = Y; -- cgit v1.2.3