diff options
| author | Chia-I Wu <olvaffe@gmail.com> | 2010-10-01 15:27:42 -0400 | 
|---|---|---|
| committer | Chia-I Wu <olvaffe@gmail.com> | 2010-12-09 20:01:35 -0500 | 
| commit | 0d4dcb25842739d586debb3472ceb90589fe741b (patch) | |
| tree | 1e53a8cc5c44a2d0e92d7162ec24e2b5accc3976 /src | |
| parent | 13375514519e00fc6598b30055d7320553f8b676 (diff) | |
android: Add Android EGL extensions.
Diffstat (limited to 'src')
| -rw-r--r-- | src/egl/main/eglapi.c | 52 | ||||
| -rw-r--r-- | src/egl/main/eglapi.h | 15 | ||||
| -rw-r--r-- | src/egl/main/egldisplay.h | 4 | ||||
| -rw-r--r-- | src/egl/main/eglmisc.c | 4 | 
4 files changed, 75 insertions, 0 deletions
| diff --git a/src/egl/main/eglapi.c b/src/egl/main/eglapi.c index efa9e97346..c339e6ebeb 100644 --- a/src/egl/main/eglapi.c +++ b/src/egl/main/eglapi.c @@ -917,6 +917,12 @@ eglGetProcAddress(const char *procname)        { "eglCreateDRMImageMESA", (_EGLProc) eglCreateDRMImageMESA },        { "eglExportDRMImageMESA", (_EGLProc) eglExportDRMImageMESA },  #endif +#ifdef EGL_ANDROID_swap_rectangle +      { "eglSetSwapRectangleANDROID", (_EGLProc) eglSetSwapRectangleANDROID }, +#endif +#ifdef EGL_ANDROID_get_render_buffer +      { "eglGetRenderBufferANDROID", (_EGLProc) eglGetRenderBufferANDROID }, +#endif        { NULL, NULL }     };     EGLint i; @@ -1494,3 +1500,49 @@ eglExportDRMImageMESA(EGLDisplay dpy, EGLImageKHR image,  }  #endif + +#ifdef EGL_ANDROID_swap_rectangle + +EGLBoolean EGLAPIENTRY +eglSetSwapRectangleANDROID(EGLDisplay dpy, EGLSurface draw, +                           EGLint left, EGLint top, +                           EGLint width, EGLint height) +{ +   _EGLDisplay *disp = _eglLockDisplay(dpy); +   _EGLSurface *surf = _eglLookupSurface(draw, disp); +   _EGLDriver *drv; +   EGLBoolean ret; + +   _EGL_CHECK_SURFACE(disp, surf, EGL_FALSE, drv); + +   if (!disp->Extensions.ANDROID_swap_rectangle) +      RETURN_EGL_EVAL(disp, EGL_FALSE); + +   ret = drv->API.SetSwapRectangleANDROID(drv, disp, surf, left, top, width, height); + +   RETURN_EGL_EVAL(disp, ret); +} + +#endif + +#ifdef EGL_ANDROID_get_render_buffer + +EGLClientBuffer EGLAPIENTRY +eglGetRenderBufferANDROID(EGLDisplay dpy, EGLSurface draw) +{ +   _EGLDisplay *disp = _eglLockDisplay(dpy); +   _EGLSurface *surf = _eglLookupSurface(draw, disp); +   _EGLDriver *drv; +   EGLClientBuffer ret; + +   _EGL_CHECK_SURFACE(disp, surf, NULL, drv); + +   if (!disp->Extensions.ANDROID_get_render_buffer) +      RETURN_EGL_EVAL(disp, NULL); + +   ret = drv->API.GetRenderBufferANDROID(drv, disp, surf); + +   RETURN_EGL_EVAL(disp, ret); +} + +#endif diff --git a/src/egl/main/eglapi.h b/src/egl/main/eglapi.h index 127becc9ac..96db72c70f 100644 --- a/src/egl/main/eglapi.h +++ b/src/egl/main/eglapi.h @@ -95,6 +95,14 @@ typedef _EGLImage *(*CreateDRMImageMESA_t)(_EGLDriver *drv, _EGLDisplay *disp, c  typedef EGLBoolean (*ExportDRMImageMESA_t)(_EGLDriver *drv, _EGLDisplay *disp, _EGLImage *img, EGLint *name, EGLint *handle, EGLint *stride);  #endif +#ifdef EGL_ANDROID_swap_rectangle +typedef EGLBoolean (*SetSwapRectangleANDROID_t)(_EGLDriver *drv, _EGLDisplay *disp, _EGLSurface *draw, EGLint left, EGLint top, EGLint width, EGLint height); +#endif + +#ifdef EGL_ANDROID_get_render_buffer +typedef EGLClientBuffer (*GetRenderBufferANDROID_t)(_EGLDriver *drv, _EGLDisplay *disp, _EGLSurface *draw); +#endif +  /**   * The API dispatcher jumps through these functions   */ @@ -169,6 +177,13 @@ struct _egl_api     CreateDRMImageMESA_t CreateDRMImageMESA;     ExportDRMImageMESA_t ExportDRMImageMESA;  #endif + +#ifdef EGL_ANDROID_swap_rectangle +   SetSwapRectangleANDROID_t SetSwapRectangleANDROID; +#endif +#ifdef EGL_ANDROID_get_render_buffer +   GetRenderBufferANDROID_t GetRenderBufferANDROID; +#endif  };  #endif /* EGLAPI_INCLUDED */ diff --git a/src/egl/main/egldisplay.h b/src/egl/main/egldisplay.h index 054c138c9e..b409ade827 100644 --- a/src/egl/main/egldisplay.h +++ b/src/egl/main/egldisplay.h @@ -76,6 +76,10 @@ struct _egl_extensions     EGLBoolean NOK_swap_region;     EGLBoolean NOK_texture_from_pixmap; +   EGLBoolean ANDROID_image_native_buffer; +   EGLBoolean ANDROID_swap_rectangle; +   EGLBoolean ANDROID_get_render_buffer; +     char String[_EGL_MAX_EXTENSIONS_LEN];  }; diff --git a/src/egl/main/eglmisc.c b/src/egl/main/eglmisc.c index bbb96a908e..de20d249c3 100644 --- a/src/egl/main/eglmisc.c +++ b/src/egl/main/eglmisc.c @@ -107,6 +107,10 @@ _eglUpdateExtensionsString(_EGLDisplay *dpy)     _EGL_CHECK_EXTENSION(NOK_swap_region);     _EGL_CHECK_EXTENSION(NOK_texture_from_pixmap); + +   _EGL_CHECK_EXTENSION(ANDROID_image_native_buffer); +   _EGL_CHECK_EXTENSION(ANDROID_swap_rectangle); +   _EGL_CHECK_EXTENSION(ANDROID_get_render_buffer);  #undef _EGL_CHECK_EXTENSION  } | 
