GTK+: OpenGL: Use fence to allow GTK+ to run during wait.

This commit is contained in:
Brandon Wright 2018-12-03 18:21:09 -06:00
parent dc4de5b7c7
commit 8106c284d5
8 changed files with 36 additions and 5 deletions

View File

@ -1897,3 +1897,10 @@ S9xInitDisplay (int argc, char **argv)
S9xCustomDisplayString = S9xGTKDisplayString;
}
bool
S9xDisplayDriverIsReady ()
{
if (!driver)
return false;
return driver->is_ready ();
}

View File

@ -132,5 +132,6 @@ void S9xDisplayReconfigure ();
void S9xQueryDrivers ();
S9xDisplayDriver *S9xDisplayGetDriver ();
bool S9xDisplayDriverIsReady ();
#endif /* __GTK_DISPLAY_H */

View File

@ -23,6 +23,7 @@ class S9xDisplayDriver
virtual void push_buffer (uint16 *src) = 0;
virtual void *get_parameters () = 0;
virtual void save (const char *filename) = 0;
virtual bool is_ready () = 0;
/* Namespaced sizing constants */
static const int image_width = 1024;

View File

@ -24,6 +24,7 @@ class S9xGTKDisplayDriver : public S9xDisplayDriver
void push_buffer (uint16 *src);
void *get_parameters () { return NULL; }
void save (const char *filename) { }
bool is_ready () { return true; }
private:
void clear ();

View File

@ -88,6 +88,7 @@ S9xOpenGLDisplayDriver::S9xOpenGLDisplayDriver (Snes9xWindow *window,
this->window = window;
this->config = config;
this->drawing_area = GTK_WIDGET (window->drawing_area);
fence = NULL;
}
void S9xOpenGLDisplayDriver::update (int width, int height, int yoffset)
@ -645,10 +646,9 @@ void S9xOpenGLDisplayDriver::swap_buffers ()
{
if (fences)
{
GLsync fence = glFenceSync (GL_SYNC_GPU_COMMANDS_COMPLETE, 0);
usleep (0);
glClientWaitSync (fence, GL_SYNC_FLUSH_COMMANDS_BIT, 100000000);
if (fence)
glDeleteSync (fence);
fence = glFenceSync (GL_SYNC_GPU_COMMANDS_COMPLETE, 0);
}
else
{
@ -716,3 +716,16 @@ int S9xOpenGLDisplayDriver::query_availability ()
return 0;
}
bool S9xOpenGLDisplayDriver::is_ready ()
{
if (!fence)
return true;
if (glClientWaitSync (fence, GL_SYNC_FLUSH_COMMANDS_BIT, 0) == GL_TIMEOUT_EXPIRED)
return false;
glDeleteSync (fence);
fence = NULL;
return true;
}

View File

@ -41,6 +41,7 @@ class S9xOpenGLDisplayDriver : public S9xDisplayDriver
void *get_parameters ();
void save (const char *filename);
static int query_availability ();
bool is_ready ();
private:
int opengl_defaults ();
@ -74,6 +75,8 @@ class S9xOpenGLDisplayDriver : public S9xDisplayDriver
OpenGLContext *context;
GLsync fence;
#ifdef GDK_WINDOWING_X11
GTKGLXContext glx;
#endif

View File

@ -32,6 +32,7 @@ class S9xXVDisplayDriver : public S9xDisplayDriver
void *get_parameters () { return NULL; }
void save (const char *filename) { }
static int query_availability ();
bool is_ready () { return true; }
private:
void clear ();

View File

@ -308,9 +308,13 @@ gboolean S9xIdleFunc (gpointer data)
}
S9xCheckPointerTimer ();
S9xThrottle ();
S9xProcessEvents (TRUE);
if (!S9xDisplayDriverIsReady ())
return TRUE;
S9xThrottle ();
if (!S9xNetplayPush ())
{
if(Settings.Rewinding)