scons: Updates for targets/egl-static.
[mesa.git] / src / egl / main / egldriver.h
index 4066c6ec1df9b9c3ab134a7ce78763b7423b7d88..d61775791939ea4c07210776074e4908ab112b84 100644 (file)
@@ -4,19 +4,36 @@
 
 #include "egltypedefs.h"
 #include "eglapi.h"
-#include "egldefines.h"
+#include <stddef.h>
+
+/**
+ * Define an inline driver typecast function.
+ *
+ * Note that this macro defines a function and should not be ended with a
+ * semicolon when used.
+ */
+#define _EGL_DRIVER_TYPECAST(drvtype, egltype, code)           \
+   static INLINE struct drvtype *drvtype(const egltype *obj)   \
+   { return (struct drvtype *) code; }
 
 
 /**
- * Optional EGL extensions info.
+ * Define the driver typecast functions for _EGLDriver, _EGLDisplay,
+ * _EGLContext, _EGLSurface, and _EGLConfig.
+ *
+ * Note that this macro defines several functions and should not be ended with
+ * a semicolon when used.
  */
-struct _egl_extensions
-{
-   EGLBoolean MESA_screen_surface;
-   EGLBoolean MESA_copy_context;
+#define _EGL_DRIVER_STANDARD_TYPECASTS(drvname)                            \
+   _EGL_DRIVER_TYPECAST(drvname ## _driver, _EGLDriver, obj)               \
+   /* note that this is not a direct cast */                               \
+   _EGL_DRIVER_TYPECAST(drvname ## _display, _EGLDisplay, obj->DriverData) \
+   _EGL_DRIVER_TYPECAST(drvname ## _context, _EGLContext, obj)             \
+   _EGL_DRIVER_TYPECAST(drvname ## _surface, _EGLSurface, obj)             \
+   _EGL_DRIVER_TYPECAST(drvname ## _config, _EGLConfig, obj)
 
-   char String[_EGL_MAX_EXTENSIONS_LEN];
-};
+
+typedef _EGLDriver *(*_EGLMain_t)(const char *args);
 
 
 /**
@@ -24,58 +41,65 @@ struct _egl_extensions
  */
 struct _egl_driver
 {
-   EGLBoolean Initialized; /**< set by driver after initialized */
-
-   void *LibHandle; /**< dlopen handle */
-
    const char *Name;  /**< name of this driver */
 
-   int APImajor, APIminor; /**< as returned by eglInitialize() */
-   char Version[1000];       /**< initialized from APImajor/minor, Name */
-
-   /** Bitmask of supported APIs (EGL_xx_BIT) set by the driver during init */
-   EGLint ClientAPIsMask;
+   /**
+    * Probe a display and return a score.
+    *
+    * Roughly,
+    *  50 means the driver supports the display;
+    *  90 means the driver can accelerate the display;
+    * 100 means a perfect match.
+    */
+   EGLint (*Probe)(_EGLDriver *drv, _EGLDisplay *dpy);
+
+   /**
+    * Release the driver resource.
+    *
+    * It is called before dlclose().
+    */
+   void (*Unload)(_EGLDriver *drv);
 
    _EGLAPI API;  /**< EGL API dispatch table */
-
-   _EGLExtensions Extensions;
-
-   int LargestPbuffer;
 };
 
 
-extern _EGLDriver *_eglMain(_EGLDisplay *dpy, const char *args);
-
+extern _EGLDriver *
+_eglBuiltInDriverGALLIUM(const char *args);
 
-extern const char *
-_eglChooseDRMDriver(int card);
 
-extern const char *
-_eglChooseDriver(_EGLDisplay *dpy);
+extern _EGLDriver *
+_eglBuiltInDriverDRI2(const char *args);
 
 
 extern _EGLDriver *
-_eglOpenDriver(_EGLDisplay *dpy, const char *driverName, const char *args);
+_eglBuiltInDriverGLX(const char *args);
 
 
-extern EGLBoolean
-_eglCloseDriver(_EGLDriver *drv, EGLDisplay dpy);
+PUBLIC _EGLDriver *
+_eglMain(const char *args);
 
 
-extern void
-_eglSaveDriver(_EGLDriver *drv);
+extern _EGLDriver *
+_eglMatchDriver(_EGLDisplay *dpy, EGLBoolean probe_only);
 
 
-extern _EGLDriver *
-_eglLookupDriver(EGLDisplay d);
+extern __eglMustCastToProperFunctionPointerType
+_eglGetDriverProc(const char *procname);
 
 
 extern void
+_eglUnloadDrivers(void);
+
+
+/* defined in eglfallbacks.c */
+PUBLIC void
 _eglInitDriverFallbacks(_EGLDriver *drv);
 
 
-extern EGLint
-_eglFindAPIs(void);
+PUBLIC void
+_eglSearchPathForEach(EGLBoolean (*callback)(const char *, size_t, void *),
+                      void *callback_data);
 
 
 #endif /* EGLDRIVER_INCLUDED */