From 3c58d4c700bc1d0a0d56c26645e900201b7f249e Mon Sep 17 00:00:00 2001 From: Chad Versace Date: Fri, 11 Oct 2013 16:04:55 -0700 Subject: [PATCH] egl: Enable EGL_EXT_client_extensions Insert two fields into _egl_global to hold the client extensions and statically initialize them: ClientExtensions // a struct of bools ClientExtensionString Post-patch, Mesa supports exactly one client extension, EGL_EXT_client_extensions. Signed-off-by: Chad Versace Reviewed-by: Kenneth Graunke Reviewed-by: Ian Romanick --- src/egl/main/eglapi.c | 8 +++++++- src/egl/main/eglglobals.c | 8 ++++++++ src/egl/main/eglglobals.h | 7 +++++++ 3 files changed, 22 insertions(+), 1 deletion(-) diff --git a/src/egl/main/eglapi.c b/src/egl/main/eglapi.c index 2d8653f04cb..66f96de4140 100644 --- a/src/egl/main/eglapi.c +++ b/src/egl/main/eglapi.c @@ -87,6 +87,7 @@ #include #include +#include "eglglobals.h" #include "eglcontext.h" #include "egldisplay.h" #include "egltypedefs.h" @@ -354,10 +355,15 @@ eglTerminate(EGLDisplay dpy) const char * EGLAPIENTRY eglQueryString(EGLDisplay dpy, EGLint name) { - _EGLDisplay *disp = _eglLockDisplay(dpy); + _EGLDisplay *disp; _EGLDriver *drv; const char *ret; + if (dpy == EGL_NO_DISPLAY && name == EGL_EXTENSIONS) { + RETURN_EGL_SUCCESS(NULL, _eglGlobal.ClientExtensionString); + } + + disp = _eglLockDisplay(dpy); _EGL_CHECK_DISPLAY(disp, NULL, drv); ret = drv->API.QueryString(drv, disp, name); diff --git a/src/egl/main/eglglobals.c b/src/egl/main/eglglobals.c index f53f078d710..5c2fddfbf9e 100644 --- a/src/egl/main/eglglobals.c +++ b/src/egl/main/eglglobals.c @@ -47,6 +47,14 @@ struct _egl_global _eglGlobal = _eglUnloadDrivers, /* always called last */ _eglFiniDisplay }, + + /* ClientExtensions */ + { + true /* EGL_EXT_client_extensions */ + }, + + /* ClientExtensionsString */ + "EGL_EXT_client_extensions" }; diff --git a/src/egl/main/eglglobals.h b/src/egl/main/eglglobals.h index b40e30e2251..63428f7f45a 100644 --- a/src/egl/main/eglglobals.h +++ b/src/egl/main/eglglobals.h @@ -31,6 +31,7 @@ #ifndef EGLGLOBALS_INCLUDED #define EGLGLOBALS_INCLUDED +#include #include "egltypedefs.h" #include "eglmutex.h" @@ -48,6 +49,12 @@ struct _egl_global EGLint NumAtExitCalls; void (*AtExitCalls[10])(void); + + struct _egl_client_extensions { + bool EXT_client_extensions; + } ClientExtensions; + + const char *ClientExtensionString; }; -- 2.30.2