summaryrefslogtreecommitdiffstats
path: root/opengl
diff options
context:
space:
mode:
authorMathias Agopian <mathias@google.com>2010-09-23 13:24:11 -0700
committerAndroid Git Automerger <android-git-automerger@android.com>2010-09-23 13:24:11 -0700
commit6ee79cfa2f2885967910ffd27f6f81e1928b3d8d (patch)
treed8edf6124d84ea83998f22a8e766e58fdfde6af4 /opengl
parent4cf6be52035667f28f8164bc46d6fbc95b712d84 (diff)
parent05c53113e0c73c7cab61edf53524c61c20a547c2 (diff)
downloadframeworks_native-6ee79cfa2f2885967910ffd27f6f81e1928b3d8d.zip
frameworks_native-6ee79cfa2f2885967910ffd27f6f81e1928b3d8d.tar.gz
frameworks_native-6ee79cfa2f2885967910ffd27f6f81e1928b3d8d.tar.bz2
am 5c6c5c7a: fix [3028370] GL get error should return a valid error if no context is bound.
Merge commit '5c6c5c7a43d44316395f5c35ab713372124b8b4c' into gingerbread-plus-aosp * commit '5c6c5c7a43d44316395f5c35ab713372124b8b4c': fix [3028370] GL get error should return a valid error if no context is bound.
Diffstat (limited to 'opengl')
-rw-r--r--opengl/libs/EGL/egl.cpp9
1 files changed, 9 insertions, 0 deletions
diff --git a/opengl/libs/EGL/egl.cpp b/opengl/libs/EGL/egl.cpp
index 105ebb4..0437263 100644
--- a/opengl/libs/EGL/egl.cpp
+++ b/opengl/libs/EGL/egl.cpp
@@ -437,6 +437,12 @@ static void gl_no_context() {
}
}
+// Always return GL_INVALID_OPERATION from glGetError() when called from
+// a thread without a bound context.
+static GLenum gl_no_context_glGetError() {
+ return GL_INVALID_OPERATION;
+}
+
static void early_egl_init(void)
{
#if !USE_FAST_TLS_KEY
@@ -447,6 +453,9 @@ static void early_egl_init(void)
(uint32_t*)(void*)&gHooksNoContext,
addr,
sizeof(gHooksNoContext));
+
+ gHooksNoContext.gl.glGetError = gl_no_context_glGetError;
+
setGlThreadSpecific(&gHooksNoContext);
}