summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndroid (Google) Code Review <android-gerrit@google.com>2009-10-06 20:18:40 -0400
committerAndroid (Google) Code Review <android-gerrit@google.com>2009-10-06 20:18:40 -0400
commitfe7c2a50148ac9f0d6fbe0030fc53f457c10870a (patch)
tree8ea52285d16acb944b13334937614009a1cfdf1b
parent521f4f3af94e3a093a37af887d3e317a526b61a1 (diff)
parent996db8dace63c452e5828586415b0dc57cccb3db (diff)
downloadframeworks_base-fe7c2a50148ac9f0d6fbe0030fc53f457c10870a.zip
frameworks_base-fe7c2a50148ac9f0d6fbe0030fc53f457c10870a.tar.gz
frameworks_base-fe7c2a50148ac9f0d6fbe0030fc53f457c10870a.tar.bz2
Merge change I996db8da into eclair
* changes: Fix tls crash on startup if more than one RS contexts are created in one process.
-rw-r--r--libs/rs/rsContext.cpp13
-rw-r--r--libs/rs/rsScriptC.cpp1
2 files changed, 10 insertions, 4 deletions
diff --git a/libs/rs/rsContext.cpp b/libs/rs/rsContext.cpp
index a1e9e45..195ea6f 100644
--- a/libs/rs/rsContext.cpp
+++ b/libs/rs/rsContext.cpp
@@ -304,10 +304,15 @@ Context::Context(Device *dev, Surface *sur, bool useDepth)
int status;
pthread_attr_t threadAttr;
- status = pthread_key_create(&gThreadTLSKey, NULL);
- if (status) {
- LOGE("Failed to init thread tls key.");
- return;
+ if (!gThreadTLSKey) {
+ status = pthread_key_create(&gThreadTLSKey, NULL);
+ if (status) {
+ LOGE("Failed to init thread tls key.");
+ return;
+ }
+ } else {
+ // HACK: workaround gl hang on start
+ exit(-1);
}
status = pthread_attr_init(&threadAttr);
diff --git a/libs/rs/rsScriptC.cpp b/libs/rs/rsScriptC.cpp
index 20088da..9da7766 100644
--- a/libs/rs/rsScriptC.cpp
+++ b/libs/rs/rsScriptC.cpp
@@ -62,6 +62,7 @@ bool ScriptC::run(Context *rsc, uint32_t launchIndex)
{
Context::ScriptTLSStruct * tls =
(Context::ScriptTLSStruct *)pthread_getspecific(Context::gThreadTLSKey);
+ rsAssert(tls);
if (mEnviroment.mFragmentStore.get()) {
rsc->setFragmentStore(mEnviroment.mFragmentStore.get());