2005-04-22 22:09:39 +01:00
|
|
|
#ifndef EGLDRIVER_INCLUDED
|
|
|
|
#define EGLDRIVER_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
#include "egltypedefs.h"
|
2005-11-24 04:02:16 +00:00
|
|
|
#include "eglapi.h"
|
2005-11-29 04:43:37 +00:00
|
|
|
|
|
|
|
|
2010-02-04 04:52:15 +00:00
|
|
|
/**
|
|
|
|
* Define an inline driver typecast function.
|
2010-02-05 03:42:05 +00:00
|
|
|
*
|
|
|
|
* Note that this macro defines a function and should not be ended with a
|
|
|
|
* semicolon when used.
|
2010-02-04 04:52:15 +00:00
|
|
|
*/
|
|
|
|
#define _EGL_DRIVER_TYPECAST(drvtype, egltype, code) \
|
|
|
|
static INLINE struct drvtype *drvtype(const egltype *obj) \
|
|
|
|
{ return (struct drvtype *) code; }
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Define the driver typecast functions for _EGLDriver, _EGLDisplay,
|
|
|
|
* _EGLContext, _EGLSurface, and _EGLConfig.
|
2010-02-05 03:42:05 +00:00
|
|
|
*
|
|
|
|
* Note that this macro defines several functions and should not be ended with
|
|
|
|
* a semicolon when used.
|
2010-02-04 04:52:15 +00:00
|
|
|
*/
|
|
|
|
#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)
|
|
|
|
|
|
|
|
|
2010-01-29 01:00:30 +00:00
|
|
|
typedef _EGLDriver *(*_EGLMain_t)(const char *args);
|
|
|
|
|
|
|
|
|
2005-04-22 22:09:39 +01:00
|
|
|
/**
|
|
|
|
* Base class for device drivers.
|
|
|
|
*/
|
|
|
|
struct _egl_driver
|
|
|
|
{
|
2008-05-30 00:02:31 +01:00
|
|
|
const char *Name; /**< name of this driver */
|
2010-01-19 10:39:59 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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().
|
|
|
|
*/
|
2009-08-13 06:01:48 +01:00
|
|
|
void (*Unload)(_EGLDriver *drv);
|
2008-05-30 00:02:31 +01:00
|
|
|
|
2008-05-28 22:43:41 +01:00
|
|
|
_EGLAPI API; /**< EGL API dispatch table */
|
2005-04-22 22:09:39 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2010-01-05 13:39:15 +00:00
|
|
|
PUBLIC _EGLDriver *
|
|
|
|
_eglMain(const char *args);
|
2005-04-22 22:09:39 +01:00
|
|
|
|
|
|
|
|
|
|
|
extern _EGLDriver *
|
2010-07-04 08:55:12 +01:00
|
|
|
_eglMatchDriver(_EGLDisplay *dpy, EGLBoolean probe_only);
|
2005-04-22 22:09:39 +01:00
|
|
|
|
|
|
|
|
2010-07-04 08:55:12 +01:00
|
|
|
extern __eglMustCastToProperFunctionPointerType
|
|
|
|
_eglGetDriverProc(const char *procname);
|
2010-01-19 10:13:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
extern void
|
2009-08-13 06:01:48 +01:00
|
|
|
_eglUnloadDrivers(void);
|
2008-05-30 21:50:33 +01:00
|
|
|
|
|
|
|
|
2010-01-05 13:39:15 +00:00
|
|
|
PUBLIC void
|
2005-04-22 22:09:39 +01:00
|
|
|
_eglInitDriverFallbacks(_EGLDriver *drv);
|
|
|
|
|
|
|
|
|
2010-05-05 10:37:19 +01:00
|
|
|
PUBLIC void
|
|
|
|
_eglSearchPathForEach(EGLBoolean (*callback)(const char *, size_t, void *),
|
|
|
|
void *callback_data);
|
|
|
|
|
|
|
|
|
2005-04-22 22:09:39 +01:00
|
|
|
#endif /* EGLDRIVER_INCLUDED */
|