2 * Public EGL API entrypoints
4 * Generally, we use the EGLDisplay parameter as a key to lookup the
5 * appropriate device driver handle, then jump though the driver's
6 * dispatch table to handle the function.
8 * That allows us the option of supporting multiple, simultaneous,
9 * heterogeneous hardware devices in the future.
11 * The EGLDisplay, EGLConfig, EGLContext and EGLSurface types are
12 * opaque handles. Internal objects are linked to a display to
15 * For each public API entry point, the opaque handles are looked up
16 * before being dispatched to the drivers. When it fails to look up
26 * is generated and the driver function is not called. An
27 * uninitialized EGLDisplay has no driver associated with it. When
28 * such display is detected,
34 * Some of the entry points use current display, context, or surface
35 * implicitly. For such entry points, the implicit objects are also
36 * checked before calling the driver function. Other than the
37 * errors listed above,
39 * EGL_BAD_CURRENT_SURFACE
41 * may also be generated.
43 * Notes on naming conventions:
45 * eglFooBar - public EGL function
46 * EGL_FOO_BAR - public EGL token
47 * EGLDatatype - public EGL datatype
49 * _eglFooBar - private EGL function
50 * _EGLDatatype - private EGL datatype, typedef'd struct
51 * _egl_struct - private EGL struct, non-typedef'd
59 #include "eglcontext.h"
60 #include "egldisplay.h"
61 #include "egltypedefs.h"
62 #include "eglglobals.h"
63 #include "egldriver.h"
64 #include "eglsurface.h"
65 #include "eglconfig.h"
66 #include "eglscreen.h"
71 * This is typically the first EGL function that an application calls.
72 * We initialize our global vars and create a private _EGLDisplay object.
74 EGLDisplay EGLAPIENTRY
75 eglGetDisplay(NativeDisplayType nativeDisplay
)
78 dpy
= _eglFindDisplay(nativeDisplay
);
80 dpy
= _eglNewDisplay(nativeDisplay
);
84 return _eglGetDisplayHandle(dpy
);
89 * This is typically the second EGL function that an application calls.
90 * Here we load/initialize the actual hardware driver.
92 EGLBoolean EGLAPIENTRY
93 eglInitialize(EGLDisplay dpy
, EGLint
*major
, EGLint
*minor
)
95 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
97 EGLint major_int
, minor_int
;
100 return _eglError(EGL_BAD_DISPLAY
, __FUNCTION__
);
104 drv
= _eglOpenDriver(disp
);
106 return _eglError(EGL_NOT_INITIALIZED
, __FUNCTION__
);
108 /* Initialize the particular display now */
109 if (!drv
->API
.Initialize(drv
, disp
, &major_int
, &minor_int
)) {
110 _eglCloseDriver(drv
, disp
);
111 return _eglError(EGL_NOT_INITIALIZED
, __FUNCTION__
);
114 disp
->APImajor
= major_int
;
115 disp
->APIminor
= minor_int
;
116 snprintf(disp
->Version
, sizeof(disp
->Version
),
117 "%d.%d (%s)", major_int
, minor_int
, drv
->Name
);
119 /* limit to APIs supported by core */
120 disp
->ClientAPIsMask
&= _EGL_API_ALL_BITS
;
124 major_int
= disp
->APImajor
;
125 minor_int
= disp
->APIminor
;
128 /* Update applications version of major and minor if not NULL */
129 if ((major
!= NULL
) && (minor
!= NULL
)) {
138 EGLBoolean EGLAPIENTRY
139 eglTerminate(EGLDisplay dpy
)
141 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
145 return _eglError(EGL_BAD_DISPLAY
, __FUNCTION__
);
149 drv
->API
.Terminate(drv
, disp
);
150 _eglCloseDriver(drv
, disp
);
159 * A bunch of check functions and declare macros to simply error checking.
161 static INLINE _EGLDriver
*
162 _eglCheckDisplay(_EGLDisplay
*disp
, const char *msg
)
165 _eglError(EGL_BAD_DISPLAY
, msg
);
169 _eglError(EGL_NOT_INITIALIZED
, msg
);
176 static INLINE _EGLDriver
*
177 _eglCheckSurface(_EGLDisplay
*disp
, _EGLSurface
*surf
, const char *msg
)
179 _EGLDriver
*drv
= _eglCheckDisplay(disp
, msg
);
183 _eglError(EGL_BAD_SURFACE
, msg
);
190 static INLINE _EGLDriver
*
191 _eglCheckContext(_EGLDisplay
*disp
, _EGLContext
*context
, const char *msg
)
193 _EGLDriver
*drv
= _eglCheckDisplay(disp
, msg
);
197 _eglError(EGL_BAD_CONTEXT
, msg
);
204 static INLINE _EGLDriver
*
205 _eglCheckConfig(_EGLDisplay
*disp
, _EGLConfig
*conf
, const char *msg
)
207 _EGLDriver
*drv
= _eglCheckDisplay(disp
, msg
);
211 _eglError(EGL_BAD_CONFIG
, msg
);
218 #define _EGL_DECLARE_DD(dpy) \
219 _EGLDisplay *disp = _eglLookupDisplay(dpy); \
222 drv = _eglCheckDisplay(disp, __FUNCTION__); \
228 #define _EGL_DECLARE_DD_AND_SURFACE(dpy, surface) \
229 _EGLDisplay *disp = _eglLookupDisplay(dpy); \
230 _EGLSurface *surf = _eglLookupSurface((surface), disp); \
233 drv = _eglCheckSurface(disp, surf, __FUNCTION__); \
239 #define _EGL_DECLARE_DD_AND_CONTEXT(dpy, ctx) \
240 _EGLDisplay *disp = _eglLookupDisplay(dpy); \
241 _EGLContext *context = _eglLookupContext((ctx), disp); \
244 drv = _eglCheckContext(disp, context, __FUNCTION__); \
250 #ifdef EGL_MESA_screen_surface
253 static INLINE _EGLDriver
*
254 _eglCheckScreen(_EGLDisplay
*disp
, _EGLScreen
*scrn
, const char *msg
)
256 _EGLDriver
*drv
= _eglCheckDisplay(disp
, msg
);
260 _eglError(EGL_BAD_SCREEN_MESA
, msg
);
267 static INLINE _EGLDriver
*
268 _eglCheckMode(_EGLDisplay
*disp
, _EGLMode
*m
, const char *msg
)
270 _EGLDriver
*drv
= _eglCheckDisplay(disp
, msg
);
274 _eglError(EGL_BAD_MODE_MESA
, msg
);
281 #define _EGL_DECLARE_DD_AND_SCREEN(dpy, screen) \
282 _EGLDisplay *disp = _eglLookupDisplay(dpy); \
283 _EGLScreen *scrn = _eglLookupScreen((screen), disp); \
286 drv = _eglCheckScreen(disp, scrn, __FUNCTION__); \
292 #define _EGL_DECLARE_DD_AND_MODE(dpy, mode) \
293 _EGLDisplay *disp = _eglLookupDisplay(dpy); \
294 _EGLMode *m = _eglLookupMode((mode), disp); \
297 drv = _eglCheckMode(disp, m, __FUNCTION__); \
303 #endif /* EGL_MESA_screen_surface */
306 const char * EGLAPIENTRY
307 eglQueryString(EGLDisplay dpy
, EGLint name
)
309 _EGL_DECLARE_DD(dpy
);
310 return drv
->API
.QueryString(drv
, disp
, name
);
314 EGLBoolean EGLAPIENTRY
315 eglGetConfigs(EGLDisplay dpy
, EGLConfig
*configs
,
316 EGLint config_size
, EGLint
*num_config
)
318 _EGL_DECLARE_DD(dpy
);
319 return drv
->API
.GetConfigs(drv
, disp
, configs
, config_size
, num_config
);
323 EGLBoolean EGLAPIENTRY
324 eglChooseConfig(EGLDisplay dpy
, const EGLint
*attrib_list
, EGLConfig
*configs
,
325 EGLint config_size
, EGLint
*num_config
)
327 _EGL_DECLARE_DD(dpy
);
328 return drv
->API
.ChooseConfig(drv
, disp
, attrib_list
, configs
,
329 config_size
, num_config
);
333 EGLBoolean EGLAPIENTRY
334 eglGetConfigAttrib(EGLDisplay dpy
, EGLConfig config
,
335 EGLint attribute
, EGLint
*value
)
337 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
338 _EGLConfig
*conf
= _eglLookupConfig(config
, disp
);
341 drv
= _eglCheckConfig(disp
, conf
, __FUNCTION__
);
345 return drv
->API
.GetConfigAttrib(drv
, disp
, conf
, attribute
, value
);
349 EGLContext EGLAPIENTRY
350 eglCreateContext(EGLDisplay dpy
, EGLConfig config
, EGLContext share_list
,
351 const EGLint
*attrib_list
)
353 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
354 _EGLConfig
*conf
= _eglLookupConfig(config
, disp
);
355 _EGLContext
*share
= _eglLookupContext(share_list
, disp
);
357 _EGLContext
*context
;
359 drv
= _eglCheckConfig(disp
, conf
, __FUNCTION__
);
361 return EGL_NO_CONTEXT
;
362 if (!share
&& share_list
!= EGL_NO_CONTEXT
) {
363 _eglError(EGL_BAD_CONTEXT
, __FUNCTION__
);
364 return EGL_NO_CONTEXT
;
367 context
= drv
->API
.CreateContext(drv
, disp
, conf
, share
, attrib_list
);
369 return _eglLinkContext(context
, disp
);
371 return EGL_NO_CONTEXT
;
375 EGLBoolean EGLAPIENTRY
376 eglDestroyContext(EGLDisplay dpy
, EGLContext ctx
)
378 _EGL_DECLARE_DD_AND_CONTEXT(dpy
, ctx
);
379 _eglUnlinkContext(context
);
380 return drv
->API
.DestroyContext(drv
, disp
, context
);
384 EGLBoolean EGLAPIENTRY
385 eglMakeCurrent(EGLDisplay dpy
, EGLSurface draw
, EGLSurface read
,
388 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
389 _EGLContext
*context
= _eglLookupContext(ctx
, disp
);
390 _EGLSurface
*draw_surf
= _eglLookupSurface(draw
, disp
);
391 _EGLSurface
*read_surf
= _eglLookupSurface(read
, disp
);
394 drv
= _eglCheckDisplay(disp
, __FUNCTION__
);
397 if (!context
&& ctx
!= EGL_NO_CONTEXT
)
398 return _eglError(EGL_BAD_CONTEXT
, __FUNCTION__
);
399 if ((!draw_surf
&& draw
!= EGL_NO_SURFACE
) ||
400 (!read_surf
&& read
!= EGL_NO_SURFACE
))
401 return _eglError(EGL_BAD_SURFACE
, __FUNCTION__
);
403 return drv
->API
.MakeCurrent(drv
, disp
, draw_surf
, read_surf
, context
);
407 EGLBoolean EGLAPIENTRY
408 eglQueryContext(EGLDisplay dpy
, EGLContext ctx
,
409 EGLint attribute
, EGLint
*value
)
411 _EGL_DECLARE_DD_AND_CONTEXT(dpy
, ctx
);
412 return drv
->API
.QueryContext(drv
, disp
, context
, attribute
, value
);
416 EGLSurface EGLAPIENTRY
417 eglCreateWindowSurface(EGLDisplay dpy
, EGLConfig config
,
418 NativeWindowType window
, const EGLint
*attrib_list
)
420 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
421 _EGLConfig
*conf
= _eglLookupConfig(config
, disp
);
425 drv
= _eglCheckConfig(disp
, conf
, __FUNCTION__
);
427 return EGL_NO_SURFACE
;
429 surf
= drv
->API
.CreateWindowSurface(drv
, disp
, conf
, window
, attrib_list
);
431 return _eglLinkSurface(surf
, disp
);
433 return EGL_NO_SURFACE
;
437 EGLSurface EGLAPIENTRY
438 eglCreatePixmapSurface(EGLDisplay dpy
, EGLConfig config
,
439 NativePixmapType pixmap
, const EGLint
*attrib_list
)
441 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
442 _EGLConfig
*conf
= _eglLookupConfig(config
, disp
);
446 drv
= _eglCheckConfig(disp
, conf
, __FUNCTION__
);
448 return EGL_NO_SURFACE
;
450 surf
= drv
->API
.CreatePixmapSurface(drv
, disp
, conf
, pixmap
, attrib_list
);
452 return _eglLinkSurface(surf
, disp
);
454 return EGL_NO_SURFACE
;
458 EGLSurface EGLAPIENTRY
459 eglCreatePbufferSurface(EGLDisplay dpy
, EGLConfig config
,
460 const EGLint
*attrib_list
)
462 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
463 _EGLConfig
*conf
= _eglLookupConfig(config
, disp
);
467 drv
= _eglCheckConfig(disp
, conf
, __FUNCTION__
);
469 return EGL_NO_SURFACE
;
471 surf
= drv
->API
.CreatePbufferSurface(drv
, disp
, conf
, attrib_list
);
473 return _eglLinkSurface(surf
, disp
);
475 return EGL_NO_SURFACE
;
479 EGLBoolean EGLAPIENTRY
480 eglDestroySurface(EGLDisplay dpy
, EGLSurface surface
)
482 _EGL_DECLARE_DD_AND_SURFACE(dpy
, surface
);
483 _eglUnlinkSurface(surf
);
484 return drv
->API
.DestroySurface(drv
, disp
, surf
);
487 EGLBoolean EGLAPIENTRY
488 eglQuerySurface(EGLDisplay dpy
, EGLSurface surface
,
489 EGLint attribute
, EGLint
*value
)
491 _EGL_DECLARE_DD_AND_SURFACE(dpy
, surface
);
492 return drv
->API
.QuerySurface(drv
, disp
, surf
, attribute
, value
);
495 EGLBoolean EGLAPIENTRY
496 eglSurfaceAttrib(EGLDisplay dpy
, EGLSurface surface
,
497 EGLint attribute
, EGLint value
)
499 _EGL_DECLARE_DD_AND_SURFACE(dpy
, surface
);
500 return drv
->API
.SurfaceAttrib(drv
, disp
, surf
, attribute
, value
);
504 EGLBoolean EGLAPIENTRY
505 eglBindTexImage(EGLDisplay dpy
, EGLSurface surface
, EGLint buffer
)
507 _EGL_DECLARE_DD_AND_SURFACE(dpy
, surface
);
508 return drv
->API
.BindTexImage(drv
, disp
, surf
, buffer
);
512 EGLBoolean EGLAPIENTRY
513 eglReleaseTexImage(EGLDisplay dpy
, EGLSurface surface
, EGLint buffer
)
515 _EGL_DECLARE_DD_AND_SURFACE(dpy
, surface
);
516 return drv
->API
.ReleaseTexImage(drv
, disp
, surf
, buffer
);
520 EGLBoolean EGLAPIENTRY
521 eglSwapInterval(EGLDisplay dpy
, EGLint interval
)
523 _EGLContext
*ctx
= _eglGetCurrentContext();
525 _EGL_DECLARE_DD(dpy
);
527 if (!ctx
|| !_eglIsContextLinked(ctx
) || ctx
->Display
!= disp
)
528 return _eglError(EGL_BAD_CONTEXT
, __FUNCTION__
);
530 surf
= ctx
->DrawSurface
;
531 if (!_eglIsSurfaceLinked(surf
))
532 return _eglError(EGL_BAD_SURFACE
, __FUNCTION__
);
534 return drv
->API
.SwapInterval(drv
, disp
, surf
, interval
);
538 EGLBoolean EGLAPIENTRY
539 eglSwapBuffers(EGLDisplay dpy
, EGLSurface surface
)
541 _EGLContext
*ctx
= _eglGetCurrentContext();
542 _EGL_DECLARE_DD_AND_SURFACE(dpy
, surface
);
544 /* surface must be bound to current context in EGL 1.4 */
545 if (!ctx
|| !_eglIsContextLinked(ctx
) || surf
!= ctx
->DrawSurface
)
546 return _eglError(EGL_BAD_SURFACE
, __FUNCTION__
);
548 return drv
->API
.SwapBuffers(drv
, disp
, surf
);
552 EGLBoolean EGLAPIENTRY
553 eglCopyBuffers(EGLDisplay dpy
, EGLSurface surface
, NativePixmapType target
)
555 _EGL_DECLARE_DD_AND_SURFACE(dpy
, surface
);
556 return drv
->API
.CopyBuffers(drv
, disp
, surf
, target
);
560 EGLBoolean EGLAPIENTRY
563 _EGLDisplay
*disp
= _eglGetCurrentDisplay();
569 /* a current display is always initialized */
572 return drv
->API
.WaitGL(drv
, disp
);
576 EGLBoolean EGLAPIENTRY
577 eglWaitNative(EGLint engine
)
579 _EGLDisplay
*disp
= _eglGetCurrentDisplay();
585 /* a current display is always initialized */
588 return drv
->API
.WaitNative(drv
, disp
, engine
);
592 EGLDisplay EGLAPIENTRY
593 eglGetCurrentDisplay(void)
595 _EGLDisplay
*dpy
= _eglGetCurrentDisplay();
596 return _eglGetDisplayHandle(dpy
);
600 EGLContext EGLAPIENTRY
601 eglGetCurrentContext(void)
603 _EGLContext
*ctx
= _eglGetCurrentContext();
604 return _eglGetContextHandle(ctx
);
608 EGLSurface EGLAPIENTRY
609 eglGetCurrentSurface(EGLint readdraw
)
611 _EGLContext
*ctx
= _eglGetCurrentContext();
615 return EGL_NO_SURFACE
;
619 surf
= ctx
->DrawSurface
;
622 surf
= ctx
->ReadSurface
;
625 _eglError(EGL_BAD_PARAMETER
, __FUNCTION__
);
630 return _eglGetSurfaceHandle(surf
);
637 _EGLThreadInfo
*t
= _eglGetCurrentThread();
638 EGLint e
= t
->LastError
;
639 if (!_eglIsCurrentThreadDummy())
640 t
->LastError
= EGL_SUCCESS
;
645 void (* EGLAPIENTRY
eglGetProcAddress(const char *procname
))()
647 static const struct {
650 } egl_functions
[] = {
651 /* extensions only */
652 #ifdef EGL_MESA_screen_surface
653 { "eglChooseModeMESA", (_EGLProc
) eglChooseModeMESA
},
654 { "eglGetModesMESA", (_EGLProc
) eglGetModesMESA
},
655 { "eglGetModeAttribMESA", (_EGLProc
) eglGetModeAttribMESA
},
656 { "eglCopyContextMESA", (_EGLProc
) eglCopyContextMESA
},
657 { "eglGetScreensMESA", (_EGLProc
) eglGetScreensMESA
},
658 { "eglCreateScreenSurfaceMESA", (_EGLProc
) eglCreateScreenSurfaceMESA
},
659 { "eglShowScreenSurfaceMESA", (_EGLProc
) eglShowScreenSurfaceMESA
},
660 { "eglScreenPositionMESA", (_EGLProc
) eglScreenPositionMESA
},
661 { "eglQueryScreenMESA", (_EGLProc
) eglQueryScreenMESA
},
662 { "eglQueryScreenSurfaceMESA", (_EGLProc
) eglQueryScreenSurfaceMESA
},
663 { "eglQueryScreenModeMESA", (_EGLProc
) eglQueryScreenModeMESA
},
664 { "eglQueryModeStringMESA", (_EGLProc
) eglQueryModeStringMESA
},
665 #endif /* EGL_MESA_screen_surface */
672 if (strncmp(procname
, "egl", 3) == 0) {
673 for (i
= 0; egl_functions
[i
].name
; i
++) {
674 if (strcmp(egl_functions
[i
].name
, procname
) == 0)
675 return egl_functions
[i
].function
;
679 /* preload a driver if there isn't one */
680 if (!_eglGlobal
.NumDrivers
)
681 _eglPreloadDriver(NULL
);
683 /* now loop over drivers to query their procs */
684 for (i
= 0; i
< _eglGlobal
.NumDrivers
; i
++) {
685 _EGLProc p
= _eglGlobal
.Drivers
[i
]->API
.GetProcAddress(procname
);
694 #ifdef EGL_MESA_screen_surface
698 * EGL_MESA_screen extension
701 EGLBoolean EGLAPIENTRY
702 eglChooseModeMESA(EGLDisplay dpy
, EGLScreenMESA screen
,
703 const EGLint
*attrib_list
, EGLModeMESA
*modes
,
704 EGLint modes_size
, EGLint
*num_modes
)
706 _EGL_DECLARE_DD_AND_SCREEN(dpy
, screen
);
707 return drv
->API
.ChooseModeMESA(drv
, disp
, scrn
, attrib_list
,
708 modes
, modes_size
, num_modes
);
712 EGLBoolean EGLAPIENTRY
713 eglGetModesMESA(EGLDisplay dpy
, EGLScreenMESA screen
, EGLModeMESA
*modes
,
714 EGLint mode_size
, EGLint
*num_mode
)
716 _EGL_DECLARE_DD_AND_SCREEN(dpy
, screen
);
717 return drv
->API
.GetModesMESA(drv
, disp
, scrn
, modes
, mode_size
, num_mode
);
721 EGLBoolean EGLAPIENTRY
722 eglGetModeAttribMESA(EGLDisplay dpy
, EGLModeMESA mode
,
723 EGLint attribute
, EGLint
*value
)
725 _EGL_DECLARE_DD_AND_MODE(dpy
, mode
);
726 return drv
->API
.GetModeAttribMESA(drv
, disp
, m
, attribute
, value
);
730 EGLBoolean EGLAPIENTRY
731 eglCopyContextMESA(EGLDisplay dpy
, EGLContext source
, EGLContext dest
,
734 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
735 _EGLContext
*source_context
= _eglLookupContext(source
, disp
);
736 _EGLContext
*dest_context
= _eglLookupContext(dest
, disp
);
739 drv
= _eglCheckContext(disp
, source_context
, __FUNCTION__
);
740 if (!drv
|| !dest_context
) {
742 _eglError(EGL_BAD_CONTEXT
, __FUNCTION__
);
746 return drv
->API
.CopyContextMESA(drv
, disp
, source_context
, dest_context
,
752 eglGetScreensMESA(EGLDisplay dpy
, EGLScreenMESA
*screens
,
753 EGLint max_screens
, EGLint
*num_screens
)
755 _EGL_DECLARE_DD(dpy
);
756 return drv
->API
.GetScreensMESA(drv
, disp
, screens
,
757 max_screens
, num_screens
);
762 eglCreateScreenSurfaceMESA(EGLDisplay dpy
, EGLConfig config
,
763 const EGLint
*attrib_list
)
765 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
766 _EGLConfig
*conf
= _eglLookupConfig(config
, disp
);
770 drv
= _eglCheckConfig(disp
, conf
, __FUNCTION__
);
772 return EGL_NO_SURFACE
;
774 surf
= drv
->API
.CreateScreenSurfaceMESA(drv
, disp
, conf
, attrib_list
);
776 return _eglLinkSurface(surf
, disp
);
778 return EGL_NO_SURFACE
;
783 eglShowScreenSurfaceMESA(EGLDisplay dpy
, EGLint screen
,
784 EGLSurface surface
, EGLModeMESA mode
)
786 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
787 _EGLScreen
*scrn
= _eglLookupScreen((EGLScreenMESA
) screen
, disp
);
788 _EGLSurface
*surf
= _eglLookupSurface(surface
, disp
);
789 _EGLMode
*m
= _eglLookupMode(mode
, disp
);
792 drv
= _eglCheckScreen(disp
, scrn
, __FUNCTION__
);
795 if (!surf
&& surface
!= EGL_NO_SURFACE
)
796 return _eglError(EGL_BAD_SURFACE
, __FUNCTION__
);
797 if (!m
&& mode
!= EGL_NO_MODE_MESA
)
798 return _eglError(EGL_BAD_MODE_MESA
, __FUNCTION__
);
800 return drv
->API
.ShowScreenSurfaceMESA(drv
, disp
, scrn
, surf
, m
);
805 eglScreenPositionMESA(EGLDisplay dpy
, EGLScreenMESA screen
, EGLint x
, EGLint y
)
807 _EGL_DECLARE_DD_AND_SCREEN(dpy
, screen
);
808 return drv
->API
.ScreenPositionMESA(drv
, disp
, scrn
, x
, y
);
813 eglQueryScreenMESA(EGLDisplay dpy
, EGLScreenMESA screen
,
814 EGLint attribute
, EGLint
*value
)
816 _EGL_DECLARE_DD_AND_SCREEN(dpy
, screen
);
817 return drv
->API
.QueryScreenMESA(drv
, disp
, scrn
, attribute
, value
);
822 eglQueryScreenSurfaceMESA(EGLDisplay dpy
, EGLScreenMESA screen
,
825 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
826 _EGLScreen
*scrn
= _eglLookupScreen((EGLScreenMESA
) screen
, disp
);
830 drv
= _eglCheckScreen(disp
, scrn
, __FUNCTION__
);
834 if (drv
->API
.QueryScreenSurfaceMESA(drv
, disp
, scrn
, &surf
) != EGL_TRUE
)
837 *surface
= _eglGetSurfaceHandle(surf
);
838 return (surf
!= NULL
);
843 eglQueryScreenModeMESA(EGLDisplay dpy
, EGLScreenMESA screen
, EGLModeMESA
*mode
)
845 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
846 _EGLScreen
*scrn
= _eglLookupScreen((EGLScreenMESA
) screen
, disp
);
850 drv
= _eglCheckScreen(disp
, scrn
, __FUNCTION__
);
854 if (drv
->API
.QueryScreenModeMESA(drv
, disp
, scrn
, &m
) != EGL_TRUE
)
864 eglQueryModeStringMESA(EGLDisplay dpy
, EGLModeMESA mode
)
866 _EGL_DECLARE_DD_AND_MODE(dpy
, mode
);
867 return drv
->API
.QueryModeStringMESA(drv
, disp
, m
);
871 #endif /* EGL_MESA_screen_surface */
878 #ifdef EGL_VERSION_1_2
882 * Specify the client API to use for subsequent calls including:
884 * eglGetCurrentContext()
885 * eglGetCurrentDisplay()
886 * eglGetCurrentSurface()
887 * eglMakeCurrent(when the ctx parameter is EGL NO CONTEXT)
890 * See section 3.7 "Rendering Context" in the EGL specification for details.
893 eglBindAPI(EGLenum api
)
895 _EGLThreadInfo
*t
= _eglGetCurrentThread();
897 if (_eglIsCurrentThreadDummy())
898 return _eglError(EGL_BAD_ALLOC
, "eglBindAPI");
900 if (!_eglIsApiValid(api
))
901 return _eglError(EGL_BAD_PARAMETER
, "eglBindAPI");
903 t
->CurrentAPIIndex
= _eglConvertApiToIndex(api
);
909 * Return the last value set with eglBindAPI().
914 /* returns one of EGL_OPENGL_API, EGL_OPENGL_ES_API or EGL_OPENVG_API */
915 _EGLThreadInfo
*t
= _eglGetCurrentThread();
916 return _eglConvertApiFromIndex(t
->CurrentAPIIndex
);
921 eglCreatePbufferFromClientBuffer(EGLDisplay dpy
, EGLenum buftype
,
922 EGLClientBuffer buffer
, EGLConfig config
,
923 const EGLint
*attrib_list
)
925 _EGLDisplay
*disp
= _eglLookupDisplay(dpy
);
926 _EGLConfig
*conf
= _eglLookupConfig(config
, disp
);
930 drv
= _eglCheckConfig(disp
, conf
, __FUNCTION__
);
932 return EGL_NO_SURFACE
;
934 surf
= drv
->API
.CreatePbufferFromClientBuffer(drv
, disp
, buftype
, buffer
,
937 return _eglLinkSurface(surf
, disp
);
939 return EGL_NO_SURFACE
;
944 eglReleaseThread(void)
946 /* unbind current context */
947 if (!_eglIsCurrentThreadDummy()) {
948 _EGLDisplay
*disp
= _eglGetCurrentDisplay();
952 (void) drv
->API
.MakeCurrent(drv
, disp
, NULL
, NULL
, NULL
);
956 _eglDestroyCurrentThread();
964 _EGLDisplay
*disp
= _eglGetCurrentDisplay();
970 /* a current display is always initialized */
973 return drv
->API
.WaitClient(drv
, disp
);
977 #endif /* EGL_VERSION_1_2 */