summaryrefslogtreecommitdiffstats
path: root/gpu/pgl
diff options
context:
space:
mode:
authorsehr@google.com <sehr@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2010-02-05 04:51:26 +0000
committersehr@google.com <sehr@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2010-02-05 04:51:26 +0000
commit5ce3da1ef045e25ef4c34cfc925fb8a48ad2e87c (patch)
treeccb5236c081167929e57ad6f31c2c2b99ef18cff /gpu/pgl
parent28375ae7d27179af48386d37e78ca47a2563e0d0 (diff)
downloadchromium_src-5ce3da1ef045e25ef4c34cfc925fb8a48ad2e87c.zip
chromium_src-5ce3da1ef045e25ef4c34cfc925fb8a48ad2e87c.tar.gz
chromium_src-5ce3da1ef045e25ef4c34cfc925fb8a48ad2e87c.tar.bz2
PGL was relying on pthread_key_create not returning zero, which does not
seem to conform to the documented interface. I have added an allocated flag. This is needed to fix NaCl PGL. Review URL: http://codereview.chromium.org/576002 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@38186 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'gpu/pgl')
-rw-r--r--gpu/pgl/pgl.cc15
1 files changed, 9 insertions, 6 deletions
diff --git a/gpu/pgl/pgl.cc b/gpu/pgl/pgl.cc
index 68a074f..d357fe2 100644
--- a/gpu/pgl/pgl.cc
+++ b/gpu/pgl/pgl.cc
@@ -51,6 +51,7 @@ class PGLContextImpl {
};
gpu::ThreadLocalKey g_pgl_context_key;
+bool g_pgl_context_key_allocated = false;
PGLContextImpl::PGLContextImpl(NPP npp,
NPDevice* device,
@@ -110,7 +111,7 @@ void PGLContextImpl::Destroy() {
}
PGLBoolean PGLContextImpl::MakeCurrent(PGLContextImpl* pgl_context) {
- if (!g_pgl_context_key)
+ if (!g_pgl_context_key_allocated)
return PGL_FALSE;
gpu::ThreadLocalSetValue(g_pgl_context_key, pgl_context);
@@ -157,19 +158,21 @@ PGLInt PGLContextImpl::GetError() {
extern "C" {
PGLBoolean pglInitialize() {
- if (g_pgl_context_key)
+ if (g_pgl_context_key_allocated)
return PGL_TRUE;
gles2::Initialize();
g_pgl_context_key = gpu::ThreadLocalAlloc();
+ g_pgl_context_key_allocated = true;
return PGL_TRUE;
}
PGLBoolean pglTerminate() {
- if (!g_pgl_context_key)
+ if (!g_pgl_context_key_allocated)
return PGL_TRUE;
gpu::ThreadLocalFree(g_pgl_context_key);
+ g_pgl_context_key_allocated = false;
g_pgl_context_key = 0;
gles2::Terminate();
@@ -179,7 +182,7 @@ PGLBoolean pglTerminate() {
PGLContext pglCreateContext(NPP npp,
NPDevice* device,
NPDeviceContext3D* device_context) {
- if (!g_pgl_context_key)
+ if (!g_pgl_context_key_allocated)
return NULL;
PGLContextImpl* pgl_context = new PGLContextImpl(
@@ -197,7 +200,7 @@ PGLBoolean pglMakeCurrent(PGLContext pgl_context) {
}
PGLContext pglGetCurrentContext(void) {
- if (!g_pgl_context_key)
+ if (!g_pgl_context_key_allocated)
return NULL;
return static_cast<PGLContext>(gpu::ThreadLocalGetValue(g_pgl_context_key));
@@ -213,7 +216,7 @@ PGLBoolean pglSwapBuffers(void) {
}
PGLBoolean pglDestroyContext(PGLContext pgl_context) {
- if (!g_pgl_context_key)
+ if (!g_pgl_context_key_allocated)
return PGL_FALSE;
if (!pgl_context)