From 133d8ec21feccc2b7be231690b49dde596bab479 Mon Sep 17 00:00:00 2001 From: Geoffrey McRae Date: Tue, 19 Dec 2017 11:02:35 +1100 Subject: [PATCH] [client] opengl: added preventBuffer option --- client/renderers/opengl-basic.c | 42 +++++++++++++++++++++++++-------- client/renderers/opengl.c | 42 +++++++++++++++++++++++++-------- 2 files changed, 64 insertions(+), 20 deletions(-) diff --git a/client/renderers/opengl-basic.c b/client/renderers/opengl-basic.c index cbd438c3..8fe875af 100644 --- a/client/renderers/opengl-basic.c +++ b/client/renderers/opengl-basic.c @@ -45,14 +45,16 @@ struct Options { bool mipmap; bool vsync; + bool preventBuffer; bool splitMouse; }; static struct Options defaultOptions = { - .mipmap = true, - .vsync = true, - .splitMouse = false + .mipmap = true, + .vsync = true, + .preventBuffer = true, + .splitMouse = false }; struct LGR_OpenGLBasic @@ -700,14 +702,19 @@ bool lgr_opengl_basic_render(void * opaque) if (this->fpsTexture) glCallList(this->fpsList); - unsigned int before, after; - glXGetVideoSyncSGI(&before); - SDL_GL_SwapWindow(this->sdlWindow); + if (this->opt.preventBuffer) + { + unsigned int before, after; + glXGetVideoSyncSGI(&before); + SDL_GL_SwapWindow(this->sdlWindow); - // wait for the swap to happen to ensure we dont buffer frames - glXGetVideoSyncSGI(&after); - if (before == after) - glXWaitVideoSyncSGI(1, 0, &before); + // wait for the swap to happen to ensure we dont buffer frames + glXGetVideoSyncSGI(&after); + if (before == after) + glXWaitVideoSyncSGI(1, 0, &before); + } + else + SDL_GL_SwapWindow(this->sdlWindow); ++this->frameCount; const uint64_t t = nanotime(); @@ -738,6 +745,15 @@ static void handle_opt_vsync(void * opaque, const char *value) this->opt.vsync = LG_RendererValueToBool(value); } +static void handle_opt_prevent_buffer(void * opaque, const char *value) +{ + struct LGR_OpenGLBasic * this = (struct LGR_OpenGLBasic *)opaque; + if (!this) + return; + + this->opt.preventBuffer = LG_RendererValueToBool(value); +} + static void handle_opt_split_mouse(void * opaque, const char *value) { struct LGR_OpenGLBasic * this = (struct LGR_OpenGLBasic *)opaque; @@ -761,6 +777,12 @@ static LG_RendererOpt lgr_opengl_basic_options[] = .validator = LG_RendererValidatorBool, .handler = handle_opt_vsync }, + { + .name = "preventBuffer", + .desc = "Prevent the driver from buffering frames [default: enabled]", + .validator = LG_RendererValidatorBool, + .handler = handle_opt_prevent_buffer + }, { .name = "splitMouse", .desc = "Draw mouse updates directly to the front buffer [default: disabled]", diff --git a/client/renderers/opengl.c b/client/renderers/opengl.c index a476b1a0..7425c42a 100644 --- a/client/renderers/opengl.c +++ b/client/renderers/opengl.c @@ -47,14 +47,16 @@ struct Options { bool mipmap; bool vsync; + bool preventBuffer; bool splitMouse; }; static struct Options defaultOptions = { - .mipmap = true, - .vsync = true, - .splitMouse = false + .mipmap = true, + .vsync = true, + .preventBuffer = true, + .splitMouse = false }; struct LGR_OpenGL @@ -764,14 +766,19 @@ bool lgr_opengl_render(void * opaque) if (this->fpsTexture) glCallList(this->fpsList); - unsigned int before, after; - glXGetVideoSyncSGI(&before); - SDL_GL_SwapWindow(this->sdlWindow); + if (this->opt.preventBuffer) + { + unsigned int before, after; + glXGetVideoSyncSGI(&before); + SDL_GL_SwapWindow(this->sdlWindow); - // wait for the swap to happen to ensure we dont buffer frames - glXGetVideoSyncSGI(&after); - if (before == after) - glXWaitVideoSyncSGI(1, 0, &before); + // wait for the swap to happen to ensure we dont buffer frames // + glXGetVideoSyncSGI(&after); + if (before == after) + glXWaitVideoSyncSGI(1, 0, &before); + } + else + SDL_GL_SwapWindow(this->sdlWindow); ++this->frameCount; const uint64_t t = nanotime(); @@ -802,6 +809,15 @@ static void handle_opt_vsync(void * opaque, const char *value) this->opt.vsync = LG_RendererValueToBool(value); } +static void handle_opt_prevent_buffer(void * opaque, const char *value) +{ + struct LGR_OpenGL * this = (struct LGR_OpenGL *)opaque; + if (!this) + return; + + this->opt.preventBuffer = LG_RendererValueToBool(value); +} + static void handle_opt_split_mouse(void * opaque, const char *value) { struct LGR_OpenGL * this = (struct LGR_OpenGL *)opaque; @@ -825,6 +841,12 @@ static LG_RendererOpt lgr_opengl_options[] = .validator = LG_RendererValidatorBool, .handler = handle_opt_vsync }, + { + .name = "preventBuffer", + .desc = "Prevent the driver from buffering frames [default: enabled]", + .validator = LG_RendererValidatorBool, + .handler = handle_opt_prevent_buffer + }, { .name = "splitMouse", .desc = "Draw mouse updates directly to the front buffer [default: disabled]",