---
display/brush.c | 4 +++-
display/driver.c | 2 ++
display/pointer.c | 8 ++++++++
3 files changed, 13 insertions(+), 1 deletion(-)
diff --git a/display/brush.c b/display/brush.c
index 0b9400d..fe94f1c 100644
--- a/display/brush.c
+++ b/display/brush.c
@@ -235,10 +235,12 @@ BOOL APIENTRY DrvRealizeBrush(BRUSHOBJ *brush, SURFOBJ
*target, SURFOBJ *pattern
int size;
if (!(pdev = (PDev *)target->dhpdev)) {
- ASSERT(NULL, 0);
+ DEBUG_PRINT((NULL, 0, "%s: err no pdev\n", __FUNCTION__));
return FALSE;
}
+ PUNT_IF_DISABLED(pdev);
+
DEBUG_PRINT((pdev, 3, "%s\n", __FUNCTION__));
if (mask) {
diff --git a/display/driver.c b/display/driver.c
index d7fdbf7..b8050de 100644
--- a/display/driver.c
+++ b/display/driver.c
@@ -1414,6 +1414,8 @@ HBITMAP APIENTRY DrvCreateDeviceBitmap(DHPDEV dhpdev,
SIZEL size, ULONG format)
pdev = (PDev *)dhpdev;
+ PUNT_IF_DISABLED(pdev);
+
if (!pdev->create_non_primary_surfaces) {
return FALSE;
}
diff --git a/display/pointer.c b/display/pointer.c
index d38a207..17fa3c5 100644
--- a/display/pointer.c
+++ b/display/pointer.c
@@ -43,6 +43,8 @@ ULONG APIENTRY DrvSetPointerShape(SURFOBJ *surf, SURFOBJ
*mask, SURFOBJ *color_p
return SPS_ERROR;
}
+ PUNT_IF_DISABLED(pdev);
+
DEBUG_PRINT((pdev, 3, "%s\n", __FUNCTION__));
if (flags & SPS_CHANGE) {
@@ -129,6 +131,12 @@ VOID APIENTRY DrvMovePointer(SURFOBJ *surf, LONG pos_x,
LONG pos_y, RECTL *area)
return;
}
+ if (!pdev->enabled) {
+ DEBUG_PRINT((pdev, 3, "%s: ignoring when device is disabled\n",
+ __FUNCTION__));
+ return;
+ }
+
cursor_cmd = CursorCmd(pdev);
if (pos_x < 0) {
cursor_cmd->type = QXL_CURSOR_HIDE;
--
1.8.3.1
_______________________________________________
Spice-devel mailing list
[email protected]
http://lists.freedesktop.org/mailman/listinfo/spice-devel