Loading opengl/libagl/egl.cpp +46 −12 Original line number Original line Diff line number Diff line Loading @@ -141,7 +141,8 @@ struct egl_surface_t egl_surface_t(EGLDisplay dpy, EGLConfig config, int32_t depthFormat); egl_surface_t(EGLDisplay dpy, EGLConfig config, int32_t depthFormat); virtual ~egl_surface_t(); virtual ~egl_surface_t(); virtual bool isValid() const = 0; bool isValid() const; virtual bool initCheck() const = 0; virtual EGLBoolean bindDrawSurface(ogles_context_t* gl) = 0; virtual EGLBoolean bindDrawSurface(ogles_context_t* gl) = 0; virtual EGLBoolean bindReadSurface(ogles_context_t* gl) = 0; virtual EGLBoolean bindReadSurface(ogles_context_t* gl) = 0; Loading Loading @@ -175,6 +176,11 @@ egl_surface_t::~egl_surface_t() magic = 0; magic = 0; free(depth.data); free(depth.data); } } bool egl_surface_t::isValid() const { LOGE_IF(magic != MAGIC, "invalid EGLSurface (%p)", this); return magic == MAGIC; } EGLBoolean egl_surface_t::swapBuffers() { EGLBoolean egl_surface_t::swapBuffers() { return EGL_FALSE; return EGL_FALSE; } } Loading Loading @@ -210,7 +216,7 @@ struct egl_window_surface_v2_t : public egl_surface_t ~egl_window_surface_v2_t(); ~egl_window_surface_v2_t(); virtual bool isValid() const { return nativeWindow->common.magic == ANDROID_NATIVE_WINDOW_MAGIC; } virtual bool initCheck() const { return true; } // TODO: report failure if ctor fails virtual EGLBoolean swapBuffers(); virtual EGLBoolean swapBuffers(); virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); Loading Loading @@ -704,7 +710,7 @@ struct egl_pixmap_surface_t : public egl_surface_t virtual ~egl_pixmap_surface_t() { } virtual ~egl_pixmap_surface_t() { } virtual bool isValid() const { return nativePixmap.version == sizeof(egl_native_pixmap_t); } virtual bool initCheck() const { return !depth.format || depth.data!=0; } virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLint getWidth() const { return nativePixmap.width; } virtual EGLint getWidth() const { return nativePixmap.width; } Loading @@ -726,7 +732,6 @@ egl_pixmap_surface_t::egl_pixmap_surface_t(EGLDisplay dpy, depth.data = (GGLubyte*)malloc(depth.stride*depth.height*2); depth.data = (GGLubyte*)malloc(depth.stride*depth.height*2); if (depth.data == 0) { if (depth.data == 0) { setError(EGL_BAD_ALLOC, EGL_NO_SURFACE); setError(EGL_BAD_ALLOC, EGL_NO_SURFACE); return; } } } } } } Loading Loading @@ -768,7 +773,7 @@ struct egl_pbuffer_surface_t : public egl_surface_t virtual ~egl_pbuffer_surface_t(); virtual ~egl_pbuffer_surface_t(); virtual bool isValid() const { return pbuffer.data != 0; } virtual bool initCheck() const { return pbuffer.data != 0; } virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLint getWidth() const { return pbuffer.width; } virtual EGLint getWidth() const { return pbuffer.width; } Loading Loading @@ -1196,6 +1201,11 @@ static EGLSurface createWindowSurface(EGLDisplay dpy, EGLConfig config, if (!(surfaceType & EGL_WINDOW_BIT)) if (!(surfaceType & EGL_WINDOW_BIT)) return setError(EGL_BAD_MATCH, EGL_NO_SURFACE); return setError(EGL_BAD_MATCH, EGL_NO_SURFACE); if (static_cast<android_native_window_t*>(window)->common.magic != ANDROID_NATIVE_WINDOW_MAGIC) { return setError(EGL_BAD_NATIVE_WINDOW, EGL_NO_SURFACE); } EGLint configID; EGLint configID; if (getConfigAttrib(dpy, config, EGL_CONFIG_ID, &configID) == EGL_FALSE) if (getConfigAttrib(dpy, config, EGL_CONFIG_ID, &configID) == EGL_FALSE) return EGL_FALSE; return EGL_FALSE; Loading Loading @@ -1241,7 +1251,7 @@ static EGLSurface createWindowSurface(EGLDisplay dpy, EGLConfig config, surface = new egl_window_surface_v2_t(dpy, config, depthFormat, surface = new egl_window_surface_v2_t(dpy, config, depthFormat, static_cast<android_native_window_t*>(window)); static_cast<android_native_window_t*>(window)); if (!surface->isValid()) { if (!surface->initCheck()) { // there was a problem in the ctor, the error // there was a problem in the ctor, the error // flag has been set. // flag has been set. delete surface; delete surface; Loading @@ -1265,6 +1275,11 @@ static EGLSurface createPixmapSurface(EGLDisplay dpy, EGLConfig config, if (!(surfaceType & EGL_PIXMAP_BIT)) if (!(surfaceType & EGL_PIXMAP_BIT)) return setError(EGL_BAD_MATCH, EGL_NO_SURFACE); return setError(EGL_BAD_MATCH, EGL_NO_SURFACE); if (static_cast<egl_native_pixmap_t*>(pixmap)->version != sizeof(egl_native_pixmap_t)) { return setError(EGL_BAD_NATIVE_PIXMAP, EGL_NO_SURFACE); } EGLint configID; EGLint configID; if (getConfigAttrib(dpy, config, EGL_CONFIG_ID, &configID) == EGL_FALSE) if (getConfigAttrib(dpy, config, EGL_CONFIG_ID, &configID) == EGL_FALSE) return EGL_FALSE; return EGL_FALSE; Loading Loading @@ -1307,7 +1322,7 @@ static EGLSurface createPixmapSurface(EGLDisplay dpy, EGLConfig config, new egl_pixmap_surface_t(dpy, config, depthFormat, new egl_pixmap_surface_t(dpy, config, depthFormat, static_cast<egl_native_pixmap_t*>(pixmap)); static_cast<egl_native_pixmap_t*>(pixmap)); if (!surface->isValid()) { if (!surface->initCheck()) { // there was a problem in the ctor, the error // there was a problem in the ctor, the error // flag has been set. // flag has been set. delete surface; delete surface; Loading Loading @@ -1375,7 +1390,7 @@ static EGLSurface createPbufferSurface(EGLDisplay dpy, EGLConfig config, egl_surface_t* surface = egl_surface_t* surface = new egl_pbuffer_surface_t(dpy, config, depthFormat, w, h, pixelFormat); new egl_pbuffer_surface_t(dpy, config, depthFormat, w, h, pixelFormat); if (!surface->isValid()) { if (!surface->initCheck()) { // there was a problem in the ctor, the error // there was a problem in the ctor, the error // flag has been set. // flag has been set. delete surface; delete surface; Loading Loading @@ -1590,7 +1605,7 @@ EGLBoolean eglDestroySurface(EGLDisplay dpy, EGLSurface eglSurface) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); if (eglSurface != EGL_NO_SURFACE) { if (eglSurface != EGL_NO_SURFACE) { egl_surface_t* surface( static_cast<egl_surface_t*>(eglSurface) ); egl_surface_t* surface( static_cast<egl_surface_t*>(eglSurface) ); if (surface->magic != egl_surface_t::MAGIC) if (!surface->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); return setError(EGL_BAD_SURFACE, EGL_FALSE); if (surface->dpy != dpy) if (surface->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); Loading @@ -1610,6 +1625,8 @@ EGLBoolean eglQuerySurface( EGLDisplay dpy, EGLSurface eglSurface, if (egl_display_t::is_valid(dpy) == EGL_FALSE) if (egl_display_t::is_valid(dpy) == EGL_FALSE) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); egl_surface_t* surface = static_cast<egl_surface_t*>(eglSurface); egl_surface_t* surface = static_cast<egl_surface_t*>(eglSurface); if (!surface->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (surface->dpy != dpy) if (surface->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); Loading Loading @@ -1702,9 +1719,19 @@ EGLBoolean eglMakeCurrent( EGLDisplay dpy, EGLSurface draw, return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); if (draw) { if (draw) { egl_surface_t* s = (egl_surface_t*)draw; egl_surface_t* s = (egl_surface_t*)draw; if (!s->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (s->dpy != dpy) if (s->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); // TODO: check that draw and read are compatible with the context // TODO: check that draw is compatible with the context } if (read && read!=draw) { egl_surface_t* s = (egl_surface_t*)read; if (!s->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (s->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); // TODO: check that read is compatible with the context } } EGLContext current_ctx = EGL_NO_CONTEXT; EGLContext current_ctx = EGL_NO_CONTEXT; Loading Loading @@ -1737,7 +1764,8 @@ EGLBoolean eglMakeCurrent( EGLDisplay dpy, EGLSurface draw, egl_surface_t* r = (egl_surface_t*)read; egl_surface_t* r = (egl_surface_t*)read; if (c->draw) { if (c->draw) { reinterpret_cast<egl_surface_t*>(c->draw)->disconnect(); egl_surface_t* s = reinterpret_cast<egl_surface_t*>(c->draw); s->disconnect(); } } if (c->read) { if (c->read) { // FIXME: unlock/disconnect the read surface too // FIXME: unlock/disconnect the read surface too Loading Loading @@ -1860,6 +1888,8 @@ EGLBoolean eglSwapBuffers(EGLDisplay dpy, EGLSurface draw) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); egl_surface_t* d = static_cast<egl_surface_t*>(draw); egl_surface_t* d = static_cast<egl_surface_t*>(draw); if (!d->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (d->dpy != dpy) if (d->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); Loading Loading @@ -2073,6 +2103,8 @@ EGLBoolean eglSetSwapRectangleANDROID(EGLDisplay dpy, EGLSurface draw, return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); egl_surface_t* d = static_cast<egl_surface_t*>(draw); egl_surface_t* d = static_cast<egl_surface_t*>(draw); if (!d->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (d->dpy != dpy) if (d->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); Loading @@ -2088,6 +2120,8 @@ EGLClientBuffer eglGetRenderBufferANDROID(EGLDisplay dpy, EGLSurface draw) return setError(EGL_BAD_DISPLAY, (EGLClientBuffer)0); return setError(EGL_BAD_DISPLAY, (EGLClientBuffer)0); egl_surface_t* d = static_cast<egl_surface_t*>(draw); egl_surface_t* d = static_cast<egl_surface_t*>(draw); if (!d->isValid()) return setError(EGL_BAD_SURFACE, (EGLClientBuffer)0); if (d->dpy != dpy) if (d->dpy != dpy) return setError(EGL_BAD_DISPLAY, (EGLClientBuffer)0); return setError(EGL_BAD_DISPLAY, (EGLClientBuffer)0); Loading Loading
opengl/libagl/egl.cpp +46 −12 Original line number Original line Diff line number Diff line Loading @@ -141,7 +141,8 @@ struct egl_surface_t egl_surface_t(EGLDisplay dpy, EGLConfig config, int32_t depthFormat); egl_surface_t(EGLDisplay dpy, EGLConfig config, int32_t depthFormat); virtual ~egl_surface_t(); virtual ~egl_surface_t(); virtual bool isValid() const = 0; bool isValid() const; virtual bool initCheck() const = 0; virtual EGLBoolean bindDrawSurface(ogles_context_t* gl) = 0; virtual EGLBoolean bindDrawSurface(ogles_context_t* gl) = 0; virtual EGLBoolean bindReadSurface(ogles_context_t* gl) = 0; virtual EGLBoolean bindReadSurface(ogles_context_t* gl) = 0; Loading Loading @@ -175,6 +176,11 @@ egl_surface_t::~egl_surface_t() magic = 0; magic = 0; free(depth.data); free(depth.data); } } bool egl_surface_t::isValid() const { LOGE_IF(magic != MAGIC, "invalid EGLSurface (%p)", this); return magic == MAGIC; } EGLBoolean egl_surface_t::swapBuffers() { EGLBoolean egl_surface_t::swapBuffers() { return EGL_FALSE; return EGL_FALSE; } } Loading Loading @@ -210,7 +216,7 @@ struct egl_window_surface_v2_t : public egl_surface_t ~egl_window_surface_v2_t(); ~egl_window_surface_v2_t(); virtual bool isValid() const { return nativeWindow->common.magic == ANDROID_NATIVE_WINDOW_MAGIC; } virtual bool initCheck() const { return true; } // TODO: report failure if ctor fails virtual EGLBoolean swapBuffers(); virtual EGLBoolean swapBuffers(); virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); Loading Loading @@ -704,7 +710,7 @@ struct egl_pixmap_surface_t : public egl_surface_t virtual ~egl_pixmap_surface_t() { } virtual ~egl_pixmap_surface_t() { } virtual bool isValid() const { return nativePixmap.version == sizeof(egl_native_pixmap_t); } virtual bool initCheck() const { return !depth.format || depth.data!=0; } virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLint getWidth() const { return nativePixmap.width; } virtual EGLint getWidth() const { return nativePixmap.width; } Loading @@ -726,7 +732,6 @@ egl_pixmap_surface_t::egl_pixmap_surface_t(EGLDisplay dpy, depth.data = (GGLubyte*)malloc(depth.stride*depth.height*2); depth.data = (GGLubyte*)malloc(depth.stride*depth.height*2); if (depth.data == 0) { if (depth.data == 0) { setError(EGL_BAD_ALLOC, EGL_NO_SURFACE); setError(EGL_BAD_ALLOC, EGL_NO_SURFACE); return; } } } } } } Loading Loading @@ -768,7 +773,7 @@ struct egl_pbuffer_surface_t : public egl_surface_t virtual ~egl_pbuffer_surface_t(); virtual ~egl_pbuffer_surface_t(); virtual bool isValid() const { return pbuffer.data != 0; } virtual bool initCheck() const { return pbuffer.data != 0; } virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindDrawSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLBoolean bindReadSurface(ogles_context_t* gl); virtual EGLint getWidth() const { return pbuffer.width; } virtual EGLint getWidth() const { return pbuffer.width; } Loading Loading @@ -1196,6 +1201,11 @@ static EGLSurface createWindowSurface(EGLDisplay dpy, EGLConfig config, if (!(surfaceType & EGL_WINDOW_BIT)) if (!(surfaceType & EGL_WINDOW_BIT)) return setError(EGL_BAD_MATCH, EGL_NO_SURFACE); return setError(EGL_BAD_MATCH, EGL_NO_SURFACE); if (static_cast<android_native_window_t*>(window)->common.magic != ANDROID_NATIVE_WINDOW_MAGIC) { return setError(EGL_BAD_NATIVE_WINDOW, EGL_NO_SURFACE); } EGLint configID; EGLint configID; if (getConfigAttrib(dpy, config, EGL_CONFIG_ID, &configID) == EGL_FALSE) if (getConfigAttrib(dpy, config, EGL_CONFIG_ID, &configID) == EGL_FALSE) return EGL_FALSE; return EGL_FALSE; Loading Loading @@ -1241,7 +1251,7 @@ static EGLSurface createWindowSurface(EGLDisplay dpy, EGLConfig config, surface = new egl_window_surface_v2_t(dpy, config, depthFormat, surface = new egl_window_surface_v2_t(dpy, config, depthFormat, static_cast<android_native_window_t*>(window)); static_cast<android_native_window_t*>(window)); if (!surface->isValid()) { if (!surface->initCheck()) { // there was a problem in the ctor, the error // there was a problem in the ctor, the error // flag has been set. // flag has been set. delete surface; delete surface; Loading @@ -1265,6 +1275,11 @@ static EGLSurface createPixmapSurface(EGLDisplay dpy, EGLConfig config, if (!(surfaceType & EGL_PIXMAP_BIT)) if (!(surfaceType & EGL_PIXMAP_BIT)) return setError(EGL_BAD_MATCH, EGL_NO_SURFACE); return setError(EGL_BAD_MATCH, EGL_NO_SURFACE); if (static_cast<egl_native_pixmap_t*>(pixmap)->version != sizeof(egl_native_pixmap_t)) { return setError(EGL_BAD_NATIVE_PIXMAP, EGL_NO_SURFACE); } EGLint configID; EGLint configID; if (getConfigAttrib(dpy, config, EGL_CONFIG_ID, &configID) == EGL_FALSE) if (getConfigAttrib(dpy, config, EGL_CONFIG_ID, &configID) == EGL_FALSE) return EGL_FALSE; return EGL_FALSE; Loading Loading @@ -1307,7 +1322,7 @@ static EGLSurface createPixmapSurface(EGLDisplay dpy, EGLConfig config, new egl_pixmap_surface_t(dpy, config, depthFormat, new egl_pixmap_surface_t(dpy, config, depthFormat, static_cast<egl_native_pixmap_t*>(pixmap)); static_cast<egl_native_pixmap_t*>(pixmap)); if (!surface->isValid()) { if (!surface->initCheck()) { // there was a problem in the ctor, the error // there was a problem in the ctor, the error // flag has been set. // flag has been set. delete surface; delete surface; Loading Loading @@ -1375,7 +1390,7 @@ static EGLSurface createPbufferSurface(EGLDisplay dpy, EGLConfig config, egl_surface_t* surface = egl_surface_t* surface = new egl_pbuffer_surface_t(dpy, config, depthFormat, w, h, pixelFormat); new egl_pbuffer_surface_t(dpy, config, depthFormat, w, h, pixelFormat); if (!surface->isValid()) { if (!surface->initCheck()) { // there was a problem in the ctor, the error // there was a problem in the ctor, the error // flag has been set. // flag has been set. delete surface; delete surface; Loading Loading @@ -1590,7 +1605,7 @@ EGLBoolean eglDestroySurface(EGLDisplay dpy, EGLSurface eglSurface) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); if (eglSurface != EGL_NO_SURFACE) { if (eglSurface != EGL_NO_SURFACE) { egl_surface_t* surface( static_cast<egl_surface_t*>(eglSurface) ); egl_surface_t* surface( static_cast<egl_surface_t*>(eglSurface) ); if (surface->magic != egl_surface_t::MAGIC) if (!surface->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); return setError(EGL_BAD_SURFACE, EGL_FALSE); if (surface->dpy != dpy) if (surface->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); Loading @@ -1610,6 +1625,8 @@ EGLBoolean eglQuerySurface( EGLDisplay dpy, EGLSurface eglSurface, if (egl_display_t::is_valid(dpy) == EGL_FALSE) if (egl_display_t::is_valid(dpy) == EGL_FALSE) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); egl_surface_t* surface = static_cast<egl_surface_t*>(eglSurface); egl_surface_t* surface = static_cast<egl_surface_t*>(eglSurface); if (!surface->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (surface->dpy != dpy) if (surface->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); Loading Loading @@ -1702,9 +1719,19 @@ EGLBoolean eglMakeCurrent( EGLDisplay dpy, EGLSurface draw, return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); if (draw) { if (draw) { egl_surface_t* s = (egl_surface_t*)draw; egl_surface_t* s = (egl_surface_t*)draw; if (!s->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (s->dpy != dpy) if (s->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); // TODO: check that draw and read are compatible with the context // TODO: check that draw is compatible with the context } if (read && read!=draw) { egl_surface_t* s = (egl_surface_t*)read; if (!s->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (s->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); // TODO: check that read is compatible with the context } } EGLContext current_ctx = EGL_NO_CONTEXT; EGLContext current_ctx = EGL_NO_CONTEXT; Loading Loading @@ -1737,7 +1764,8 @@ EGLBoolean eglMakeCurrent( EGLDisplay dpy, EGLSurface draw, egl_surface_t* r = (egl_surface_t*)read; egl_surface_t* r = (egl_surface_t*)read; if (c->draw) { if (c->draw) { reinterpret_cast<egl_surface_t*>(c->draw)->disconnect(); egl_surface_t* s = reinterpret_cast<egl_surface_t*>(c->draw); s->disconnect(); } } if (c->read) { if (c->read) { // FIXME: unlock/disconnect the read surface too // FIXME: unlock/disconnect the read surface too Loading Loading @@ -1860,6 +1888,8 @@ EGLBoolean eglSwapBuffers(EGLDisplay dpy, EGLSurface draw) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); egl_surface_t* d = static_cast<egl_surface_t*>(draw); egl_surface_t* d = static_cast<egl_surface_t*>(draw); if (!d->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (d->dpy != dpy) if (d->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); Loading Loading @@ -2073,6 +2103,8 @@ EGLBoolean eglSetSwapRectangleANDROID(EGLDisplay dpy, EGLSurface draw, return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); egl_surface_t* d = static_cast<egl_surface_t*>(draw); egl_surface_t* d = static_cast<egl_surface_t*>(draw); if (!d->isValid()) return setError(EGL_BAD_SURFACE, EGL_FALSE); if (d->dpy != dpy) if (d->dpy != dpy) return setError(EGL_BAD_DISPLAY, EGL_FALSE); return setError(EGL_BAD_DISPLAY, EGL_FALSE); Loading @@ -2088,6 +2120,8 @@ EGLClientBuffer eglGetRenderBufferANDROID(EGLDisplay dpy, EGLSurface draw) return setError(EGL_BAD_DISPLAY, (EGLClientBuffer)0); return setError(EGL_BAD_DISPLAY, (EGLClientBuffer)0); egl_surface_t* d = static_cast<egl_surface_t*>(draw); egl_surface_t* d = static_cast<egl_surface_t*>(draw); if (!d->isValid()) return setError(EGL_BAD_SURFACE, (EGLClientBuffer)0); if (d->dpy != dpy) if (d->dpy != dpy) return setError(EGL_BAD_DISPLAY, (EGLClientBuffer)0); return setError(EGL_BAD_DISPLAY, (EGLClientBuffer)0); Loading