mirror of
https://github.com/gnif/LookingGlass.git
synced 2025-01-18 10:43:58 +00:00
[host] switch to fast polling mode, fixes stuttering issues
This commit is contained in:
parent
afff50dfde
commit
e379f70784
3 changed files with 21 additions and 28 deletions
|
@ -69,6 +69,7 @@ KVMFRFrame;
|
|||
#define KVMFR_HEADER_FLAG_FRAME 1 // frame update available
|
||||
#define KVMFR_HEADER_FLAG_CURSOR 2 // cursor update available
|
||||
#define KVMFR_HEADER_FLAG_RESTART 4 // restart signal from client
|
||||
#define KVMFR_HEADER_FLAG_READY 8 // ready signal from client
|
||||
|
||||
typedef struct KVMFRHeader
|
||||
{
|
||||
|
|
|
@ -30,7 +30,7 @@ Service * Service::m_instance = NULL;
|
|||
Service::Service() :
|
||||
m_initialized(false),
|
||||
m_memory(NULL),
|
||||
m_readyEvent(INVALID_HANDLE_VALUE),
|
||||
m_timer(NULL),
|
||||
m_capture(NULL),
|
||||
m_header(NULL),
|
||||
m_frameIndex(0)
|
||||
|
@ -73,11 +73,10 @@ bool Service::Initialize(ICapture * captureDevice)
|
|||
if (!InitPointers())
|
||||
return false;
|
||||
|
||||
m_readyEvent = m_ivshmem->CreateVectorEvent(0);
|
||||
if (m_readyEvent == INVALID_HANDLE_VALUE)
|
||||
m_timer = CreateWaitableTimer(NULL, TRUE, NULL);
|
||||
if (!m_timer)
|
||||
{
|
||||
DEBUG_ERROR("Failed to get event for vector 0");
|
||||
DeInitialize();
|
||||
DEBUG_ERROR("Failed to create waitable timer");
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -117,10 +116,10 @@ bool Service::InitPointers()
|
|||
|
||||
void Service::DeInitialize()
|
||||
{
|
||||
if (m_readyEvent != INVALID_HANDLE_VALUE)
|
||||
if (m_timer)
|
||||
{
|
||||
CloseHandle(m_readyEvent);
|
||||
m_readyEvent = INVALID_HANDLE_VALUE;
|
||||
CloseHandle(m_timer);
|
||||
m_timer = NULL;
|
||||
}
|
||||
|
||||
m_header = NULL;
|
||||
|
@ -153,8 +152,7 @@ bool Service::Process()
|
|||
frame.bufferSize = m_frameSize;
|
||||
|
||||
// wait for the host to notify that is it is ready to proceed
|
||||
bool eventDone = false;
|
||||
while (!eventDone)
|
||||
while (true)
|
||||
{
|
||||
// check if the client has flagged a restart
|
||||
if (m_header->flags & KVMFR_HEADER_FLAG_RESTART)
|
||||
|
@ -164,29 +162,23 @@ bool Service::Process()
|
|||
break;
|
||||
}
|
||||
|
||||
switch (WaitForSingleObject(m_readyEvent, 200))
|
||||
// check if the client has flagged it's ready
|
||||
if (m_header->flags & KVMFR_HEADER_FLAG_READY)
|
||||
{
|
||||
case WAIT_ABANDONED:
|
||||
DEBUG_ERROR("Wait abandoned");
|
||||
return false;
|
||||
|
||||
case WAIT_OBJECT_0:
|
||||
eventDone = true;
|
||||
InterlockedAnd8((char *)&m_header->flags, ~(KVMFR_HEADER_FLAG_READY));
|
||||
break;
|
||||
}
|
||||
|
||||
case WAIT_TIMEOUT:
|
||||
continue;
|
||||
|
||||
case WAIT_FAILED:
|
||||
DEBUG_ERROR("Wait failed");
|
||||
return false;
|
||||
|
||||
default:
|
||||
DEBUG_ERROR("Unknown error");
|
||||
// wait for 100ns before polling again
|
||||
LARGE_INTEGER timeout;
|
||||
timeout.QuadPart = -100;
|
||||
if (!SetWaitableTimer(m_timer, &timeout, 0, NULL, NULL, FALSE))
|
||||
{
|
||||
DEBUG_ERROR("Failed to set waitable timer");
|
||||
return false;
|
||||
}
|
||||
WaitForSingleObject(m_timer, INFINITE);
|
||||
}
|
||||
ResetEvent(m_readyEvent);
|
||||
|
||||
bool ok = false;
|
||||
bool cursorOnly = false;
|
||||
|
|
|
@ -51,7 +51,7 @@ private:
|
|||
bool m_initialized;
|
||||
uint8_t * m_memory;
|
||||
IVSHMEM * m_ivshmem;
|
||||
HANDLE m_readyEvent;
|
||||
HANDLE m_timer;
|
||||
ICapture * m_capture;
|
||||
|
||||
KVMFRHeader * m_header;
|
||||
|
|
Loading…
Reference in a new issue