rsContext.cpp revision 5086938044e0a9b6b1138f915d0d252fe046e102
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         }
1735086938044e0a9b6b1138f915d0d252fe046e102Jason Sams         rsc->objDestroyOOBRun();
174326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     }
175326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
176326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     glClearColor(0,0,0,0);
177326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     glClear(GL_COLOR_BUFFER_BIT);
178326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     eglSwapBuffers(rsc->mDisplay, rsc->mSurface);
179326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     eglTerminate(rsc->mDisplay);
1805086938044e0a9b6b1138f915d0d252fe046e102Jason Sams     rsc->objDestroyOOBRun();
181326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams     return NULL;
182326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
183326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
184326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsContext::Context(Device *dev, Surface *sur)
185326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
186326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    dev->addContext(this);
187326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mDev = dev;
188326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mRunning = false;
189326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mExit = false;
190326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
191326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    // see comment in header
192326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    gCon = this;
193326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
194a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    int status;
195a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    pthread_attr_t threadAttr;
196a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams
197e57691037aea219562ac686429b4b98202aab7bcJason Sams    status = pthread_key_create(&gThreadTLSKey, NULL);
198e57691037aea219562ac686429b4b98202aab7bcJason Sams    if (status) {
199e57691037aea219562ac686429b4b98202aab7bcJason Sams        LOGE("Failed to init thread tls key.");
200e57691037aea219562ac686429b4b98202aab7bcJason Sams        return;
201e57691037aea219562ac686429b4b98202aab7bcJason Sams    }
202e57691037aea219562ac686429b4b98202aab7bcJason Sams
203a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    status = pthread_attr_init(&threadAttr);
204a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    if (status) {
205a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams        LOGE("Failed to init thread attribute.");
206a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams        return;
207a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    }
208a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams
209a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    sched_param sparam;
210a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    sparam.sched_priority = ANDROID_PRIORITY_DISPLAY;
211a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    pthread_attr_setschedparam(&threadAttr, &sparam);
212a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams
213992a0b70d8fd7a14f0c57bc3c7e16c1f269a6609Jason Sams    mWndSurface = sur;
214992a0b70d8fd7a14f0c57bc3c7e16c1f269a6609Jason Sams
2155086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    objDestroyOOBInit();
2165086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
217992a0b70d8fd7a14f0c57bc3c7e16c1f269a6609Jason Sams    LOGV("RS Launching thread");
218a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    status = pthread_create(&mThreadId, &threadAttr, threadProc, this);
219326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (status) {
220326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        LOGE("Failed to start rs context thread.");
221326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
222326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
223326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    while(!mRunning) {
224326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        sleep(1);
225326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
226326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
227a658e905f14fe500bfee3812b213a73cb37ef6f2Jason Sams    pthread_attr_destroy(&threadAttr);
228326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
229326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
230326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsContext::~Context()
231326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
232326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mExit = true;
233326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    void *res;
234326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
235326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    int status = pthread_join(mThreadId, &res);
2365086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    objDestroyOOBRun();
237326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
238326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (mDev) {
239326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        mDev->removeContext(this);
240e57691037aea219562ac686429b4b98202aab7bcJason Sams        pthread_key_delete(gThreadTLSKey);
241326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
2425086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
2435086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    objDestroyOOBDestroy();
244326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
245326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
246326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::swapBuffers()
247326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
248326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    eglSwapBuffers(mDisplay, mSurface);
249326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
250326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
251326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsContextSwap(RsContext vrsc)
252326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
253326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Context *rsc = static_cast<Context *>(vrsc);
254326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->swapBuffers();
255326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
256326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
257326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setRootScript(Script *s)
258326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
259326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mRootScript.set(s);
260326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
261326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
262326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setFragmentStore(ProgramFragmentStore *pfs)
263326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
2648ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    if (pfs == NULL) {
2658ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mFragmentStore.set(mStateFragmentStore.mDefault);
2668ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    } else {
2678ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mFragmentStore.set(pfs);
2688ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    }
269326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
270326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
271326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setFragment(ProgramFragment *pf)
272326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
2738ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    if (pf == NULL) {
2748ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mFragment.set(mStateFragment.mDefault);
2758ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    } else {
2768ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mFragment.set(pf);
2778ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    }
278cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams}
279cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams
280cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Samsvoid Context::allocationCheck(const Allocation *a)
281cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams{
282cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    mVertex->checkUpdatedAllocation(a);
283cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    mFragment->checkUpdatedAllocation(a);
284cfb1d11ce6826fce7241d316d8b7dcab661f63a6Jason Sams    mFragmentStore->checkUpdatedAllocation(a);
285326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
286326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
287326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Context::setVertex(ProgramVertex *pv)
288326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
2898ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    if (pv == NULL) {
2908ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mVertex.set(mStateVertex.mDefault);
2918ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    } else {
2928ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams        mVertex.set(pv);
2938ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams    }
294326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
295326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
296a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Samsvoid Context::assignName(ObjectBase *obj, const char *name, uint32_t len)
297a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams{
298a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    rsAssert(!obj->getName());
299a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    obj->setName(name, len);
300a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    mNames.add(obj);
301a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams}
302a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams
303a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Samsvoid Context::removeName(ObjectBase *obj)
304a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams{
305a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    for(size_t ct=0; ct < mNames.size(); ct++) {
306a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams        if (obj == mNames[ct]) {
307a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams            mNames.removeAt(ct);
308a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams            return;
309a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams        }
310a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    }
311a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams}
312a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams
313a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason SamsObjectBase * Context::lookupName(const char *name) const
314a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams{
315a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    for(size_t ct=0; ct < mNames.size(); ct++) {
316a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams        if (!strcmp(name, mNames[ct]->getName())) {
317a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams            return mNames[ct];
318a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams        }
319a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    }
320a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    return NULL;
321a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams}
322a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams
323a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Samsvoid Context::appendNameDefines(String8 *str) const
324a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams{
325a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    char buf[256];
326a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    for (size_t ct=0; ct < mNames.size(); ct++) {
327a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        str->append("#define NAMED_");
328a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        str->append(mNames[ct]->getName());
329a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        str->append(" ");
330a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        sprintf(buf, "%i\n", (int)mNames[ct]);
331a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams        str->append(buf);
332a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    }
333a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams}
334a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams
33557b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onoratovoid Context::appendVarDefines(String8 *str) const
33657b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato{
33757b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    char buf[256];
33857b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    for (size_t ct=0; ct < mInt32Defines.size(); ct++) {
33957b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append("#define ");
34057b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(mInt32Defines.keyAt(ct));
34157b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(" ");
34257b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        sprintf(buf, "%i\n", (int)mInt32Defines.valueAt(ct));
34357b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(buf);
34457b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato
34557b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    }
34657b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    for (size_t ct=0; ct < mFloatDefines.size(); ct++) {
34757b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append("#define ");
34857b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(mFloatDefines.keyAt(ct));
34957b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(" ");
35057b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        sprintf(buf, "%ff\n", mFloatDefines.valueAt(ct));
35157b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato        str->append(buf);
35257b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    }
35357b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato}
35457b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato
3555086938044e0a9b6b1138f915d0d252fe046e102Jason Samsbool Context::objDestroyOOBInit()
3565086938044e0a9b6b1138f915d0d252fe046e102Jason Sams{
3575086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    int status = pthread_mutex_init(&mObjDestroy.mMutex, NULL);
3585086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    if (status) {
3595086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        LOGE("Context::ObjDestroyOOBInit mutex init failure");
3605086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        return false;
3615086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    }
3625086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    return true;
3635086938044e0a9b6b1138f915d0d252fe046e102Jason Sams}
3645086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
3655086938044e0a9b6b1138f915d0d252fe046e102Jason Samsvoid Context::objDestroyOOBRun()
3665086938044e0a9b6b1138f915d0d252fe046e102Jason Sams{
3675086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    if (mObjDestroy.mNeedToEmpty) {
3685086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        int status = pthread_mutex_lock(&mObjDestroy.mMutex);
3695086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        if (status) {
3705086938044e0a9b6b1138f915d0d252fe046e102Jason Sams            LOGE("Context::ObjDestroyOOBRun: error %i locking for OOBRun.", status);
3715086938044e0a9b6b1138f915d0d252fe046e102Jason Sams            return;
3725086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        }
3735086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
3745086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        for (size_t ct = 0; ct < mObjDestroy.mDestroyList.size(); ct++) {
3755086938044e0a9b6b1138f915d0d252fe046e102Jason Sams            mObjDestroy.mDestroyList[ct]->decRef();
3765086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        }
3775086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        mObjDestroy.mDestroyList.clear();
3785086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        mObjDestroy.mNeedToEmpty = false;
3795086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
3805086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        status = pthread_mutex_unlock(&mObjDestroy.mMutex);
3815086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        if (status) {
3825086938044e0a9b6b1138f915d0d252fe046e102Jason Sams            LOGE("Context::ObjDestroyOOBRun: error %i unlocking for set condition.", status);
3835086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        }
3845086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    }
3855086938044e0a9b6b1138f915d0d252fe046e102Jason Sams}
3865086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
3875086938044e0a9b6b1138f915d0d252fe046e102Jason Samsvoid Context::objDestroyOOBDestroy()
3885086938044e0a9b6b1138f915d0d252fe046e102Jason Sams{
3895086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    rsAssert(!mObjDestroy.mNeedToEmpty);
3905086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    pthread_mutex_destroy(&mObjDestroy.mMutex);
3915086938044e0a9b6b1138f915d0d252fe046e102Jason Sams}
3925086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
3935086938044e0a9b6b1138f915d0d252fe046e102Jason Samsvoid Context::objDestroyAdd(ObjectBase *obj)
3945086938044e0a9b6b1138f915d0d252fe046e102Jason Sams{
3955086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    int status = pthread_mutex_lock(&mObjDestroy.mMutex);
3965086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    if (status) {
3975086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        LOGE("Context::ObjDestroyOOBRun: error %i locking for OOBRun.", status);
3985086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        return;
3995086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    }
4005086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
4015086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    mObjDestroy.mNeedToEmpty = true;
4025086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    mObjDestroy.mDestroyList.add(obj);
4035086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
4045086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    status = pthread_mutex_unlock(&mObjDestroy.mMutex);
4055086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    if (status) {
4065086938044e0a9b6b1138f915d0d252fe046e102Jason Sams        LOGE("Context::ObjDestroyOOBRun: error %i unlocking for set condition.", status);
4075086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    }
4085086938044e0a9b6b1138f915d0d252fe046e102Jason Sams}
4095086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
4105086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
411a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams
412326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams///////////////////////////////////////////////////////////////////////////////////////////
413a44cb29164726cd9d812117819abdd7b60dfdd93Jason Sams//
414326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
415326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace android {
416326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace renderscript {
417326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
418326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
419326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindRootScript(Context *rsc, RsScript vs)
420326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
421326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Script *s = static_cast<Script *>(vs);
422326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->setRootScript(s);
423326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
424326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
425326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindSampler(Context *rsc, uint32_t slot, RsSampler vs)
426326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
427326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Sampler *s = static_cast<Sampler *>(vs);
428326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
429326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    if (slot > RS_MAX_SAMPLER_SLOT) {
430326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        LOGE("Invalid sampler slot");
431326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams        return;
432326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
433326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
434326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    s->bindToContext(&rsc->mStateSampler, slot);
435326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
436326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
437326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindProgramFragmentStore(Context *rsc, RsProgramFragmentStore vpfs)
438326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
439326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    ProgramFragmentStore *pfs = static_cast<ProgramFragmentStore *>(vpfs);
440326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->setFragmentStore(pfs);
441326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
442326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
443326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindProgramFragment(Context *rsc, RsProgramFragment vpf)
444326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
445326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    ProgramFragment *pf = static_cast<ProgramFragment *>(vpf);
446326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->setFragment(pf);
447326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
448326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
449326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_ContextBindProgramVertex(Context *rsc, RsProgramVertex vpv)
450326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
451326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    ProgramVertex *pv = static_cast<ProgramVertex *>(vpv);
452326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    rsc->setVertex(pv);
453326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
454326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
455a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Samsvoid rsi_AssignName(Context *rsc, void * obj, const char *name, uint32_t len)
456a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams{
457a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams    ObjectBase *ob = static_cast<ObjectBase *>(obj);
458a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams    rsc->assignName(ob, name, len);
459a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams}
460326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
461707aaf341a4b068e6ccadf923af85acdd85fd775Jason Samsvoid rsi_ObjDestroy(Context *rsc, void *obj)
462707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams{
463707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams    ObjectBase *ob = static_cast<ObjectBase *>(obj);
464707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams    rsc->removeName(ob);
465707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams    ob->decRef();
466707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams}
467707aaf341a4b068e6ccadf923af85acdd85fd775Jason Sams
46857b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onoratovoid rsi_ContextSetDefineF(Context *rsc, const char* name, float value)
46957b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato{
47057b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    rsc->addInt32Define(name, value);
47157b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato}
47257b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato
47357b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onoratovoid rsi_ContextSetDefineI32(Context *rsc, const char* name, int32_t value)
47457b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato{
47557b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato    rsc->addFloatDefine(name, value);
47657b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato}
477326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
478326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
479326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
480326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
481326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
482326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsRsContext rsContextCreate(RsDevice vdev, void *sur, uint32_t version)
483326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
484326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Device * dev = static_cast<Device *>(vdev);
485326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Context *rsc = new Context(dev, (Surface *)sur);
486326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    return rsc;
487326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
488326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
489326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsContextDestroy(RsContext vrsc)
490326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{
491326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    Context * rsc = static_cast<Context *>(vrsc);
492326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    delete rsc;
493326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
494326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
4955086938044e0a9b6b1138f915d0d252fe046e102Jason Samsvoid rsObjDestroyOOB(RsContext vrsc, void *obj)
4965086938044e0a9b6b1138f915d0d252fe046e102Jason Sams{
4975086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    Context * rsc = static_cast<Context *>(vrsc);
4985086938044e0a9b6b1138f915d0d252fe046e102Jason Sams    rsc->objDestroyAdd(static_cast<ObjectBase *>(obj));
4995086938044e0a9b6b1138f915d0d252fe046e102Jason Sams}
5005086938044e0a9b6b1138f915d0d252fe046e102Jason Sams
501