rsScriptC.cpp revision 1f24db404b2cf8768bf2bd53a3caeb5812b8ce9f
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 "rsContext.h" 18326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include "rsScriptC.h" 19326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include "rsMatrix.h" 20e7b4b86cf8ff443ce4f7bdf7050ab9e3cf39a6d5Anatol Pomazau#include "../../compile/libbcc/include/bcc/bcc.h" 219c4e4ca9ff75a7fe18544c83fcf782e46c9b6ac2Joe Onorato#include "utils/Timers.h" 22b26fb04770442244233b630960f419cb154abc77Alex Sakhartchouk#include "utils/StopWatch.h" 231ef8b80bc49f415b93912fe7335f852953bde4a4Jack Palevich 241aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams#include <GLES/gl.h> 251aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams#include <GLES/glext.h> 261aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams 27326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android; 28326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android::renderscript; 29326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 30e57691037aea219562ac686429b4b98202aab7bcJason Sams#define GET_TLS() Context::ScriptTLSStruct * tls = \ 31e57691037aea219562ac686429b4b98202aab7bcJason Sams (Context::ScriptTLSStruct *)pthread_getspecific(Context::gThreadTLSKey); \ 32e57691037aea219562ac686429b4b98202aab7bcJason Sams Context * rsc = tls->mContext; \ 33e57691037aea219562ac686429b4b98202aab7bcJason Sams ScriptC * sc = (ScriptC *) tls->mScript 34e57691037aea219562ac686429b4b98202aab7bcJason Sams 35326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 36afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukScriptC::ScriptC(Context *rsc) : Script(rsc) { 37be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams mBccScript = NULL; 38efb8de1ef851c9c2a042ad06f64e33bb8b366041Jason Sams memset(&mProgram, 0, sizeof(mProgram)); 39326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 40326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 41afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukScriptC::~ScriptC() { 42be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams if (mBccScript) { 43be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams bccDeleteScript(mBccScript); 441ef8b80bc49f415b93912fe7335f852953bde4a4Jack Palevich } 45e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams free(mEnviroment.mScriptText); 46e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams mEnviroment.mScriptText = NULL; 47326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 48326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 49afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid ScriptC::setupScript(Context *rsc) { 50c61346b91434307c5003029017b54ce9c49112beJason Sams mEnviroment.mStartTimeMillis 51c61346b91434307c5003029017b54ce9c49112beJason Sams = nanoseconds_to_milliseconds(systemTime(SYSTEM_TIME_MONOTONIC)); 52c61346b91434307c5003029017b54ce9c49112beJason Sams 53be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams for (uint32_t ct=0; ct < mEnviroment.mFieldCount; ct++) { 54900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams if (mSlots[ct].get() && !mTypes[ct].get()) { 55900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams mTypes[ct].set(mSlots[ct]->getType()); 56900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams } 57900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams 58900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams if (!mTypes[ct].get()) 59be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams continue; 60900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams void *ptr = NULL; 61900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams if (mSlots[ct].get()) { 62900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams ptr = mSlots[ct]->getPtr(); 63900f1616bf33c7ba13cf2a737832a95bcd176388Jason Sams } 64be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams void **dest = ((void ***)mEnviroment.mFieldAddress)[ct]; 65be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams 66b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams if (rsc->props.mLogScripts) { 672fad7e47a8177235bb88fe271572bd986a7e4136Jason Sams if (mSlots[ct].get() != NULL) { 682fad7e47a8177235bb88fe271572bd986a7e4136Jason Sams LOGV("%p ScriptC::setupScript slot=%i dst=%p src=%p type=%p", rsc, ct, dest, ptr, mSlots[ct]->getType()); 692fad7e47a8177235bb88fe271572bd986a7e4136Jason Sams } else { 702fad7e47a8177235bb88fe271572bd986a7e4136Jason Sams LOGV("%p ScriptC::setupScript slot=%i dst=%p src=%p type=null", rsc, ct, dest, ptr); 712fad7e47a8177235bb88fe271572bd986a7e4136Jason Sams } 72b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams } 73be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams 74be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams if (dest) { 75be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams *dest = ptr; 76ada7f272890d8791bc518c95989ad7d13050834dJason Sams } 77ada7f272890d8791bc518c95989ad7d13050834dJason Sams } 78ada7f272890d8791bc518c95989ad7d13050834dJason Sams} 79ada7f272890d8791bc518c95989ad7d13050834dJason Sams 80afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukconst Allocation *ScriptC::ptrToAllocation(const void *ptr) const { 81ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams if (!ptr) { 82ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams return NULL; 83ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams } 84ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams for (uint32_t ct=0; ct < mEnviroment.mFieldCount; ct++) { 85ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams if (!mSlots[ct].get()) 86ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams continue; 87ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams if (mSlots[ct]->getPtr() == ptr) { 88ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams return mSlots[ct].get(); 89ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams } 90ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams } 91ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams LOGE("ScriptC::ptrToAllocation, failed to find %p", ptr); 92ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams return NULL; 93ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams} 94ce92d4baf7a5bce097228fdd4498601764cd4014Jason Sams 95afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukScript * ScriptC::setTLS(Script *sc) { 9622fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams Context::ScriptTLSStruct * tls = (Context::ScriptTLSStruct *) 9722fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams pthread_getspecific(Context::gThreadTLSKey); 9822fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams rsAssert(tls); 99c61346b91434307c5003029017b54ce9c49112beJason Sams Script *old = tls->mScript; 100c61346b91434307c5003029017b54ce9c49112beJason Sams tls->mScript = sc; 101c61346b91434307c5003029017b54ce9c49112beJason Sams return old; 10222fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams} 10322fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams 104afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid ScriptC::setupGLState(Context *rsc) { 105a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams if (mEnviroment.mFragmentStore.get()) { 10660709257bbdeb0c50f39b9c8969dc76264d6e142Jason Sams rsc->setProgramStore(mEnviroment.mFragmentStore.get()); 107a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams } 108a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams if (mEnviroment.mFragment.get()) { 10960709257bbdeb0c50f39b9c8969dc76264d6e142Jason Sams rsc->setProgramFragment(mEnviroment.mFragment.get()); 110a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams } 1118ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams if (mEnviroment.mVertex.get()) { 11260709257bbdeb0c50f39b9c8969dc76264d6e142Jason Sams rsc->setProgramVertex(mEnviroment.mVertex.get()); 1138ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams } 114b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams if (mEnviroment.mRaster.get()) { 11560709257bbdeb0c50f39b9c8969dc76264d6e142Jason Sams rsc->setProgramRaster(mEnviroment.mRaster.get()); 116b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams } 117c61346b91434307c5003029017b54ce9c49112beJason Sams} 118a0a1b6fbece2eb8d72d788422ab3e5f58d5a9216Jason Sams 119afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukuint32_t ScriptC::run(Context *rsc) { 120c61346b91434307c5003029017b54ce9c49112beJason Sams if (mProgram.mRoot == NULL) { 121c61346b91434307c5003029017b54ce9c49112beJason Sams rsc->setError(RS_ERROR_BAD_SCRIPT, "Attempted to run bad script"); 122c61346b91434307c5003029017b54ce9c49112beJason Sams return 0; 1239c4e4ca9ff75a7fe18544c83fcf782e46c9b6ac2Joe Onorato } 124c61346b91434307c5003029017b54ce9c49112beJason Sams 1251f24db404b2cf8768bf2bd53a3caeb5812b8ce9fJason Sams setupGLState(rsc); 126c61346b91434307c5003029017b54ce9c49112beJason Sams setupScript(rsc); 1271d54f10f3c23e0d7ec57e52ec3b0701a2a5ed24eJason Sams 1282dca84dd6c07992f78ad050177975f16486dd77eJason Sams uint32_t ret = 0; 129c61346b91434307c5003029017b54ce9c49112beJason Sams Script * oldTLS = setTLS(this); 130b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams 131b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams if (rsc->props.mLogScripts) { 132b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams LOGV("%p ScriptC::run invoking root, ptr %p", rsc, mProgram.mRoot); 133b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams } 134b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams 135be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams ret = mProgram.mRoot(); 136b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams 137b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams if (rsc->props.mLogScripts) { 138b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams LOGV("%p ScriptC::run invoking complete, ret=%i", rsc, ret); 139b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams } 140b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams 141c61346b91434307c5003029017b54ce9c49112beJason Sams setTLS(oldTLS); 142e45ac6e91864f2a6617b6a2c0aa87cdb62cf58fdJason Sams return ret; 143326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 144326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 1457bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Samstypedef struct { 1467bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams Context *rsc; 1477bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams ScriptC *script; 1487bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams const Allocation * ain; 1497bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams Allocation * aout; 1507bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams const void * usr; 1517bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 1527bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t mSliceSize; 1537bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams volatile int mSliceNum; 1547bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 1557bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams const uint8_t *ptrIn; 1567bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t eStrideIn; 1577bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint8_t *ptrOut; 1587bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t eStrideOut; 1597bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 1607bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t xStart; 1617bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t xEnd; 1627bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t yStart; 1637bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t yEnd; 1647bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t zStart; 1657bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t zEnd; 1667bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t arrayStart; 1677bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t arrayEnd; 1687bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 1697bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t dimX; 1707bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t dimY; 1717bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t dimZ; 1727bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t dimArray; 1737bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams} MTLaunchStruct; 1747bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Samstypedef int (*rs_t)(const void *, void *, const void *, uint32_t, uint32_t, uint32_t, uint32_t); 1757bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 176afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukstatic void wc_xy(void *usr, uint32_t idx) { 1777bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams MTLaunchStruct *mtls = (MTLaunchStruct *)usr; 1787bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 1797bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams while (1) { 1807bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t slice = (uint32_t)android_atomic_inc(&mtls->mSliceNum); 1817bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t yStart = mtls->yStart + slice * mtls->mSliceSize; 1827bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t yEnd = yStart + mtls->mSliceSize; 1837bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams yEnd = rsMin(yEnd, mtls->yEnd); 1847bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams if (yEnd <= yStart) { 1857bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams return; 1867bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams } 1877bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 1887bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams //LOGE("usr idx %i, x %i,%i y %i,%i", idx, mtls->xStart, mtls->xEnd, yStart, yEnd); 1898d957fa762eff6c03a93ddea9405d9575665f1ecJason Sams //LOGE("usr ptr in %p, out %p", mtls->ptrIn, mtls->ptrOut); 1907bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams for (uint32_t y = yStart; y < yEnd; y++) { 1917bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint32_t offset = mtls->dimX * y; 1927bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams uint8_t *xPtrOut = mtls->ptrOut + (mtls->eStrideOut * offset); 1937bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams const uint8_t *xPtrIn = mtls->ptrIn + (mtls->eStrideIn * offset); 1947bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 1957bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams for (uint32_t x = mtls->xStart; x < mtls->xEnd; x++) { 1967bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams ((rs_t)mtls->script->mProgram.mRoot) (xPtrIn, xPtrOut, mtls->usr, x, y, 0, 0); 1977bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams xPtrIn += mtls->eStrideIn; 1987bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams xPtrOut += mtls->eStrideOut; 1997bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams } 2007bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams } 2017bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams } 2027bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams} 2037bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 204afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukstatic void wc_x(void *usr, uint32_t idx) { 205177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams MTLaunchStruct *mtls = (MTLaunchStruct *)usr; 206177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams 207177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams while (1) { 208177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams uint32_t slice = (uint32_t)android_atomic_inc(&mtls->mSliceNum); 209177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams uint32_t xStart = mtls->xStart + slice * mtls->mSliceSize; 210177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams uint32_t xEnd = xStart + mtls->mSliceSize; 211177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams xEnd = rsMin(xEnd, mtls->xEnd); 212177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams if (xEnd <= xStart) { 213177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams return; 214177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams } 215177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams 216177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams //LOGE("usr idx %i, x %i,%i y %i,%i", idx, mtls->xStart, mtls->xEnd, yStart, yEnd); 217177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams //LOGE("usr ptr in %p, out %p", mtls->ptrIn, mtls->ptrOut); 218177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams uint8_t *xPtrOut = mtls->ptrOut + (mtls->eStrideOut * xStart); 219177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams const uint8_t *xPtrIn = mtls->ptrIn + (mtls->eStrideIn * xStart); 220177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams for (uint32_t x = xStart; x < xEnd; x++) { 221177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams ((rs_t)mtls->script->mProgram.mRoot) (xPtrIn, xPtrOut, mtls->usr, x, 0, 0, 0); 222177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams xPtrIn += mtls->eStrideIn; 223177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams xPtrOut += mtls->eStrideOut; 224177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams } 225177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams } 226177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams} 227177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams 228ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Samsvoid ScriptC::runForEach(Context *rsc, 229ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams const Allocation * ain, 230ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams Allocation * aout, 231ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams const void * usr, 232afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchouk const RsScriptCall *sc) { 2337bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams MTLaunchStruct mtls; 2347bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams memset(&mtls, 0, sizeof(mtls)); 23560709257bbdeb0c50f39b9c8969dc76264d6e142Jason Sams Context::PushState ps(rsc); 2367bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 2377bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams if (ain) { 2387bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.dimX = ain->getType()->getDimX(); 2397bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.dimY = ain->getType()->getDimY(); 2407bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.dimZ = ain->getType()->getDimZ(); 2417bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams //mtls.dimArray = ain->getType()->getDimArray(); 2427bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams } else if (aout) { 2437bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.dimX = aout->getType()->getDimX(); 2447bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.dimY = aout->getType()->getDimY(); 2457bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.dimZ = aout->getType()->getDimZ(); 2467bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams //mtls.dimArray = aout->getType()->getDimArray(); 2477bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams } else { 2487bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams rsc->setError(RS_ERROR_BAD_SCRIPT, "rsForEach called with null allocations"); 2497bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams return; 2507bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams } 251ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams 252ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams if (!sc || (sc->xEnd == 0)) { 2537bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.xEnd = mtls.dimX; 254ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams } else { 2557bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams rsAssert(sc->xStart < mtls.dimX); 2567bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams rsAssert(sc->xEnd <= mtls.dimX); 257ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams rsAssert(sc->xStart < sc->xEnd); 2587bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.xStart = rsMin(mtls.dimX, sc->xStart); 2597bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.xEnd = rsMin(mtls.dimX, sc->xEnd); 2607bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams if (mtls.xStart >= mtls.xEnd) return; 261ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams } 262c61346b91434307c5003029017b54ce9c49112beJason Sams 263ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams if (!sc || (sc->yEnd == 0)) { 2647bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.yEnd = mtls.dimY; 265ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams } else { 2667bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams rsAssert(sc->yStart < mtls.dimY); 2677bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams rsAssert(sc->yEnd <= mtls.dimY); 268ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams rsAssert(sc->yStart < sc->yEnd); 2697bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.yStart = rsMin(mtls.dimY, sc->yStart); 2707bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.yEnd = rsMin(mtls.dimY, sc->yEnd); 2717bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams if (mtls.yStart >= mtls.yEnd) return; 272ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams } 273ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams 2747bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.xEnd = rsMax((uint32_t)1, mtls.xEnd); 2757bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.yEnd = rsMax((uint32_t)1, mtls.yEnd); 2767bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.zEnd = rsMax((uint32_t)1, mtls.zEnd); 2777bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.arrayEnd = rsMax((uint32_t)1, mtls.arrayEnd); 278ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams 279ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams rsAssert(ain->getType()->getDimZ() == 0); 280c61346b91434307c5003029017b54ce9c49112beJason Sams 2811f24db404b2cf8768bf2bd53a3caeb5812b8ce9fJason Sams setupGLState(rsc); 282c61346b91434307c5003029017b54ce9c49112beJason Sams setupScript(rsc); 283c61346b91434307c5003029017b54ce9c49112beJason Sams Script * oldTLS = setTLS(this); 284c61346b91434307c5003029017b54ce9c49112beJason Sams 2857bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.rsc = rsc; 2867bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.ain = ain; 2877bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.aout = aout; 2887bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.script = this; 2897bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.usr = usr; 2907bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.mSliceSize = 10; 2917bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.mSliceNum = 0; 2927bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 2937bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.ptrIn = NULL; 2947bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.eStrideIn = 0; 2957bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams if (ain) { 2967bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.ptrIn = (const uint8_t *)ain->getPtr(); 2977bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.eStrideIn = ain->getType()->getElementSizeBytes(); 2987bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams } 299c61346b91434307c5003029017b54ce9c49112beJason Sams 3007bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.ptrOut = NULL; 3017bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.eStrideOut = 0; 302c61346b91434307c5003029017b54ce9c49112beJason Sams if (aout) { 3037bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.ptrOut = (uint8_t *)aout->getPtr(); 3047bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams mtls.eStrideOut = aout->getType()->getElementSizeBytes(); 305c61346b91434307c5003029017b54ce9c49112beJason Sams } 306c61346b91434307c5003029017b54ce9c49112beJason Sams 307177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams if ((rsc->getWorkerPoolSize() > 1) && mEnviroment.mIsThreadable) { 308177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams if (mtls.dimY > 1) { 309177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams rsc->launchThreads(wc_xy, &mtls); 310177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams } else { 311177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams rsc->launchThreads(wc_x, &mtls); 312177f8446d58e5b1a4258935371a9450dbe34dca6Jason Sams } 3137bf29ddc35450d8064541c42c99a1f48be6cf0ddJason Sams 314181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams //LOGE("launch 1"); 315181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams } else { 3168d957fa762eff6c03a93ddea9405d9575665f1ecJason Sams //LOGE("launch 3"); 317181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams for (uint32_t ar = mtls.arrayStart; ar < mtls.arrayEnd; ar++) { 318181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams for (uint32_t z = mtls.zStart; z < mtls.zEnd; z++) { 319181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams for (uint32_t y = mtls.yStart; y < mtls.yEnd; y++) { 320181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams uint32_t offset = mtls.dimX * mtls.dimY * mtls.dimZ * ar + 321181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams mtls.dimX * mtls.dimY * z + 322181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams mtls.dimX * y; 323181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams uint8_t *xPtrOut = mtls.ptrOut + (mtls.eStrideOut * offset); 324181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams const uint8_t *xPtrIn = mtls.ptrIn + (mtls.eStrideIn * offset); 325181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams 326181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams for (uint32_t x = mtls.xStart; x < mtls.xEnd; x++) { 327181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams ((rs_t)mProgram.mRoot) (xPtrIn, xPtrOut, usr, x, y, z, ar); 328181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams xPtrIn += mtls.eStrideIn; 329181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams xPtrOut += mtls.eStrideOut; 330181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams } 331ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams } 332ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams } 333ace3e01f07252ee0fa47fcf1ac48864d8220b90eJason Sams } 334c61346b91434307c5003029017b54ce9c49112beJason Sams } 335181334092f78273d0da2d854ebbe7b24508d3bfcJason Sams 336c61346b91434307c5003029017b54ce9c49112beJason Sams setTLS(oldTLS); 337c61346b91434307c5003029017b54ce9c49112beJason Sams} 338c61346b91434307c5003029017b54ce9c49112beJason Sams 339afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid ScriptC::Invoke(Context *rsc, uint32_t slot, const void *data, uint32_t len) { 34022fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams if ((slot >= mEnviroment.mInvokeFunctionCount) || 34122fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams (mEnviroment.mInvokeFunctions[slot] == NULL)) { 34222fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams rsc->setError(RS_ERROR_BAD_SCRIPT, "Calling invoke on bad script"); 34322fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams return; 34422fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams } 345c61346b91434307c5003029017b54ce9c49112beJason Sams setupScript(rsc); 346c61346b91434307c5003029017b54ce9c49112beJason Sams Script * oldTLS = setTLS(this); 34722fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams 348b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams if (rsc->props.mLogScripts) { 349b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams LOGV("%p ScriptC::Invoke invoking slot %i, ptr %p", rsc, slot, mEnviroment.mInvokeFunctions[slot]); 350b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams } 3512a63bf6c293d89c8e3725cfb7ee2add3dd3f0246Jason Sams ((void (*)(const void *, uint32_t)) 3522a63bf6c293d89c8e3725cfb7ee2add3dd3f0246Jason Sams mEnviroment.mInvokeFunctions[slot])(data, len); 353b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams if (rsc->props.mLogScripts) { 354b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams LOGV("%p ScriptC::Invoke complete", rsc); 355b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams } 3562a63bf6c293d89c8e3725cfb7ee2add3dd3f0246Jason Sams 357c61346b91434307c5003029017b54ce9c49112beJason Sams setTLS(oldTLS); 35822fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams} 35922fa371bf64b8aae786acfe5d711af21afb13a93Jason Sams 360afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukScriptCState::ScriptCState() { 36101b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines mScript.clear(); 362326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 363326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 364afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukScriptCState::~ScriptCState() { 36501b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines mScript.clear(); 366326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 367326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 368afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid ScriptCState::init(Context *rsc) { 36901b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines clear(rsc); 37001b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines} 37101b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines 372afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid ScriptCState::clear(Context *rsc) { 37301b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines rsAssert(rsc); 37401b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines mScript.clear(); 37501b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines mScript.set(new ScriptC(rsc)); 3761f52633fefd1862451e6a30209d590680d02beecJason Sams} 3771f52633fefd1862451e6a30209d590680d02beecJason Sams 378afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukstatic BCCvoid* symbolLookup(BCCvoid* pContext, const BCCchar* name) { 379aeb094b520d8ea49b74129927578f18f758c873eJason Sams const ScriptCState::SymbolTable_t *sym; 380dd663fa8367bfacb6c77b368f91adf614cd0bebaJason Sams ScriptC *s = (ScriptC *)pContext; 381f17b13be814135b85e6aed7e3cca441c8e00e8c4Shih-wei Liao if (!strcmp(name, "__isThreadable")) { 382f17b13be814135b85e6aed7e3cca441c8e00e8c4Shih-wei Liao return (BCCvoid*) s->mEnviroment.mIsThreadable; 383f17b13be814135b85e6aed7e3cca441c8e00e8c4Shih-wei Liao } else if (!strcmp(name, "__clearThreadable")) { 384f17b13be814135b85e6aed7e3cca441c8e00e8c4Shih-wei Liao s->mEnviroment.mIsThreadable = false; 385f17b13be814135b85e6aed7e3cca441c8e00e8c4Shih-wei Liao return NULL; 386f17b13be814135b85e6aed7e3cca441c8e00e8c4Shih-wei Liao } 387aeb094b520d8ea49b74129927578f18f758c873eJason Sams sym = ScriptCState::lookupSymbol(name); 3886bfc1b91dc7684f8ad9dc9f605e92ed8a31d5bbeJason Sams if (!sym) { 3896bfc1b91dc7684f8ad9dc9f605e92ed8a31d5bbeJason Sams sym = ScriptCState::lookupSymbolCL(name); 390aeb094b520d8ea49b74129927578f18f758c873eJason Sams } 3916bfc1b91dc7684f8ad9dc9f605e92ed8a31d5bbeJason Sams if (!sym) { 3926bfc1b91dc7684f8ad9dc9f605e92ed8a31d5bbeJason Sams sym = ScriptCState::lookupSymbolGL(name); 393aeb094b520d8ea49b74129927578f18f758c873eJason Sams } 39429df66f82aeef7fa7e2cf00edbf00d43c822b05aJason Sams if (sym) { 3956bfc1b91dc7684f8ad9dc9f605e92ed8a31d5bbeJason Sams s->mEnviroment.mIsThreadable &= sym->threadable; 39629df66f82aeef7fa7e2cf00edbf00d43c822b05aJason Sams return sym->mPtr; 39729df66f82aeef7fa7e2cf00edbf00d43c822b05aJason Sams } 39829df66f82aeef7fa7e2cf00edbf00d43c822b05aJason Sams LOGE("ScriptC sym lookup failed for %s", name); 39929df66f82aeef7fa7e2cf00edbf00d43c822b05aJason Sams return NULL; 40029df66f82aeef7fa7e2cf00edbf00d43c822b05aJason Sams} 401a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams 4021f9ba735cc429ae8df140644f6f0a4481f2a8068Shih-wei Liaoextern const char rs_runtime_lib_bc[]; 4031f9ba735cc429ae8df140644f6f0a4481f2a8068Shih-wei Liaoextern unsigned rs_runtime_lib_bc_size; 4041f9ba735cc429ae8df140644f6f0a4481f2a8068Shih-wei Liao 4059503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liaovoid ScriptCState::runCompiler(Context *rsc, ScriptC *s, const char *resName) { 406b26fb04770442244233b630960f419cb154abc77Alex Sakhartchouk { 407b26fb04770442244233b630960f419cb154abc77Alex Sakhartchouk s->mBccScript = bccCreateScript(); 408b26fb04770442244233b630960f419cb154abc77Alex Sakhartchouk s->mEnviroment.mIsThreadable = true; 409b26fb04770442244233b630960f419cb154abc77Alex Sakhartchouk bccRegisterSymbolCallback(s->mBccScript, symbolLookup, s); 4109503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao // bccReadBC() reads in the BitCode, if no cache file corresponding to 4119503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao // the resName is found. Otherwise, bccReadBC() returns a negative value 4129503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao // and the "else" branch will be taken. 4139503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao if (bccReadBC(s->mBccScript, 4149503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao s->mEnviroment.mScriptText, 4159503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao s->mEnviroment.mScriptTextLength, 4169503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao resName) >= 0) { 4179503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao //bccLinkBC(s->mBccScript, rs_runtime_lib_bc, rs_runtime_lib_bc_size); 4189503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao bccCompileBC(s->mBccScript); 4199503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao } else { 4209503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao // bccReadBC returns a neagative value: Didn't read any script, 4219503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao // So, use cached binary instead 4229503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao bccLoadBinary(s->mBccScript); 4239503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao } 424b26fb04770442244233b630960f419cb154abc77Alex Sakhartchouk bccGetScriptLabel(s->mBccScript, "root", (BCCvoid**) &s->mProgram.mRoot); 425b26fb04770442244233b630960f419cb154abc77Alex Sakhartchouk bccGetScriptLabel(s->mBccScript, "init", (BCCvoid**) &s->mProgram.mInit); 426b26fb04770442244233b630960f419cb154abc77Alex Sakhartchouk } 427b9077f48e2c5aff1838bbbeccf56c2b5f5490ab6Jason Sams LOGV("%p ScriptCState::runCompiler root %p, init %p", rsc, s->mProgram.mRoot, s->mProgram.mInit); 428f1685045e3423f2e342c3d74c206a25d72eba89dJason Sams 4298c6bc6930d4996b897de8e5113da4a4efae2310cJason Sams if (s->mProgram.mInit) { 4308c6bc6930d4996b897de8e5113da4a4efae2310cJason Sams s->mProgram.mInit(); 4311d54f10f3c23e0d7ec57e52ec3b0701a2a5ed24eJason Sams } 4321d54f10f3c23e0d7ec57e52ec3b0701a2a5ed24eJason Sams 4338c88090e8cccab103eebe2ff569e116e9f5fb208Jason Sams bccGetExportFuncs(s->mBccScript, (BCCsizei*) &s->mEnviroment.mInvokeFunctionCount, 0, NULL); 434afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchouk if (s->mEnviroment.mInvokeFunctionCount <= 0) 4358c88090e8cccab103eebe2ff569e116e9f5fb208Jason Sams s->mEnviroment.mInvokeFunctions = NULL; 4368c88090e8cccab103eebe2ff569e116e9f5fb208Jason Sams else { 4378c88090e8cccab103eebe2ff569e116e9f5fb208Jason Sams s->mEnviroment.mInvokeFunctions = (Script::InvokeFunc_t*) calloc(s->mEnviroment.mInvokeFunctionCount, sizeof(Script::InvokeFunc_t)); 4388c88090e8cccab103eebe2ff569e116e9f5fb208Jason Sams bccGetExportFuncs(s->mBccScript, NULL, s->mEnviroment.mInvokeFunctionCount, (BCCvoid **) s->mEnviroment.mInvokeFunctions); 4398c88090e8cccab103eebe2ff569e116e9f5fb208Jason Sams } 4408c88090e8cccab103eebe2ff569e116e9f5fb208Jason Sams 441a226b166dde77ae4bf4202a60afd14339b040dd3Shih-wei Liao bccGetExportVars(s->mBccScript, (BCCsizei*) &s->mEnviroment.mFieldCount, 0, NULL); 442afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchouk if (s->mEnviroment.mFieldCount <= 0) 443a226b166dde77ae4bf4202a60afd14339b040dd3Shih-wei Liao s->mEnviroment.mFieldAddress = NULL; 444a226b166dde77ae4bf4202a60afd14339b040dd3Shih-wei Liao else { 445a226b166dde77ae4bf4202a60afd14339b040dd3Shih-wei Liao s->mEnviroment.mFieldAddress = (void **) calloc(s->mEnviroment.mFieldCount, sizeof(void *)); 446a226b166dde77ae4bf4202a60afd14339b040dd3Shih-wei Liao bccGetExportVars(s->mBccScript, NULL, s->mEnviroment.mFieldCount, (BCCvoid **) s->mEnviroment.mFieldAddress); 447700ba38f022208686523ab4280c4fc9f102aa273Alex Sakhartchouk s->initSlots(); 448a226b166dde77ae4bf4202a60afd14339b040dd3Shih-wei Liao } 4491d54f10f3c23e0d7ec57e52ec3b0701a2a5ed24eJason Sams 4508c6bc6930d4996b897de8e5113da4a4efae2310cJason Sams s->mEnviroment.mFragment.set(rsc->getDefaultProgramFragment()); 4518c6bc6930d4996b897de8e5113da4a4efae2310cJason Sams s->mEnviroment.mVertex.set(rsc->getDefaultProgramVertex()); 452ccc010bb7c0f89e162bf60033968a20be90a903aJason Sams s->mEnviroment.mFragmentStore.set(rsc->getDefaultProgramStore()); 453b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams s->mEnviroment.mRaster.set(rsc->getDefaultProgramRaster()); 454a4a54e42fc710a62b47cbcb9d64c34a190429d9eJason Sams 455be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams if (s->mProgram.mRoot) { 4561030893d9b99b72468034da13df025bda479bb97Jason Sams const static int pragmaMax = 16; 457be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams BCCsizei pragmaCount; 458be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams BCCchar * str[pragmaMax]; 459be36bf3a76481737a7fa606a04144ceef80eb4f2Jason Sams bccGetPragmas(s->mBccScript, &pragmaCount, pragmaMax, &str[0]); 4601030893d9b99b72468034da13df025bda479bb97Jason Sams 4611030893d9b99b72468034da13df025bda479bb97Jason Sams for (int ct=0; ct < pragmaCount; ct+=2) { 462aeb094b520d8ea49b74129927578f18f758c873eJason Sams //LOGE("pragme %s %s", str[ct], str[ct+1]); 4631030893d9b99b72468034da13df025bda479bb97Jason Sams if (!strcmp(str[ct], "version")) { 4641030893d9b99b72468034da13df025bda479bb97Jason Sams continue; 4651030893d9b99b72468034da13df025bda479bb97Jason Sams } 4661030893d9b99b72468034da13df025bda479bb97Jason Sams 4671030893d9b99b72468034da13df025bda479bb97Jason Sams if (!strcmp(str[ct], "stateVertex")) { 4688ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams if (!strcmp(str[ct+1], "default")) { 4698ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams continue; 4708ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams } 4718ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams if (!strcmp(str[ct+1], "parent")) { 4728c6bc6930d4996b897de8e5113da4a4efae2310cJason Sams s->mEnviroment.mVertex.clear(); 4738ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams continue; 4748ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams } 4751030893d9b99b72468034da13df025bda479bb97Jason Sams LOGE("Unreconized value %s passed to stateVertex", str[ct+1]); 4761030893d9b99b72468034da13df025bda479bb97Jason Sams } 4771030893d9b99b72468034da13df025bda479bb97Jason Sams 4781030893d9b99b72468034da13df025bda479bb97Jason Sams if (!strcmp(str[ct], "stateRaster")) { 479b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams if (!strcmp(str[ct+1], "default")) { 480b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams continue; 481b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams } 482b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams if (!strcmp(str[ct+1], "parent")) { 483b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams s->mEnviroment.mRaster.clear(); 484b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams continue; 485b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams } 4861030893d9b99b72468034da13df025bda479bb97Jason Sams LOGE("Unreconized value %s passed to stateRaster", str[ct+1]); 4871030893d9b99b72468034da13df025bda479bb97Jason Sams } 4881030893d9b99b72468034da13df025bda479bb97Jason Sams 4891030893d9b99b72468034da13df025bda479bb97Jason Sams if (!strcmp(str[ct], "stateFragment")) { 4908ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams if (!strcmp(str[ct+1], "default")) { 4918ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams continue; 4928ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams } 4938ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams if (!strcmp(str[ct+1], "parent")) { 4948c6bc6930d4996b897de8e5113da4a4efae2310cJason Sams s->mEnviroment.mFragment.clear(); 4958ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams continue; 4968ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams } 4971030893d9b99b72468034da13df025bda479bb97Jason Sams LOGE("Unreconized value %s passed to stateFragment", str[ct+1]); 4981030893d9b99b72468034da13df025bda479bb97Jason Sams } 4991030893d9b99b72468034da13df025bda479bb97Jason Sams 500b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams if (!strcmp(str[ct], "stateStore")) { 5018ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams if (!strcmp(str[ct+1], "default")) { 5028ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams continue; 5038ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams } 5048ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams if (!strcmp(str[ct+1], "parent")) { 5058c6bc6930d4996b897de8e5113da4a4efae2310cJason Sams s->mEnviroment.mFragmentStore.clear(); 5068ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams continue; 5078ce125be69531dbf3a7e856d5e59d1b8e2789db0Jason Sams } 508b681c8af69ef6938c80dd5cc5fc920db94ee9f43Jason Sams LOGE("Unreconized value %s passed to stateStore", str[ct+1]); 5091030893d9b99b72468034da13df025bda479bb97Jason Sams } 5101030893d9b99b72468034da13df025bda479bb97Jason Sams 5111030893d9b99b72468034da13df025bda479bb97Jason Sams } 5121030893d9b99b72468034da13df025bda479bb97Jason Sams 513d34b725ac1752f5a234c7643a0b65245591ea1ccJason Sams 5141030893d9b99b72468034da13df025bda479bb97Jason Sams } else { 5151030893d9b99b72468034da13df025bda479bb97Jason Sams // Deal with an error. 5161030893d9b99b72468034da13df025bda479bb97Jason Sams } 51757b79ceb1126e3797fa42367b97dd7bcfcda1ed9Joe Onorato} 5181030893d9b99b72468034da13df025bda479bb97Jason Sams 519326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace android { 520326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace renderscript { 521326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 522afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid rsi_ScriptCBegin(Context * rsc) { 523326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams ScriptCState *ss = &rsc->mScriptC; 52401b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines ss->clear(rsc); 525326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 526326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 527afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid rsi_ScriptCSetText(Context *rsc, const char *text, uint32_t len) { 5281f52633fefd1862451e6a30209d590680d02beecJason Sams ScriptCState *ss = &rsc->mScriptC; 529e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams 530e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams char *t = (char *)malloc(len + 1); 531e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams memcpy(t, text, len); 532e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams t[len] = 0; 533e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams ss->mScript->mEnviroment.mScriptText = t; 5348c6bc6930d4996b897de8e5113da4a4efae2310cJason Sams ss->mScript->mEnviroment.mScriptTextLength = len; 5351f52633fefd1862451e6a30209d590680d02beecJason Sams} 5361f52633fefd1862451e6a30209d590680d02beecJason Sams 5379503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei LiaoRsScript rsi_ScriptCCreate(Context * rsc, const char *resName) 5389503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao{ 539326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams ScriptCState *ss = &rsc->mScriptC; 540326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 541225afd317e101a7be5fe02c0a86361146ea89f05Jason Sams ObjectBaseRef<ScriptC> s(ss->mScript); 54201b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines ss->mScript.clear(); 543225afd317e101a7be5fe02c0a86361146ea89f05Jason Sams s->incUserRef(); 5441f52633fefd1862451e6a30209d590680d02beecJason Sams 5459503b66e5329703535f7cc71a0755e6f3b1e39a6Shih-wei Liao ss->runCompiler(rsc, s.get(), resName); 54601b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines ss->clear(rsc); 54701b7d2995f9cbd33a9ccdf861fe959743a4b9954Stephen Hines return s.get(); 548326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 549326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 550326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 551326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 552