rsContext.cpp revision 707aaf341a4b068e6ccadf923af85acdd85fd775
1326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams/*
2326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * Copyright (C) 2009 The Android Open Source Project
3326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *
4326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * Licensed under the Apache License, Version 2.0 (the "License");
5326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * you may not use this file except in compliance with the License.
6326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * You may obtain a copy of the License at
7326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *
8326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *      http://www.apache.org/licenses/LICENSE-2.0
9326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *
10326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * Unless required by applicable law or agreed to in writing, software
11326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * distributed under the License is distributed on an "AS IS" BASIS,
12326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * See the License for the specific language governing permissions and
14326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * limitations under the License.
15326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams */
16326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
17326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include "rsDevice.h"
18326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include "rsContext.h"
19326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include "rsThreadIO.h"
205ae678f2e68e25bd74cdc408df354c3b6fe481bfMathias Agopian#include <ui/FramebufferNativeWindow.h>
21326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
221aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams#include <GLES/gl.h>
231aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams#include <GLES/glext.h>
241aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams
25326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android;
26326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android::renderscript;
27326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
28326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsContext * Context::gCon = NULL;
29e57691037aea219562ac686429b4b98202aab7bcJason Samspthread_key_t Context::gThreadTLSKey = 0;
30326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
31326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::initEGL()
32326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
33326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mNumConfigs = -1;
34326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
35326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    EGLint s_configAttribs[] = {
36326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams         EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
37b80dfa72dfdd146a9ddee948ad76635dbea3c0cdJason Sams#if 1
38b80dfa72dfdd146a9ddee948ad76635dbea3c0cdJason Sams         EGL_RED_SIZE,       8,
39b80dfa72dfdd146a9ddee948ad76635dbea3c0cdJason Sams         EGL_GREEN_SIZE,     8,
40b80dfa72dfdd146a9ddee948ad76635dbea3c0cdJason Sams         EGL_BLUE_SIZE,      8,
41b80dfa72dfdd146a9ddee948ad76635dbea3c0cdJason Sams         EGL_ALPHA_SIZE,     8,
42b80dfa72dfdd146a9ddee948ad76635dbea3c0cdJason Sams#else
43326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams         EGL_RED_SIZE,       5,
44326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams         EGL_GREEN_SIZE,     6,
45326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams         EGL_BLUE_SIZE,      5,
46b80dfa72dfdd146a9ddee948ad76635dbea3c0cdJason Sams#endif
47326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams         EGL_DEPTH_SIZE,     16,
48326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams         EGL_NONE
49326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     };
50326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
51326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     mDisplay = eglGetDisplay(EGL_DEFAULT_DISPLAY);
52326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     eglInitialize(mDisplay, &mMajorVersion, &mMinorVersion);
53326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     eglChooseConfig(mDisplay, s_configAttribs, &mConfig, 1, &mNumConfigs);
54326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
55326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     if (mWndSurface) {
565ae678f2e68e25bd74cdc408df354c3b6fe481bfMathias Agopian         mSurface = eglCreateWindowSurface(mDisplay, mConfig, mWndSurface,
57326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams                 NULL);
58326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     } else {
59326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams         mSurface = eglCreateWindowSurface(mDisplay, mConfig,
60326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams                 android_createDisplaySurface(),
61326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams                 NULL);
62326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     }
63326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
64326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     mContext = eglCreateContext(mDisplay, mConfig, NULL, NULL);
65a44cb29164726cd9d812117819abdd7b60dfdd93Jason Sams     eglMakeCurrent(mDisplay, mSurface, mSurface, mContext);
66326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     eglQuerySurface(mDisplay, mSurface, EGL_WIDTH, &mWidth);
67326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     eglQuerySurface(mDisplay, mSurface, EGL_HEIGHT, &mHeight);
68326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
69326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
70a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Samsbool Context::runScript(Script *s, uint32_t launchID)
711030893d9b99b72468034da13df025bda479bb97Jason Sams{
721030893d9b99b72468034da13df025bda479bb97Jason Sams    ObjectBaseRef<ProgramFragment> frag(mFragment);
731030893d9b99b72468034da13df025bda479bb97Jason Sams    ObjectBaseRef<ProgramVertex> vtx(mVertex);
741030893d9b99b72468034da13df025bda479bb97Jason Sams    ObjectBaseRef<ProgramFragmentStore> store(mFragmentStore);
751030893d9b99b72468034da13df025bda479bb97Jason Sams
76a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    bool ret = s->run(this, launchID);
771030893d9b99b72468034da13df025bda479bb97Jason Sams
78a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    mFragment.set(frag);
79a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    mVertex.set(vtx);
80a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    mFragmentStore.set(store);
81c9d43db4d216b01b13aebfdb31d5615909591b33Jason Sams    return ret;
821030893d9b99b72468034da13df025bda479bb97Jason Sams}
831030893d9b99b72468034da13df025bda479bb97Jason Sams
841030893d9b99b72468034da13df025bda479bb97Jason Sams
85a44cb29164726cd9d812117819abdd7b60dfdd93Jason Samsbool Context::runRootScript()
86326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
871030893d9b99b72468034da13df025bda479bb97Jason Sams    rsAssert(mRootScript->mEnviroment.mIsRoot);
88326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
89cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    //glColor4f(1,1,1,1);
90cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    //glEnable(GL_LIGHT0);
911030893d9b99b72468034da13df025bda479bb97Jason Sams    glViewport(0, 0, mWidth, mHeight);
92326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
93326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    glDepthMask(GL_TRUE);
94326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
95326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
96928b734b2fbba0800567c8b7e686bcf5f45483ccJason Sams    glClearColor(mRootScript->mEnviroment.mClearColor[0],
97928b734b2fbba0800567c8b7e686bcf5f45483ccJason Sams                 mRootScript->mEnviroment.mClearColor[1],
98928b734b2fbba0800567c8b7e686bcf5f45483ccJason Sams                 mRootScript->mEnviroment.mClearColor[2],
99928b734b2fbba0800567c8b7e686bcf5f45483ccJason Sams                 mRootScript->mEnviroment.mClearColor[3]);
100928b734b2fbba0800567c8b7e686bcf5f45483ccJason Sams    glClearDepthf(mRootScript->mEnviroment.mClearDepth);
101326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    glClear(GL_COLOR_BUFFER_BIT);
102326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    glClear(GL_DEPTH_BUFFER_BIT);
103326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
104cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams#if RS_LOG_TIMES
105cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    struct timespec startTime;
106cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    clock_gettime(CLOCK_MONOTONIC, &startTime);
107cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams#endif
108cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    bool ret = runScript(mRootScript.get(), 0);
109cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams
110cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams#if RS_LOG_TIMES
111cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    struct timespec endTime;
112cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    clock_gettime(CLOCK_MONOTONIC, &endTime);
113cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams
114fcd3192ebff8ab58d841836b7e94361d0998338cJason Sams    uint64_t t1 = endTime.tv_nsec + ((uint64_t)endTime.tv_sec * 1000 * 1000 * 1000);
115fcd3192ebff8ab58d841836b7e94361d0998338cJason Sams    uint64_t t2 = startTime.tv_nsec + ((uint64_t)startTime.tv_sec * 1000 * 1000 * 1000);
116fcd3192ebff8ab58d841836b7e94361d0998338cJason Sams    int t3 = (int)((t1 - t2) / 1000 / 1000);
117fcd3192ebff8ab58d841836b7e94361d0998338cJason Sams    LOGE("times  %i", t3);
118cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams#endif
119cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams
120cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    return ret;
121326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
122326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
123326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setupCheck()
124326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
125326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (mFragmentStore.get()) {
126cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams        mFragmentStore->setupGL(&mStateFragmentStore);
127326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
128326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (mFragment.get()) {
129cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams        mFragment->setupGL(&mStateFragment);
130326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
131326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (mVertex.get()) {
132cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams        mVertex->setupGL(&mStateVertex);
133326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
134326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
135326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
136326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
137326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
138326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid * Context::threadProc(void *vrsc)
139326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
140326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     Context *rsc = static_cast<Context *>(vrsc);
141326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
142326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     rsc->initEGL();
1438ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams
144e57691037aea219562ac686429b4b98202aab7bcJason Sams     ScriptTLSStruct *tlsStruct = new ScriptTLSStruct;
145e57691037aea219562ac686429b4b98202aab7bcJason Sams     if (!tlsStruct) {
146e57691037aea219562ac686429b4b98202aab7bcJason Sams         LOGE("Error allocating tls storage");
147e57691037aea219562ac686429b4b98202aab7bcJason Sams         return NULL;
148e57691037aea219562ac686429b4b98202aab7bcJason Sams     }
149e57691037aea219562ac686429b4b98202aab7bcJason Sams     tlsStruct->mContext = rsc;
150e57691037aea219562ac686429b4b98202aab7bcJason Sams     tlsStruct->mScript = NULL;
151e57691037aea219562ac686429b4b98202aab7bcJason Sams     int status = pthread_setspecific(rsc->gThreadTLSKey, tlsStruct);
152e57691037aea219562ac686429b4b98202aab7bcJason Sams     if (status) {
153e57691037aea219562ac686429b4b98202aab7bcJason Sams         LOGE("pthread_setspecific %i", status);
154e57691037aea219562ac686429b4b98202aab7bcJason Sams     }
155e57691037aea219562ac686429b4b98202aab7bcJason Sams
1568ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams     rsc->mStateVertex.init(rsc, rsc->mWidth, rsc->mHeight);
1578ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams     rsc->setVertex(NULL);
1588ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams     rsc->mStateFragment.init(rsc, rsc->mWidth, rsc->mHeight);
1598ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams     rsc->setFragment(NULL);
1608ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams     rsc->mStateFragmentStore.init(rsc, rsc->mWidth, rsc->mHeight);
1618ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams     rsc->setFragmentStore(NULL);
1628ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams
163326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     rsc->mRunning = true;
164a44cb29164726cd9d812117819abdd7b60dfdd93Jason Sams     bool mDraw = true;
165326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     while (!rsc->mExit) {
166fcd3192ebff8ab58d841836b7e94361d0998338cJason Sams         mDraw |= rsc->mIO.playCoreCommands(rsc, !mDraw);
167732f1c0a29cc468ea271ca3bd654239a0a973fd5Jason Sams         mDraw &= (rsc->mRootScript.get() != NULL);
168326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
169732f1c0a29cc468ea271ca3bd654239a0a973fd5Jason Sams         if (mDraw) {
170a44cb29164726cd9d812117819abdd7b60dfdd93Jason Sams             mDraw = rsc->runRootScript();
171a44cb29164726cd9d812117819abdd7b60dfdd93Jason Sams             eglSwapBuffers(rsc->mDisplay, rsc->mSurface);
172326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams         }
173326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     }
174326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
175326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     glClearColor(0,0,0,0);
176326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     glClear(GL_COLOR_BUFFER_BIT);
177326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     eglSwapBuffers(rsc->mDisplay, rsc->mSurface);
178326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     eglTerminate(rsc->mDisplay);
179326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     return NULL;
180326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
181326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
182326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsContext::Context(Device *dev, Surface *sur)
183326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
184326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    dev->addContext(this);
185326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mDev = dev;
186326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mRunning = false;
187326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mExit = false;
188326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
189326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    // see comment in header
190326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    gCon = this;
191326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
192a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    int status;
193a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    pthread_attr_t threadAttr;
194a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams
195e57691037aea219562ac686429b4b98202aab7bcJason Sams    status = pthread_key_create(&gThreadTLSKey, NULL);
196e57691037aea219562ac686429b4b98202aab7bcJason Sams    if (status) {
197e57691037aea219562ac686429b4b98202aab7bcJason Sams        LOGE("Failed to init thread tls key.");
198e57691037aea219562ac686429b4b98202aab7bcJason Sams        return;
199e57691037aea219562ac686429b4b98202aab7bcJason Sams    }
200e57691037aea219562ac686429b4b98202aab7bcJason Sams
201a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    status = pthread_attr_init(&threadAttr);
202a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    if (status) {
203a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams        LOGE("Failed to init thread attribute.");
204a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams        return;
205a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    }
206a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams
207a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    sched_param sparam;
208a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    sparam.sched_priority = ANDROID_PRIORITY_DISPLAY;
209a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    pthread_attr_setschedparam(&threadAttr, &sparam);
210a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams
211992a0b70d8fd7a14f0c57bc3c7e16c1f269a6609Jason Sams    mWndSurface = sur;
212992a0b70d8fd7a14f0c57bc3c7e16c1f269a6609Jason Sams
213992a0b70d8fd7a14f0c57bc3c7e16c1f269a6609Jason Sams    LOGV("RS Launching thread");
214a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    status = pthread_create(&mThreadId, &threadAttr, threadProc, this);
215326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (status) {
216326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        LOGE("Failed to start rs context thread.");
217326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
218326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
219326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    while(!mRunning) {
220326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        sleep(1);
221326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
222326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
223a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    pthread_attr_destroy(&threadAttr);
224326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
225326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
226326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsContext::~Context()
227326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
228326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mExit = true;
229326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    void *res;
230326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
231326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    int status = pthread_join(mThreadId, &res);
232326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
233326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (mDev) {
234326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        mDev->removeContext(this);
235e57691037aea219562ac686429b4b98202aab7bcJason Sams        pthread_key_delete(gThreadTLSKey);
236326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
237326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
238326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
239326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::swapBuffers()
240326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
241326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    eglSwapBuffers(mDisplay, mSurface);
242326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
243326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
244326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsContextSwap(RsContext vrsc)
245326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
246326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Context *rsc = static_cast<Context *>(vrsc);
247326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->swapBuffers();
248326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
249326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
250326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setRootScript(Script *s)
251326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
252326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mRootScript.set(s);
253326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
254326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
255326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setFragmentStore(ProgramFragmentStore *pfs)
256326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
2578ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    if (pfs == NULL) {
2588ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mFragmentStore.set(mStateFragmentStore.mDefault);
2598ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    } else {
2608ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mFragmentStore.set(pfs);
2618ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    }
262326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
263326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
264326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setFragment(ProgramFragment *pf)
265326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
2668ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    if (pf == NULL) {
2678ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mFragment.set(mStateFragment.mDefault);
2688ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    } else {
2698ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mFragment.set(pf);
2708ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    }
271cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams}
272cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams
273cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Samsvoid Context::allocationCheck(const Allocation *a)
274cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams{
275cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    mVertex->checkUpdatedAllocation(a);
276cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    mFragment->checkUpdatedAllocation(a);
277cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    mFragmentStore->checkUpdatedAllocation(a);
278326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
279326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
280326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setVertex(ProgramVertex *pv)
281326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
2828ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    if (pv == NULL) {
2838ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mVertex.set(mStateVertex.mDefault);
2848ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    } else {
2858ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mVertex.set(pv);
2868ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    }
287326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
288326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
289a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Samsvoid Context::assignName(ObjectBase *obj, const char *name, uint32_t len)
290a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams{
291a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    rsAssert(!obj->getName());
292a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    obj->setName(name, len);
293a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    mNames.add(obj);
294a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams}
295a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams
296a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Samsvoid Context::removeName(ObjectBase *obj)
297a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams{
298a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    for(size_t ct=0; ct < mNames.size(); ct++) {
299a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams        if (obj == mNames[ct]) {
300a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams            mNames.removeAt(ct);
301a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams            return;
302a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams        }
303a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    }
304a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams}
305a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams
306a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason SamsObjectBase * Context::lookupName(const char *name) const
307a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams{
308a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    for(size_t ct=0; ct < mNames.size(); ct++) {
309a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams        if (!strcmp(name, mNames[ct]->getName())) {
310a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams            return mNames[ct];
311a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams        }
312a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    }
313a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    return NULL;
314a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams}
315a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams
316a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Samsvoid Context::appendNameDefines(String8 *str) const
317a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams{
318a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    char buf[256];
319a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    for (size_t ct=0; ct < mNames.size(); ct++) {
320a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        str->append("#define NAMED_");
321a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        str->append(mNames[ct]->getName());
322a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        str->append(" ");
323a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        sprintf(buf, "%i\n", (int)mNames[ct]);
324a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        str->append(buf);
325a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    }
326a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams}
327a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams
32857b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onoratovoid Context::appendVarDefines(String8 *str) const
32957b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato{
33057b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    char buf[256];
33157b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    for (size_t ct=0; ct < mInt32Defines.size(); ct++) {
33257b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append("#define ");
33357b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(mInt32Defines.keyAt(ct));
33457b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(" ");
33557b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        sprintf(buf, "%i\n", (int)mInt32Defines.valueAt(ct));
33657b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(buf);
33757b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato
33857b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    }
33957b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    for (size_t ct=0; ct < mFloatDefines.size(); ct++) {
34057b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append("#define ");
34157b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(mFloatDefines.keyAt(ct));
34257b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(" ");
34357b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        sprintf(buf, "%ff\n", mFloatDefines.valueAt(ct));
34457b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(buf);
34557b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    }
34657b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato}
34757b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato
348a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams
349326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams///////////////////////////////////////////////////////////////////////////////////////////
350a44cb29164726cd9d812117819abdd7b60dfdd93Jason Sams//
351326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
352326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace android {
353326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace renderscript {
354326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
355326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
356326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindRootScript(Context *rsc, RsScript vs)
357326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
358326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Script *s = static_cast<Script *>(vs);
359326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->setRootScript(s);
360326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
361326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
362326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindSampler(Context *rsc, uint32_t slot, RsSampler vs)
363326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
364326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Sampler *s = static_cast<Sampler *>(vs);
365326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
366326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (slot > RS_MAX_SAMPLER_SLOT) {
367326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        LOGE("Invalid sampler slot");
368326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        return;
369326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
370326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
371326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    s->bindToContext(&rsc->mStateSampler, slot);
372326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
373326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
374326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindProgramFragmentStore(Context *rsc, RsProgramFragmentStore vpfs)
375326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
376326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    ProgramFragmentStore *pfs = static_cast<ProgramFragmentStore *>(vpfs);
377326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->setFragmentStore(pfs);
378326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
379326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
380326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindProgramFragment(Context *rsc, RsProgramFragment vpf)
381326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
382326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    ProgramFragment *pf = static_cast<ProgramFragment *>(vpf);
383326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->setFragment(pf);
384326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
385326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
386326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindProgramVertex(Context *rsc, RsProgramVertex vpv)
387326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
388326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    ProgramVertex *pv = static_cast<ProgramVertex *>(vpv);
389326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->setVertex(pv);
390326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
391326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
392a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Samsvoid rsi_AssignName(Context *rsc, void * obj, const char *name, uint32_t len)
393a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams{
394a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    ObjectBase *ob = static_cast<ObjectBase *>(obj);
395a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    rsc->assignName(ob, name, len);
396a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams}
397326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
398707aaf341a4b068e6ccadf923af85acdd85fd775Jason Samsvoid rsi_ObjDestroy(Context *rsc, void *obj)
399707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams{
400707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams    ObjectBase *ob = static_cast<ObjectBase *>(obj);
401707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams    rsc->removeName(ob);
402707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams    ob->decRef();
403707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams}
404707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams
40557b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onoratovoid rsi_ContextSetDefineF(Context *rsc, const char* name, float value)
40657b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato{
40757b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    rsc->addInt32Define(name, value);
40857b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato}
40957b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato
41057b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onoratovoid rsi_ContextSetDefineI32(Context *rsc, const char* name, int32_t value)
41157b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato{
41257b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    rsc->addFloatDefine(name, value);
41357b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato}
414326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
415326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
416326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
417326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
418326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
419326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsRsContext rsContextCreate(RsDevice vdev, void *sur, uint32_t version)
420326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
421326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Device * dev = static_cast<Device *>(vdev);
422326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Context *rsc = new Context(dev, (Surface *)sur);
423326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    return rsc;
424326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
425326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
426326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsContextDestroy(RsContext vrsc)
427326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
428326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Context * rsc = static_cast<Context *>(vrsc);
429326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    delete rsc;
430326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
431326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
432