st/egl: One driver per hardware.
[mesa.git] / src / egl / main / eglglobals.h
index 14d8ea487af04467a83ba8d0b0f973642c434421..436889802080d2886b2d7dfa7f7f110fb18be832 100644 (file)
@@ -1,19 +1,9 @@
 #ifndef EGLGLOBALS_INCLUDED
 #define EGLGLOBALS_INCLUDED
 
-#include "egltypedefs.h"
-#include "eglhash.h"
-
 
-/**
- * Per-thread info
- */
-struct _egl_thread_info
-{
-   EGLint LastError;
-   _EGLContext *CurrentContext;
-   EGLenum CurrentAPI;
-};
+#include "egltypedefs.h"
+#include "eglmutex.h"
 
 
 /**
@@ -21,23 +11,19 @@ struct _egl_thread_info
  */
 struct _egl_global
 {
-   EGLBoolean Initialized;
+   _EGLMutex *Mutex;
 
-   _EGLHashtable *Displays;
-   _EGLHashtable *Surfaces;
+   /* the list of all displays */
+   _EGLDisplay *DisplayList;
 
    EGLScreenMESA FreeScreenHandle;
 
-   /* bitmaks of supported APIs (supported by _some_ driver) */
-   EGLint ClientAPIsMask;
-
-   char ClientAPIs[1000];   /**< updated by eglQueryString */
-
-   /* XXX temporary - should be thread-specific data (TSD) */
-   _EGLThreadInfo *ThreadInfo;
-
+   /* these never change after preloading */
    EGLint NumDrivers;
    _EGLDriver *Drivers[10];
+
+   EGLint NumAtExitCalls;
+   void (*AtExitCalls[10])(void);
 };
 
 
@@ -45,27 +31,7 @@ extern struct _egl_global _eglGlobal;
 
 
 extern void
-_eglInitGlobals(void);
-
-
-extern void
-_eglDestroyGlobals(void);
-
-
-extern _EGLThreadInfo *
-_eglNewThreadInfo(void);
-
-
-extern void
-_eglDeleteThreadData(_EGLThreadInfo *t);
-
-
-extern _EGLThreadInfo *
-_eglGetCurrentThread(void);
-
-
-extern void
-_eglError(EGLint errCode, const char *msg);
+_eglAddAtExitCall(void (*func)(void));
 
 
 #endif /* EGLGLOBALS_INCLUDED */