mirror of
https://github.com/gnif/LookingGlass.git
synced 2025-01-10 22:33:58 +00:00
[client] code cleanup
This commit is contained in:
parent
a54f3000f5
commit
7638925387
1 changed files with 36 additions and 31 deletions
|
@ -149,6 +149,37 @@ inline bool areFormatsSame(const struct KVMGFXHeader s1, const struct KVMGFXHead
|
||||||
(s1.height == s2.height );
|
(s1.height == s2.height );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline bool waitGuest()
|
||||||
|
{
|
||||||
|
bool ready = false;
|
||||||
|
bool error = false;
|
||||||
|
while(state.running && !ready && !error)
|
||||||
|
{
|
||||||
|
switch(ivshmem_wait_irq(0))
|
||||||
|
{
|
||||||
|
case IVSHMEM_WAIT_RESULT_OK:
|
||||||
|
ready = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case IVSHMEM_WAIT_RESULT_TIMEOUT:
|
||||||
|
ivshmem_kick_irq(state.shm->guestID, 0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case IVSHMEM_WAIT_RESULT_ERROR:
|
||||||
|
error = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (error)
|
||||||
|
{
|
||||||
|
DEBUG_ERROR("error during wait for host");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
int renderThread(void * unused)
|
int renderThread(void * unused)
|
||||||
{
|
{
|
||||||
struct KVMGFXHeader header;
|
struct KVMGFXHeader header;
|
||||||
|
@ -170,13 +201,15 @@ int renderThread(void * unused)
|
||||||
|
|
||||||
memset(&header, 0, sizeof(struct KVMGFXHeader));
|
memset(&header, 0, sizeof(struct KVMGFXHeader));
|
||||||
|
|
||||||
// kick the guest early for our intial frame
|
// initial guest kick to get things started
|
||||||
// the guestID may be invalid, it doesn't matter
|
|
||||||
ivshmem_kick_irq(state.shm->guestID, 0);
|
ivshmem_kick_irq(state.shm->guestID, 0);
|
||||||
|
|
||||||
while(state.running)
|
while(state.running)
|
||||||
{
|
{
|
||||||
// copy the header for our use
|
// wait for the guest to signal ready and copy the header
|
||||||
|
if (!waitGuest())
|
||||||
|
break;
|
||||||
|
|
||||||
memcpy(&newHeader, state.shm, sizeof(struct KVMGFXHeader));
|
memcpy(&newHeader, state.shm, sizeof(struct KVMGFXHeader));
|
||||||
ivshmem_kick_irq(newHeader.guestID, 0);
|
ivshmem_kick_irq(newHeader.guestID, 0);
|
||||||
|
|
||||||
|
@ -471,34 +504,6 @@ int renderThread(void * unused)
|
||||||
|
|
||||||
SDL_RenderPresent(state.renderer);
|
SDL_RenderPresent(state.renderer);
|
||||||
state.started = true;
|
state.started = true;
|
||||||
|
|
||||||
bool ready = false;
|
|
||||||
bool error = false;
|
|
||||||
while(state.running && !ready && !error)
|
|
||||||
{
|
|
||||||
// kick the guest and wait for a frame
|
|
||||||
switch(ivshmem_wait_irq(0))
|
|
||||||
{
|
|
||||||
case IVSHMEM_WAIT_RESULT_OK:
|
|
||||||
ready = true;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case IVSHMEM_WAIT_RESULT_TIMEOUT:
|
|
||||||
ivshmem_kick_irq(newHeader.guestID, 0);
|
|
||||||
ready = false;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case IVSHMEM_WAIT_RESULT_ERROR:
|
|
||||||
error = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
DEBUG_ERROR("error during wait for host");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
state.running = false;
|
state.running = false;
|
||||||
|
|
Loading…
Reference in a new issue