From c2af57a978b29e536260b6bf8440827a4d8e01f7 Mon Sep 17 00:00:00 2001 From: dec05eba Date: Thu, 21 Mar 2024 10:49:11 +0100 Subject: Destroy glx context on fail/deinit --- src/egl.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'src') diff --git a/src/egl.c b/src/egl.c index 5f6da48..2ad4f85 100644 --- a/src/egl.c +++ b/src/egl.c @@ -318,6 +318,12 @@ static bool gsr_egl_switch_to_glx_context(gsr_egl *self) { return true; fail: + if(self->glx_context) { + self->glXMakeContextCurrent(self->x11.dpy, None, None, NULL); + self->glXDestroyContext(self->x11.dpy, self->glx_context); + self->glx_context = NULL; + self->glx_fb_config = NULL; + } return false; } @@ -372,6 +378,7 @@ static bool gsr_egl_load_glx(gsr_egl *self, void *library) { { (void**)&self->glXChooseFBConfig, "glXChooseFBConfig" }, { (void**)&self->glXMakeContextCurrent, "glXMakeContextCurrent" }, { (void**)&self->glXCreateNewContext, "glXCreateNewContext" }, + { (void**)&self->glXDestroyContext, "glXDestroyContext" }, { (void**)&self->glXSwapBuffers, "glXSwapBuffers" }, { NULL, NULL } @@ -567,6 +574,13 @@ void gsr_egl_unload(gsr_egl *self) { self->egl_display = NULL; } + if(self->glx_context) { + self->glXMakeContextCurrent(self->x11.dpy, None, None, NULL); + self->glXDestroyContext(self->x11.dpy, self->glx_context); + self->glx_context = NULL; + self->glx_fb_config = NULL; + } + if(self->x11.window) { XDestroyWindow(self->x11.dpy, self->x11.window); self->x11.window = None; -- cgit v1.2.3