Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 1 | /* |
Stephen Hines | 4419977 | 2012-02-21 20:13:12 -0800 | [diff] [blame] | 2 | * Copyright (C) 2009-2012 The Android Open Source Project |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | #include "rsContext.h" |
| 18 | #include "rsScriptC.h" |
Jack Palevich | 1ef8b80 | 2009-05-28 15:53:04 -0700 | [diff] [blame] | 19 | |
Jean-Luc Brouillet | f4d216e | 2014-06-09 18:04:16 -0700 | [diff] [blame] | 20 | #if !defined(RS_COMPATIBILITY_LIB) && !defined(ANDROID_RS_SERIALIZE) |
Stephen Hines | cbb0b8a | 2011-08-01 15:02:34 -0700 | [diff] [blame] | 21 | #include <bcinfo/BitcodeTranslator.h> |
Stephen Hines | f8d4469 | 2011-11-22 19:43:58 -0800 | [diff] [blame] | 22 | #include <bcinfo/BitcodeWrapper.h> |
Stephen Hines | cbb0b8a | 2011-08-01 15:02:34 -0700 | [diff] [blame] | 23 | #endif |
| 24 | |
Stephen Hines | b0934b6 | 2013-07-03 17:27:38 -0700 | [diff] [blame] | 25 | #if !defined(RS_SERVER) && !defined(RS_COMPATIBILITY_LIB) |
Tim Murray | 0b575de | 2013-03-15 15:56:43 -0700 | [diff] [blame] | 26 | #include "utils/Timers.h" |
Tobias Grosser | 47935ac | 2013-06-17 11:47:26 -0700 | [diff] [blame] | 27 | #include "cutils/trace.h" |
Stephen Hines | 574854b | 2013-07-10 08:29:51 -0700 | [diff] [blame] | 28 | #endif |
Tobias Grosser | 47935ac | 2013-06-17 11:47:26 -0700 | [diff] [blame] | 29 | |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 30 | #include <sys/stat.h> |
| 31 | |
Yang Ni | b8353c5 | 2015-02-14 18:00:59 -0800 | [diff] [blame] | 32 | #include <string> |
| 33 | |
Chris Wailes | 6847e73 | 2014-08-11 17:30:51 -0700 | [diff] [blame] | 34 | #ifdef USE_MINGW |
| 35 | /* Define the default path separator for the platform. */ |
| 36 | #define OS_PATH_SEPARATOR '\\' |
| 37 | #define OS_PATH_SEPARATOR_STR "\\" |
| 38 | |
| 39 | #else /* not USE_MINGW */ |
| 40 | |
| 41 | /* Define the default path separator for the platform. */ |
| 42 | #define OS_PATH_SEPARATOR '/' |
| 43 | #define OS_PATH_SEPARATOR_STR "/" |
| 44 | |
| 45 | #endif |
| 46 | |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 47 | using namespace android; |
| 48 | using namespace android::renderscript; |
| 49 | |
Jason Sams | e576910 | 2009-06-19 16:03:18 -0700 | [diff] [blame] | 50 | #define GET_TLS() Context::ScriptTLSStruct * tls = \ |
| 51 | (Context::ScriptTLSStruct *)pthread_getspecific(Context::gThreadTLSKey); \ |
| 52 | Context * rsc = tls->mContext; \ |
| 53 | ScriptC * sc = (ScriptC *) tls->mScript |
| 54 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 55 | ScriptC::ScriptC(Context *rsc) : Script(rsc) { |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 56 | } |
| 57 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 58 | ScriptC::~ScriptC() { |
Jason Sams | 77020c5 | 2011-11-22 12:49:11 -0800 | [diff] [blame] | 59 | if (mInitialized) { |
| 60 | mRSC->mHal.funcs.script.invokeFreeChildren(mRSC, this); |
| 61 | mRSC->mHal.funcs.script.destroy(mRSC, this); |
| 62 | } |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 63 | } |
| 64 | |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 65 | #ifndef RS_COMPATIBILITY_LIB |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 66 | bool ScriptC::createCacheDir(const char *cacheDir) { |
Chris Wailes | 6847e73 | 2014-08-11 17:30:51 -0700 | [diff] [blame] | 67 | std::string currentDir; |
| 68 | const std::string cacheDirString(cacheDir); |
| 69 | |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 70 | struct stat statBuf; |
| 71 | int statReturn = stat(cacheDir, &statBuf); |
| 72 | if (!statReturn) { |
| 73 | return true; |
| 74 | } |
| 75 | |
Chris Wailes | 6847e73 | 2014-08-11 17:30:51 -0700 | [diff] [blame] | 76 | // Start from the beginning of the cacheDirString. |
| 77 | int currPos = 0; |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 78 | |
Chris Wailes | 6847e73 | 2014-08-11 17:30:51 -0700 | [diff] [blame] | 79 | // Reserve space in currentDir for the entire cacheDir path. |
| 80 | currentDir.reserve(cacheDirString.length()); |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 81 | |
Chris Wailes | 6847e73 | 2014-08-11 17:30:51 -0700 | [diff] [blame] | 82 | while (currPos >= 0) { |
| 83 | /* |
| 84 | * The character at currPos should be a path separator. We need to look |
| 85 | * for the next one. |
| 86 | */ |
| 87 | int nextPos = cacheDirString.find(OS_PATH_SEPARATOR_STR, currPos + 1); |
| 88 | |
| 89 | if (nextPos > 0) { |
| 90 | // A new path separator has been found. |
| 91 | currentDir += cacheDirString.substr(currPos, nextPos - currPos); |
| 92 | } else { |
| 93 | // There are no more path separators. |
| 94 | currentDir += cacheDirString.substr(currPos); |
| 95 | } |
| 96 | |
| 97 | currPos = nextPos; |
| 98 | |
| 99 | statReturn = stat(currentDir.c_str(), &statBuf); |
| 100 | |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 101 | if (statReturn) { |
| 102 | if (errno == ENOENT) { |
Chris Wailes | 6847e73 | 2014-08-11 17:30:51 -0700 | [diff] [blame] | 103 | if (mkdir(currentDir.c_str(), S_IRUSR | S_IWUSR | S_IXUSR)) { |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 104 | ALOGE("Couldn't create cache directory: %s", |
Chris Wailes | 6847e73 | 2014-08-11 17:30:51 -0700 | [diff] [blame] | 105 | currentDir.c_str()); |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 106 | ALOGE("Error: %s", strerror(errno)); |
| 107 | return false; |
| 108 | } |
| 109 | } else { |
| 110 | ALOGE("Stat error: %s", strerror(errno)); |
| 111 | return false; |
| 112 | } |
| 113 | } |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 114 | } |
| 115 | return true; |
| 116 | } |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 117 | #endif |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 118 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 119 | void ScriptC::setupScript(Context *rsc) { |
Tim Murray | 0b575de | 2013-03-15 15:56:43 -0700 | [diff] [blame] | 120 | #ifndef RS_SERVER |
Jason Sams | c61346b | 2010-05-28 18:23:22 -0700 | [diff] [blame] | 121 | mEnviroment.mStartTimeMillis |
| 122 | = nanoseconds_to_milliseconds(systemTime(SYSTEM_TIME_MONOTONIC)); |
Tim Murray | 0b575de | 2013-03-15 15:56:43 -0700 | [diff] [blame] | 123 | #endif |
Jason Sams | c61346b | 2010-05-28 18:23:22 -0700 | [diff] [blame] | 124 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 125 | for (uint32_t ct=0; ct < mHal.info.exportedVariableCount; ct++) { |
Jason Sams | 900f161 | 2010-09-16 18:18:29 -0700 | [diff] [blame] | 126 | if (mSlots[ct].get() && !mTypes[ct].get()) { |
| 127 | mTypes[ct].set(mSlots[ct]->getType()); |
| 128 | } |
| 129 | |
| 130 | if (!mTypes[ct].get()) |
Jason Sams | be36bf3 | 2010-05-11 14:03:58 -0700 | [diff] [blame] | 131 | continue; |
Jason Sams | 807fdc4 | 2012-07-25 17:55:39 -0700 | [diff] [blame] | 132 | rsc->mHal.funcs.script.setGlobalBind(rsc, this, ct, mSlots[ct].get()); |
Jason Sams | ada7f27 | 2009-09-24 14:55:38 -0700 | [diff] [blame] | 133 | } |
| 134 | } |
| 135 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 136 | void ScriptC::setupGLState(Context *rsc) { |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 137 | #ifndef RS_COMPATIBILITY_LIB |
Jason Sams | a0a1b6f | 2009-06-10 15:04:38 -0700 | [diff] [blame] | 138 | if (mEnviroment.mFragmentStore.get()) { |
Jason Sams | 6070925 | 2010-11-17 15:29:32 -0800 | [diff] [blame] | 139 | rsc->setProgramStore(mEnviroment.mFragmentStore.get()); |
Jason Sams | a0a1b6f | 2009-06-10 15:04:38 -0700 | [diff] [blame] | 140 | } |
| 141 | if (mEnviroment.mFragment.get()) { |
Jason Sams | 6070925 | 2010-11-17 15:29:32 -0800 | [diff] [blame] | 142 | rsc->setProgramFragment(mEnviroment.mFragment.get()); |
Jason Sams | a0a1b6f | 2009-06-10 15:04:38 -0700 | [diff] [blame] | 143 | } |
Jason Sams | 8ce125b | 2009-06-17 16:52:59 -0700 | [diff] [blame] | 144 | if (mEnviroment.mVertex.get()) { |
Jason Sams | 6070925 | 2010-11-17 15:29:32 -0800 | [diff] [blame] | 145 | rsc->setProgramVertex(mEnviroment.mVertex.get()); |
Jason Sams | 8ce125b | 2009-06-17 16:52:59 -0700 | [diff] [blame] | 146 | } |
Jason Sams | b681c8a | 2009-09-28 18:12:56 -0700 | [diff] [blame] | 147 | if (mEnviroment.mRaster.get()) { |
Jason Sams | 6070925 | 2010-11-17 15:29:32 -0800 | [diff] [blame] | 148 | rsc->setProgramRaster(mEnviroment.mRaster.get()); |
Jason Sams | b681c8a | 2009-09-28 18:12:56 -0700 | [diff] [blame] | 149 | } |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 150 | #endif |
Jason Sams | c61346b | 2010-05-28 18:23:22 -0700 | [diff] [blame] | 151 | } |
Jason Sams | a0a1b6f | 2009-06-10 15:04:38 -0700 | [diff] [blame] | 152 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 153 | uint32_t ScriptC::run(Context *rsc) { |
Chris Wailes | 44bef6f | 2014-08-12 13:51:10 -0700 | [diff] [blame] | 154 | if (mHal.info.root == nullptr) { |
Jason Sams | c61346b | 2010-05-28 18:23:22 -0700 | [diff] [blame] | 155 | rsc->setError(RS_ERROR_BAD_SCRIPT, "Attempted to run bad script"); |
| 156 | return 0; |
Joe Onorato | 9c4e4ca | 2009-08-09 11:39:02 -0700 | [diff] [blame] | 157 | } |
Jason Sams | c61346b | 2010-05-28 18:23:22 -0700 | [diff] [blame] | 158 | |
Jason Sams | 1f24db4 | 2010-12-11 17:42:30 -0800 | [diff] [blame] | 159 | setupGLState(rsc); |
Jason Sams | c61346b | 2010-05-28 18:23:22 -0700 | [diff] [blame] | 160 | setupScript(rsc); |
Jason Sams | 1d54f10 | 2009-09-03 15:43:13 -0700 | [diff] [blame] | 161 | |
Jason Sams | 2dca84d | 2009-12-09 11:05:45 -0800 | [diff] [blame] | 162 | uint32_t ret = 0; |
Jason Sams | b9077f4 | 2010-09-22 15:57:41 -0700 | [diff] [blame] | 163 | |
| 164 | if (rsc->props.mLogScripts) { |
Steve Block | 6598201 | 2011-10-20 11:56:00 +0100 | [diff] [blame] | 165 | ALOGV("%p ScriptC::run invoking root, ptr %p", rsc, mHal.info.root); |
Jason Sams | b9077f4 | 2010-09-22 15:57:41 -0700 | [diff] [blame] | 166 | } |
| 167 | |
Jason Sams | cdfdb8f | 2011-03-17 16:12:47 -0700 | [diff] [blame] | 168 | ret = rsc->mHal.funcs.script.invokeRoot(rsc, this); |
Jason Sams | b9077f4 | 2010-09-22 15:57:41 -0700 | [diff] [blame] | 169 | |
| 170 | if (rsc->props.mLogScripts) { |
Steve Block | 6598201 | 2011-10-20 11:56:00 +0100 | [diff] [blame] | 171 | ALOGV("%p ScriptC::run invoking complete, ret=%i", rsc, ret); |
Jason Sams | b9077f4 | 2010-09-22 15:57:41 -0700 | [diff] [blame] | 172 | } |
| 173 | |
Jason Sams | e45ac6e | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 174 | return ret; |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 175 | } |
| 176 | |
Jason Sams | 177f844 | 2010-10-29 10:19:21 -0700 | [diff] [blame] | 177 | |
Jason Sams | ace3e01 | 2010-07-15 17:11:13 -0700 | [diff] [blame] | 178 | void ScriptC::runForEach(Context *rsc, |
Stephen Hines | 4419977 | 2012-02-21 20:13:12 -0800 | [diff] [blame] | 179 | uint32_t slot, |
Chris Wailes | 4b3c34e | 2014-06-11 12:00:29 -0700 | [diff] [blame] | 180 | const Allocation ** ains, |
| 181 | size_t inLen, |
| 182 | Allocation * aout, |
| 183 | const void * usr, |
| 184 | size_t usrBytes, |
| 185 | const RsScriptCall *sc) { |
Pirama Arumuga Nainar | 9479e5b | 2015-04-28 14:40:45 -0700 | [diff] [blame] | 186 | // Make a copy of RsScriptCall and zero out extra fields that are absent |
| 187 | // in API levels below 23. |
| 188 | RsScriptCall sc_copy; |
| 189 | if (sc != nullptr && getApiLevel() < 23) { |
| 190 | memset(&sc_copy, 0, sizeof(sc_copy)); |
| 191 | memcpy(&sc_copy, sc, 7*4); |
| 192 | sc = &sc_copy; |
| 193 | } |
| 194 | |
Matt Wala | 14ce007 | 2015-07-30 17:30:25 -0700 | [diff] [blame] | 195 | if (slot >= mHal.info.exportedForEachCount) { |
| 196 | rsc->setError(RS_ERROR_BAD_SCRIPT, |
| 197 | "The forEach kernel index is out of bounds"); |
| 198 | return; |
| 199 | } |
| 200 | |
Chris Wailes | 4b3c34e | 2014-06-11 12:00:29 -0700 | [diff] [blame] | 201 | // Trace this function call. |
| 202 | // To avoid overhead we only build the string if tracing is actually |
| 203 | // enabled. |
Yang Ni | b8353c5 | 2015-02-14 18:00:59 -0800 | [diff] [blame] | 204 | String8 *AString = NULL; |
| 205 | const char *String = ""; |
Chris Wailes | 4b3c34e | 2014-06-11 12:00:29 -0700 | [diff] [blame] | 206 | if (ATRACE_ENABLED()) { |
Yang Ni | b8353c5 | 2015-02-14 18:00:59 -0800 | [diff] [blame] | 207 | AString = new String8("runForEach_"); |
| 208 | AString->append(mHal.info.exportedForeachFuncList[slot].first); |
| 209 | String = AString->string(); |
Chris Wailes | 4b3c34e | 2014-06-11 12:00:29 -0700 | [diff] [blame] | 210 | } |
Yang Ni | b8353c5 | 2015-02-14 18:00:59 -0800 | [diff] [blame] | 211 | ATRACE_NAME(String); |
| 212 | (void)String; |
Jason Sams | 4efe3d3 | 2015-03-18 18:28:06 -0700 | [diff] [blame] | 213 | if (mRSC->hadFatalError()) return; |
Chris Wailes | 4b3c34e | 2014-06-11 12:00:29 -0700 | [diff] [blame] | 214 | |
| 215 | Context::PushState ps(rsc); |
| 216 | |
| 217 | setupGLState(rsc); |
| 218 | setupScript(rsc); |
| 219 | |
Matt Wala | 14ce007 | 2015-07-30 17:30:25 -0700 | [diff] [blame] | 220 | if (rsc->props.mLogScripts) { |
| 221 | ALOGV("%p ScriptC::runForEach invoking slot %i, ptr %p", rsc, slot, this); |
| 222 | } |
| 223 | |
Chris Wailes | 44bef6f | 2014-08-12 13:51:10 -0700 | [diff] [blame] | 224 | if (rsc->mHal.funcs.script.invokeForEachMulti != nullptr) { |
Chris Wailes | f371213 | 2014-07-16 15:18:30 -0700 | [diff] [blame] | 225 | rsc->mHal.funcs.script.invokeForEachMulti(rsc, this, slot, ains, inLen, |
| 226 | aout, usr, usrBytes, sc); |
Chris Wailes | 4b3c34e | 2014-06-11 12:00:29 -0700 | [diff] [blame] | 227 | |
Chris Wailes | f371213 | 2014-07-16 15:18:30 -0700 | [diff] [blame] | 228 | } else if (inLen == 1) { |
| 229 | rsc->mHal.funcs.script.invokeForEach(rsc, this, slot, ains[0], aout, |
| 230 | usr, usrBytes, sc); |
| 231 | |
| 232 | } else { |
| 233 | rsc->setError(RS_ERROR_FATAL_DRIVER, |
| 234 | "Driver support for multi-input not present"); |
| 235 | } |
| 236 | |
Yang Ni | b8353c5 | 2015-02-14 18:00:59 -0800 | [diff] [blame] | 237 | if (AString) { |
| 238 | delete AString; |
Chris Wailes | f371213 | 2014-07-16 15:18:30 -0700 | [diff] [blame] | 239 | } |
Chris Wailes | 4b3c34e | 2014-06-11 12:00:29 -0700 | [diff] [blame] | 240 | } |
| 241 | |
Matt Wala | 14ce007 | 2015-07-30 17:30:25 -0700 | [diff] [blame] | 242 | void ScriptC::runReduce(Context *rsc, uint32_t slot, const Allocation *ain, |
| 243 | Allocation *aout, const RsScriptCall *sc) { |
| 244 | // TODO: Record the name of the kernel in the tracing information. |
| 245 | ATRACE_CALL(); |
| 246 | |
| 247 | if (slot >= mHal.info.exportedReduceCount) { |
David Gross | 6c1876b | 2016-01-15 11:52:14 -0800 | [diff] [blame^] | 248 | rsc->setError(RS_ERROR_BAD_SCRIPT, "The simple reduce kernel index is out of bounds"); |
Matt Wala | 14ce007 | 2015-07-30 17:30:25 -0700 | [diff] [blame] | 249 | return; |
| 250 | } |
| 251 | if (mRSC->hadFatalError()) return; |
| 252 | |
| 253 | setupScript(rsc); |
| 254 | |
| 255 | if (rsc->props.mLogScripts) { |
| 256 | ALOGV("%p ScriptC::runReduce invoking slot %i, ptr %p", rsc, slot, this); |
| 257 | } |
| 258 | |
| 259 | rsc->mHal.funcs.script.invokeReduce(rsc, this, slot, ain, aout, sc); |
| 260 | } |
| 261 | |
David Gross | 6c1876b | 2016-01-15 11:52:14 -0800 | [diff] [blame^] | 262 | void ScriptC::runReduceNew(Context *rsc, uint32_t slot, |
| 263 | const Allocation ** ains, size_t inLen, |
| 264 | Allocation *aout, const RsScriptCall *sc) { |
| 265 | // TODO: Record the name of the kernel in the tracing information. |
| 266 | ATRACE_CALL(); |
| 267 | |
| 268 | if (slot >= mHal.info.exportedReduceNewCount) { |
| 269 | rsc->setError(RS_ERROR_BAD_SCRIPT, "The general reduce kernel index is out of bounds"); |
| 270 | return; |
| 271 | } |
| 272 | if (mRSC->hadFatalError()) return; |
| 273 | |
| 274 | setupScript(rsc); |
| 275 | |
| 276 | if (rsc->props.mLogScripts) { |
| 277 | ALOGV("%p ScriptC::runReduceNew invoking slot %i, ptr %p", rsc, slot, this); |
| 278 | } |
| 279 | |
| 280 | rsc->mHal.funcs.script.invokeReduceNew(rsc, this, slot, ains, inLen, aout, sc); |
| 281 | } |
| 282 | |
Alex Sakhartchouk | b81a0eb | 2011-06-03 10:18:01 -0700 | [diff] [blame] | 283 | void ScriptC::Invoke(Context *rsc, uint32_t slot, const void *data, size_t len) { |
Tim Murray | fa85e91 | 2013-05-23 13:19:36 -0700 | [diff] [blame] | 284 | ATRACE_CALL(); |
| 285 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 286 | if (slot >= mHal.info.exportedFunctionCount) { |
Matt Wala | 14ce007 | 2015-07-30 17:30:25 -0700 | [diff] [blame] | 287 | rsc->setError(RS_ERROR_BAD_SCRIPT, "The invokable index is out of bounds"); |
Jason Sams | 22fa371 | 2010-05-19 17:22:57 -0700 | [diff] [blame] | 288 | return; |
| 289 | } |
Jason Sams | 4efe3d3 | 2015-03-18 18:28:06 -0700 | [diff] [blame] | 290 | if (mRSC->hadFatalError()) return; |
| 291 | |
Jason Sams | c61346b | 2010-05-28 18:23:22 -0700 | [diff] [blame] | 292 | setupScript(rsc); |
Jason Sams | 22fa371 | 2010-05-19 17:22:57 -0700 | [diff] [blame] | 293 | |
Jason Sams | b9077f4 | 2010-09-22 15:57:41 -0700 | [diff] [blame] | 294 | if (rsc->props.mLogScripts) { |
Steve Block | 6598201 | 2011-10-20 11:56:00 +0100 | [diff] [blame] | 295 | ALOGV("%p ScriptC::Invoke invoking slot %i, ptr %p", rsc, slot, this); |
Jason Sams | b9077f4 | 2010-09-22 15:57:41 -0700 | [diff] [blame] | 296 | } |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 297 | rsc->mHal.funcs.script.invokeFunction(rsc, this, slot, data, len); |
Jason Sams | 22fa371 | 2010-05-19 17:22:57 -0700 | [diff] [blame] | 298 | } |
| 299 | |
Stephen Hines | f6af3bd | 2014-12-23 17:47:43 -0800 | [diff] [blame] | 300 | static const bool kDebugBitcode = false; |
| 301 | |
| 302 | #ifndef RS_COMPATIBILITY_LIB |
| 303 | #ifndef ANDROID_RS_SERIALIZE |
| 304 | |
| 305 | static bool dumpBitcodeFile(const char *cacheDir, const char *resName, |
| 306 | const char *suffix, const uint8_t *bitcode, |
| 307 | size_t bitcodeLen) { |
| 308 | std::string f(cacheDir); |
| 309 | f.append("/"); |
| 310 | f.append(resName); |
| 311 | f.append("#"); |
| 312 | f.append(suffix); |
| 313 | f.append(".bc"); |
| 314 | |
| 315 | if (!ScriptC::createCacheDir(cacheDir)) { |
| 316 | return false; |
| 317 | } |
| 318 | |
| 319 | FILE *fp = fopen(f.c_str(), "w"); |
| 320 | if (!fp) { |
| 321 | ALOGE("Could not open %s", f.c_str()); |
| 322 | return false; |
| 323 | } |
| 324 | |
| 325 | size_t nWritten = fwrite(bitcode, 1, bitcodeLen, fp); |
| 326 | fclose(fp); |
| 327 | if (nWritten != bitcodeLen) { |
| 328 | ALOGE("Could not write %s", f.c_str()); |
| 329 | return false; |
| 330 | } |
| 331 | return true; |
| 332 | } |
| 333 | |
| 334 | #endif // !ANDROID_RS_SERIALIZE |
| 335 | #endif // !RS_COMPATIBILITY_LIB |
| 336 | |
| 337 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 338 | bool ScriptC::runCompiler(Context *rsc, |
| 339 | const char *resName, |
| 340 | const char *cacheDir, |
| 341 | const uint8_t *bitcode, |
| 342 | size_t bitcodeLen) { |
Tim Murray | fa85e91 | 2013-05-23 13:19:36 -0700 | [diff] [blame] | 343 | ATRACE_CALL(); |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 344 | //ALOGE("runCompiler %p %p %p %p %p %i", rsc, this, resName, cacheDir, bitcode, bitcodeLen); |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 345 | #ifndef RS_COMPATIBILITY_LIB |
Stephen Hines | cbb0b8a | 2011-08-01 15:02:34 -0700 | [diff] [blame] | 346 | #ifndef ANDROID_RS_SERIALIZE |
Stephen Hines | f8d4469 | 2011-11-22 19:43:58 -0800 | [diff] [blame] | 347 | uint32_t sdkVersion = 0; |
| 348 | bcinfo::BitcodeWrapper bcWrapper((const char *)bitcode, bitcodeLen); |
| 349 | if (!bcWrapper.unwrap()) { |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 350 | ALOGE("Bitcode is not in proper container format (raw or wrapper)"); |
Stephen Hines | f8d4469 | 2011-11-22 19:43:58 -0800 | [diff] [blame] | 351 | return false; |
| 352 | } |
| 353 | |
Stephen Hines | f8d4469 | 2011-11-22 19:43:58 -0800 | [diff] [blame] | 354 | if (bcWrapper.getBCFileType() == bcinfo::BC_WRAPPER) { |
| 355 | sdkVersion = bcWrapper.getTargetAPI(); |
| 356 | } |
| 357 | |
| 358 | if (sdkVersion == 0) { |
| 359 | // This signals that we didn't have a wrapper containing information |
| 360 | // about the bitcode. |
| 361 | sdkVersion = rsc->getTargetSdkVersion(); |
| 362 | } |
| 363 | |
Stephen Hines | 5d95a78 | 2015-04-13 20:11:48 -0700 | [diff] [blame] | 364 | // Save off the sdkVersion, so that we can handle broken cases later. |
| 365 | // Bug 19734267 |
| 366 | mApiLevel = sdkVersion; |
| 367 | |
Stephen Hines | 98f401d | 2015-12-03 00:44:46 -0800 | [diff] [blame] | 368 | bcinfo::BitcodeTranslator BT((const char *)bitcode, bitcodeLen, |
| 369 | sdkVersion); |
| 370 | if (!BT.translate()) { |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 371 | ALOGE("Failed to translate bitcode from version: %u", sdkVersion); |
Stephen Hines | cbb0b8a | 2011-08-01 15:02:34 -0700 | [diff] [blame] | 372 | return false; |
| 373 | } |
Stephen Hines | 98f401d | 2015-12-03 00:44:46 -0800 | [diff] [blame] | 374 | bitcode = (const uint8_t *) BT.getTranslatedBitcode(); |
| 375 | bitcodeLen = BT.getTranslatedBitcodeSize(); |
Shih-wei Liao | 37150de | 2011-01-07 18:17:07 -0800 | [diff] [blame] | 376 | |
Stephen Hines | f6af3bd | 2014-12-23 17:47:43 -0800 | [diff] [blame] | 377 | if (kDebugBitcode) { |
| 378 | if (!dumpBitcodeFile(cacheDir, resName, "after", bitcode, bitcodeLen)) { |
| 379 | return false; |
| 380 | } |
| 381 | } |
| 382 | |
Tim Murray | e195a3f | 2014-03-13 15:04:58 -0700 | [diff] [blame] | 383 | #endif |
Tim Murray | 84bf2b8 | 2012-10-31 16:03:16 -0700 | [diff] [blame] | 384 | if (!cacheDir) { |
| 385 | // MUST BE FIXED BEFORE ANYTHING USING C++ API IS RELEASED |
| 386 | cacheDir = getenv("EXTERNAL_STORAGE"); |
| 387 | ALOGV("Cache dir changed to %s", cacheDir); |
| 388 | } |
| 389 | |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 390 | // ensure that cache dir exists |
Tim Murray | 84bf2b8 | 2012-10-31 16:03:16 -0700 | [diff] [blame] | 391 | if (cacheDir && !createCacheDir(cacheDir)) { |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 392 | return false; |
| 393 | } |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 394 | #endif |
Tim Murray | e78c14b | 2012-10-01 15:27:18 -0700 | [diff] [blame] | 395 | |
Jason Sams | 77020c5 | 2011-11-22 12:49:11 -0800 | [diff] [blame] | 396 | if (!rsc->mHal.funcs.script.init(rsc, this, resName, cacheDir, bitcode, bitcodeLen, 0)) { |
| 397 | return false; |
| 398 | } |
Shih-wei Liao | 37150de | 2011-01-07 18:17:07 -0800 | [diff] [blame] | 399 | |
Jason Sams | 77020c5 | 2011-11-22 12:49:11 -0800 | [diff] [blame] | 400 | mInitialized = true; |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 401 | #ifndef RS_COMPATIBILITY_LIB |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 402 | mEnviroment.mFragment.set(rsc->getDefaultProgramFragment()); |
| 403 | mEnviroment.mVertex.set(rsc->getDefaultProgramVertex()); |
| 404 | mEnviroment.mFragmentStore.set(rsc->getDefaultProgramStore()); |
| 405 | mEnviroment.mRaster.set(rsc->getDefaultProgramRaster()); |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 406 | #endif |
Shih-wei Liao | 37150de | 2011-01-07 18:17:07 -0800 | [diff] [blame] | 407 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 408 | rsc->mHal.funcs.script.invokeInit(rsc, this); |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 409 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 410 | for (size_t i=0; i < mHal.info.exportedPragmaCount; ++i) { |
| 411 | const char * key = mHal.info.exportedPragmaKeyList[i]; |
| 412 | const char * value = mHal.info.exportedPragmaValueList[i]; |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 413 | //ALOGE("pragma %s %s", keys[i], values[i]); |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 414 | if (!strcmp(key, "version")) { |
| 415 | if (!strcmp(value, "1")) { |
Stephen Hines | b5dc6af | 2011-01-18 14:10:44 -0800 | [diff] [blame] | 416 | continue; |
| 417 | } |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 418 | ALOGE("Invalid version pragma value: %s\n", value); |
Jason Sams | 26b2c9f | 2011-01-19 16:14:21 -0800 | [diff] [blame] | 419 | return false; |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 420 | } |
| 421 | |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 422 | #ifndef RS_COMPATIBILITY_LIB |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 423 | if (!strcmp(key, "stateVertex")) { |
| 424 | if (!strcmp(value, "default")) { |
Jason Sams | 1030893 | 2009-06-09 12:15:30 -0700 | [diff] [blame] | 425 | continue; |
Jason Sams | 1030893 | 2009-06-09 12:15:30 -0700 | [diff] [blame] | 426 | } |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 427 | if (!strcmp(value, "parent")) { |
| 428 | mEnviroment.mVertex.clear(); |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 429 | continue; |
Jason Sams | 1030893 | 2009-06-09 12:15:30 -0700 | [diff] [blame] | 430 | } |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 431 | ALOGE("Unrecognized value %s passed to stateVertex", value); |
Jason Sams | 26b2c9f | 2011-01-19 16:14:21 -0800 | [diff] [blame] | 432 | return false; |
Jason Sams | 1030893 | 2009-06-09 12:15:30 -0700 | [diff] [blame] | 433 | } |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 434 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 435 | if (!strcmp(key, "stateRaster")) { |
| 436 | if (!strcmp(value, "default")) { |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 437 | continue; |
| 438 | } |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 439 | if (!strcmp(value, "parent")) { |
| 440 | mEnviroment.mRaster.clear(); |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 441 | continue; |
| 442 | } |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 443 | ALOGE("Unrecognized value %s passed to stateRaster", value); |
Jason Sams | 26b2c9f | 2011-01-19 16:14:21 -0800 | [diff] [blame] | 444 | return false; |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 445 | } |
| 446 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 447 | if (!strcmp(key, "stateFragment")) { |
| 448 | if (!strcmp(value, "default")) { |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 449 | continue; |
| 450 | } |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 451 | if (!strcmp(value, "parent")) { |
| 452 | mEnviroment.mFragment.clear(); |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 453 | continue; |
| 454 | } |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 455 | ALOGE("Unrecognized value %s passed to stateFragment", value); |
Jason Sams | 26b2c9f | 2011-01-19 16:14:21 -0800 | [diff] [blame] | 456 | return false; |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 457 | } |
| 458 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 459 | if (!strcmp(key, "stateStore")) { |
| 460 | if (!strcmp(value, "default")) { |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 461 | continue; |
| 462 | } |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 463 | if (!strcmp(value, "parent")) { |
| 464 | mEnviroment.mFragmentStore.clear(); |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 465 | continue; |
| 466 | } |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 467 | ALOGE("Unrecognized value %s passed to stateStore", value); |
Jason Sams | 26b2c9f | 2011-01-19 16:14:21 -0800 | [diff] [blame] | 468 | return false; |
Stephen Hines | 7b337b1 | 2011-01-17 17:31:58 -0800 | [diff] [blame] | 469 | } |
Jason Sams | 93eacc7 | 2012-12-18 14:26:57 -0800 | [diff] [blame] | 470 | #endif |
| 471 | |
Jason Sams | 1030893 | 2009-06-09 12:15:30 -0700 | [diff] [blame] | 472 | } |
Jason Sams | 2e8665d | 2011-01-27 00:14:13 -0800 | [diff] [blame] | 473 | |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 474 | mSlots = new ObjectBaseRef<Allocation>[mHal.info.exportedVariableCount]; |
| 475 | mTypes = new ObjectBaseRef<const Type>[mHal.info.exportedVariableCount]; |
Jason Sams | 2e8665d | 2011-01-27 00:14:13 -0800 | [diff] [blame] | 476 | |
Jason Sams | 26b2c9f | 2011-01-19 16:14:21 -0800 | [diff] [blame] | 477 | return true; |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 478 | } |
| 479 | |
| 480 | namespace android { |
| 481 | namespace renderscript { |
| 482 | |
Shih-wei Liao | ce8a079 | 2010-12-20 20:45:56 +0800 | [diff] [blame] | 483 | RsScript rsi_ScriptCCreate(Context *rsc, |
Alex Sakhartchouk | 70b83c1 | 2011-04-06 10:57:51 -0700 | [diff] [blame] | 484 | const char *resName, size_t resName_length, |
| 485 | const char *cacheDir, size_t cacheDir_length, |
Alex Sakhartchouk | b81a0eb | 2011-06-03 10:18:01 -0700 | [diff] [blame] | 486 | const char *text, size_t text_length) |
Shih-wei Liao | 9503b66 | 2010-11-08 01:33:59 -0800 | [diff] [blame] | 487 | { |
Jason Sams | 249d453 | 2011-01-23 17:48:45 -0800 | [diff] [blame] | 488 | ScriptC *s = new ScriptC(rsc); |
Jason Sams | 1f52633 | 2009-06-05 17:35:09 -0700 | [diff] [blame] | 489 | |
Alex Sakhartchouk | 70b83c1 | 2011-04-06 10:57:51 -0700 | [diff] [blame] | 490 | if (!s->runCompiler(rsc, resName, cacheDir, (uint8_t *)text, text_length)) { |
Jason Sams | 26b2c9f | 2011-01-19 16:14:21 -0800 | [diff] [blame] | 491 | // Error during compile, destroy s and return null. |
Stephen Hines | 4769d68 | 2012-02-02 13:23:20 -0800 | [diff] [blame] | 492 | ObjectBase::checkDelete(s); |
Chris Wailes | 44bef6f | 2014-08-12 13:51:10 -0700 | [diff] [blame] | 493 | return nullptr; |
Jason Sams | 26b2c9f | 2011-01-19 16:14:21 -0800 | [diff] [blame] | 494 | } |
Jason Sams | bad8074 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 495 | |
| 496 | s->incUserRef(); |
Jason Sams | 249d453 | 2011-01-23 17:48:45 -0800 | [diff] [blame] | 497 | return s; |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 498 | } |
| 499 | |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 500 | } |
| 501 | } |