[client] spice: release the mouse if the host stops

This commit is contained in:
Geoffrey McRae 2021-01-21 15:39:15 +11:00
parent ef4df571f0
commit dcd0cb7d8e
2 changed files with 18 additions and 12 deletions

View file

@ -48,6 +48,7 @@ Place, Suite 330, Boston, MA 02111-1307 USA
#include "common/time.h" #include "common/time.h"
#include "common/version.h" #include "common/version.h"
#include "app.h"
#include "utils.h" #include "utils.h"
#include "kb.h" #include "kb.h"
#include "ll.h" #include "ll.h"
@ -87,14 +88,24 @@ static void setCursorInView(bool enable);
static void lgInit(void) static void lgInit(void)
{ {
g_state.state = APP_STATE_RUNNING; g_state.state = APP_STATE_RUNNING;
g_state.formatValid = false;
g_state.resizeDone = true; g_state.resizeDone = true;
if (g_cursor.grab)
setGrab(false);
g_cursor.useScale = false; g_cursor.useScale = false;
g_cursor.scale.x = 1.0; g_cursor.scale.x = 1.0;
g_cursor.scale.y = 1.0; g_cursor.scale.y = 1.0;
g_cursor.draw = false; g_cursor.draw = false;
g_cursor.inView = false; g_cursor.inView = false;
g_cursor.guest.valid = false; g_cursor.guest.valid = false;
// if spice is not in use, hide the local cursor
if (!app_inputEnabled() && params.hideMouse)
SDL_ShowCursor(SDL_DISABLE);
else
SDL_ShowCursor(SDL_ENABLE);
} }
bool app_getProp(LG_DSProperty prop, void * ret) bool app_getProp(LG_DSProperty prop, void * ret)
@ -516,7 +527,6 @@ static int frameThread(void * unused)
PLGMPClientQueue queue; PLGMPClientQueue queue;
uint32_t formatVer = 0; uint32_t formatVer = 0;
bool formatValid = false;
size_t dataSize; size_t dataSize;
LG_RendererFormat lgrFormat; LG_RendererFormat lgrFormat;
@ -590,7 +600,7 @@ static int frameThread(void * unused)
KVMFRFrame * frame = (KVMFRFrame *)msg.mem; KVMFRFrame * frame = (KVMFRFrame *)msg.mem;
struct DMAFrameInfo *dma = NULL; struct DMAFrameInfo *dma = NULL;
if (!formatValid || frame->formatVer != formatVer) if (!g_state.formatValid || frame->formatVer != formatVer)
{ {
// setup the renderer format with the frame format details // setup the renderer format with the frame format details
lgrFormat.type = frame->type; lgrFormat.type = frame->type;
@ -636,7 +646,7 @@ static int frameThread(void * unused)
break; break;
} }
formatValid = true; g_state.formatValid = true;
formatVer = frame->formatVer; formatVer = frame->formatVer;
DEBUG_INFO("Format: %s %ux%u stride:%u pitch:%u rotation:%d", DEBUG_INFO("Format: %s %ux%u stride:%u pitch:%u rotation:%d",
@ -1555,7 +1565,7 @@ static void setGrabQuiet(bool enable)
g_state.ds->ungrabKeyboard(); g_state.ds->ungrabKeyboard();
} }
if (!warpSupport || params.captureInputOnly) if (!warpSupport || params.captureInputOnly || !g_state.formatValid)
g_state.ds->ungrabPointer(); g_state.ds->ungrabPointer();
// if exiting capture when input on capture only, we want to show the cursor // if exiting capture when input on capture only, we want to show the cursor
@ -1798,13 +1808,10 @@ static int lg_run(void)
{ {
memset(&g_state, 0, sizeof(g_state)); memset(&g_state, 0, sizeof(g_state));
lgInit();
g_cursor.sens = params.mouseSens; g_cursor.sens = params.mouseSens;
if (g_cursor.sens < -9) g_cursor.sens = -9; if (g_cursor.sens < -9) g_cursor.sens = -9;
else if (g_cursor.sens > 9) g_cursor.sens = 9; else if (g_cursor.sens > 9) g_cursor.sens = 9;
// try to early detect the platform // try to early detect the platform
SDL_SYSWM_TYPE subsystem = SDL_SYSWM_UNKNOWN; SDL_SYSWM_TYPE subsystem = SDL_SYSWM_UNKNOWN;
if (getenv("WAYLAND_DISPLAY")) subsystem = SDL_SYSWM_WAYLAND; if (getenv("WAYLAND_DISPLAY")) subsystem = SDL_SYSWM_WAYLAND;
@ -1993,10 +2000,6 @@ static int lg_run(void)
// ensure renderer viewport is aware of the current window size // ensure renderer viewport is aware of the current window size
updatePositionInfo(); updatePositionInfo();
// if spice is not in use, hide the local cursor
if (!app_inputEnabled() && params.hideMouse)
SDL_ShowCursor(SDL_DISABLE);
if (params.fpsMin <= 0) if (params.fpsMin <= 0)
{ {
// default 30 fps // default 30 fps
@ -2071,6 +2074,8 @@ static int lg_run(void)
KVMFR *udata; KVMFR *udata;
int waitCount = 0; int waitCount = 0;
lgInit();
restart: restart:
while(g_state.state == APP_STATE_RUNNING) while(g_state.state == APP_STATE_RUNNING)
{ {

View file

@ -80,6 +80,7 @@ struct AppState
PLGMPClientQueue frameQueue; PLGMPClientQueue frameQueue;
PLGMPClientQueue pointerQueue; PLGMPClientQueue pointerQueue;
bool formatValid;
atomic_uint_least64_t frameTime; atomic_uint_least64_t frameTime;
uint64_t lastFrameTime; uint64_t lastFrameTime;
uint64_t renderTime; uint64_t renderTime;