i965: Add support for MRT to the new FS backend.
[mesa.git] / src / egl / main / eglglobals.h
index 14d8ea487af04467a83ba8d0b0f973642c434421..c3771a8ef10bebe7feb55968d39aeaf185a4de22 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,13 @@ struct _egl_thread_info
  */
 struct _egl_global
 {
-   EGLBoolean Initialized;
-
-   _EGLHashtable *Displays;
-   _EGLHashtable *Surfaces;
-
-   EGLScreenMESA FreeScreenHandle;
+   _EGLMutex *Mutex;
 
-   /* bitmaks of supported APIs (supported by _some_ driver) */
-   EGLint ClientAPIsMask;
+   /* the list of all displays */
+   _EGLDisplay *DisplayList;
 
-   char ClientAPIs[1000];   /**< updated by eglQueryString */
-
-   /* XXX temporary - should be thread-specific data (TSD) */
-   _EGLThreadInfo *ThreadInfo;
-
-   EGLint NumDrivers;
-   _EGLDriver *Drivers[10];
+   EGLint NumAtExitCalls;
+   void (*AtExitCalls[10])(void);
 };
 
 
@@ -45,27 +25,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 */