scons: Updates for targets/egl-static.
[mesa.git] / src / egl / main / eglglobals.c
index 870316865007ecd6e16ea0dd3a74bf52d405758a..52eebb07f6c4e3959c45929f659fcabe079ef613 100644 (file)
@@ -1,13 +1,50 @@
 #include <stdlib.h>
+#include <assert.h>
 #include "eglglobals.h"
 #include "egldisplay.h"
-#include "egllog.h"
+#include "egldriver.h"
+#include "eglmutex.h"
 
+
+static _EGL_DECLARE_MUTEX(_eglGlobalMutex);
 struct _egl_global _eglGlobal =
 {
-   1,                      /* FreeScreenHandle */
-   0x0,                    /* ClientAPIsMask */
-   { 0x0 },                /* ClientAPIs */
-   0,                      /* NumDrivers */
-   { NULL },               /* Drivers */
+   &_eglGlobalMutex,       /* Mutex */
+   NULL,                   /* DisplayList */
+   2,                      /* NumAtExitCalls */
+   {
+      /* default AtExitCalls, called in reverse order */
+      _eglUnloadDrivers, /* always called last */
+      _eglFiniDisplay
+   },
 };
+
+
+static void
+_eglAtExit(void)
+{
+   EGLint i;
+   for (i = _eglGlobal.NumAtExitCalls - 1; i >= 0; i--)
+      _eglGlobal.AtExitCalls[i]();
+}
+
+
+void
+_eglAddAtExitCall(void (*func)(void))
+{
+   if (func) {
+      static EGLBoolean registered = EGL_FALSE;
+
+      _eglLockMutex(_eglGlobal.Mutex);
+
+      if (!registered) {
+         atexit(_eglAtExit);
+         registered = EGL_TRUE;
+      }
+
+      assert(_eglGlobal.NumAtExitCalls < ARRAY_SIZE(_eglGlobal.AtExitCalls));
+      _eglGlobal.AtExitCalls[_eglGlobal.NumAtExitCalls++] = func;
+
+      _eglUnlockMutex(_eglGlobal.Mutex);
+   }
+}