Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 1 | /* |
Stephen Hines | 473a204 | 2012-02-21 20:13:12 -0800 | [diff] [blame] | 2 | * Copyright (C) 2009-2012 The Android Open Source Project |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -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" |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 19 | #include "rsMatrix4x4.h" |
| 20 | #include "rsMatrix3x3.h" |
| 21 | #include "rsMatrix2x2.h" |
Alex Sakhartchouk | bedc023 | 2012-03-09 10:47:27 -0800 | [diff] [blame^] | 22 | #include "rsgApiStructs.h" |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 23 | |
Joe Onorato | 3370ec9 | 2009-08-09 11:39:02 -0700 | [diff] [blame] | 24 | #include "utils/Timers.h" |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 25 | |
Romain Guy | 584a375 | 2009-07-30 18:45:01 -0700 | [diff] [blame] | 26 | #include <time.h> |
Romain Guy | 584a375 | 2009-07-30 18:45:01 -0700 | [diff] [blame] | 27 | |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 28 | using namespace android; |
| 29 | using namespace android::renderscript; |
| 30 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 31 | |
| 32 | namespace android { |
| 33 | namespace renderscript { |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 34 | |
Jason Sams | 4d33993 | 2010-05-11 14:03:58 -0700 | [diff] [blame] | 35 | |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 36 | ////////////////////////////////////////////////////////////////////////////// |
| 37 | // Math routines |
| 38 | ////////////////////////////////////////////////////////////////////////////// |
| 39 | |
Stephen Hines | 1bf1f8d | 2011-03-01 17:34:59 -0800 | [diff] [blame] | 40 | #if 0 |
Alex Sakhartchouk | ed9f210 | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 41 | static float SC_sinf_fast(float x) { |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 42 | const float A = 1.0f / (2.0f * M_PI); |
| 43 | const float B = -16.0f; |
| 44 | const float C = 8.0f; |
Jason Sams | ea84a7c | 2009-09-04 14:42:41 -0700 | [diff] [blame] | 45 | |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 46 | // scale angle for easy argument reduction |
| 47 | x *= A; |
Jason Sams | ea84a7c | 2009-09-04 14:42:41 -0700 | [diff] [blame] | 48 | |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 49 | if (fabsf(x) >= 0.5f) { |
| 50 | // argument reduction |
| 51 | x = x - ceilf(x + 0.5f) + 1.0f; |
| 52 | } |
Jason Sams | ea84a7c | 2009-09-04 14:42:41 -0700 | [diff] [blame] | 53 | |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 54 | const float y = B * x * fabsf(x) + C * x; |
| 55 | return 0.2215f * (y * fabsf(y) - y) + y; |
| 56 | } |
| 57 | |
Alex Sakhartchouk | ed9f210 | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 58 | static float SC_cosf_fast(float x) { |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 59 | x += float(M_PI / 2); |
| 60 | |
| 61 | const float A = 1.0f / (2.0f * M_PI); |
| 62 | const float B = -16.0f; |
| 63 | const float C = 8.0f; |
Jason Sams | ea84a7c | 2009-09-04 14:42:41 -0700 | [diff] [blame] | 64 | |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 65 | // scale angle for easy argument reduction |
| 66 | x *= A; |
Jason Sams | ea84a7c | 2009-09-04 14:42:41 -0700 | [diff] [blame] | 67 | |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 68 | if (fabsf(x) >= 0.5f) { |
| 69 | // argument reduction |
| 70 | x = x - ceilf(x + 0.5f) + 1.0f; |
| 71 | } |
Jason Sams | ea84a7c | 2009-09-04 14:42:41 -0700 | [diff] [blame] | 72 | |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 73 | const float y = B * x * fabsf(x) + C * x; |
| 74 | return 0.2215f * (y * fabsf(y) - y) + y; |
| 75 | } |
Stephen Hines | 1bf1f8d | 2011-03-01 17:34:59 -0800 | [diff] [blame] | 76 | #endif |
Romain Guy | cac80a6 | 2009-08-18 11:39:17 -0700 | [diff] [blame] | 77 | |
Romain Guy | 584a375 | 2009-07-30 18:45:01 -0700 | [diff] [blame] | 78 | ////////////////////////////////////////////////////////////////////////////// |
| 79 | // Time routines |
| 80 | ////////////////////////////////////////////////////////////////////////////// |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 81 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 82 | time_t rsrTime(Context *rsc, Script *sc, time_t *timer) { |
Stephen Hines | 1ac9da6 | 2011-01-07 15:11:30 -0800 | [diff] [blame] | 83 | return time(timer); |
Romain Guy | 584a375 | 2009-07-30 18:45:01 -0700 | [diff] [blame] | 84 | } |
| 85 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 86 | tm* rsrLocalTime(Context *rsc, Script *sc, tm *local, time_t *timer) { |
Stephen Hines | 1ac9da6 | 2011-01-07 15:11:30 -0800 | [diff] [blame] | 87 | if (!local) { |
| 88 | return NULL; |
| 89 | } |
Jason Sams | 1bada8c | 2009-08-09 17:01:55 -0700 | [diff] [blame] | 90 | |
Stephen Hines | 1ac9da6 | 2011-01-07 15:11:30 -0800 | [diff] [blame] | 91 | // The native localtime function is not thread-safe, so we |
| 92 | // have to apply locking for proper behavior in RenderScript. |
| 93 | pthread_mutex_lock(&rsc->gLibMutex); |
| 94 | tm *tmp = localtime(timer); |
| 95 | memcpy(local, tmp, sizeof(*tmp)); |
| 96 | pthread_mutex_unlock(&rsc->gLibMutex); |
| 97 | return local; |
Romain Guy | 8839ca5 | 2009-07-31 11:20:59 -0700 | [diff] [blame] | 98 | } |
| 99 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 100 | int64_t rsrUptimeMillis(Context *rsc, Script *sc) { |
Jason Sams | d79b2e9 | 2010-05-19 17:22:57 -0700 | [diff] [blame] | 101 | return nanoseconds_to_milliseconds(systemTime(SYSTEM_TIME_MONOTONIC)); |
| 102 | } |
| 103 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 104 | int64_t rsrUptimeNanos(Context *rsc, Script *sc) { |
Jason Sams | f0690c4 | 2010-07-29 17:31:14 -0700 | [diff] [blame] | 105 | return systemTime(SYSTEM_TIME_MONOTONIC); |
Jason Sams | d79b2e9 | 2010-05-19 17:22:57 -0700 | [diff] [blame] | 106 | } |
| 107 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 108 | float rsrGetDt(Context *rsc, Script *sc) { |
Jason Sams | 1796651 | 2010-07-28 11:17:53 -0700 | [diff] [blame] | 109 | int64_t l = sc->mEnviroment.mLastDtTime; |
| 110 | sc->mEnviroment.mLastDtTime = systemTime(SYSTEM_TIME_MONOTONIC); |
| 111 | return ((float)(sc->mEnviroment.mLastDtTime - l)) / 1.0e9; |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 112 | } |
| 113 | |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 114 | ////////////////////////////////////////////////////////////////////////////// |
| 115 | // |
| 116 | ////////////////////////////////////////////////////////////////////////////// |
| 117 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 118 | void rsrSetObject(const Context *rsc, const Script *sc, ObjectBase **dst, ObjectBase * src) { |
Steve Block | 3762c31 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 119 | //ALOGE("rsiSetObject %p,%p %p", vdst, *vdst, vsrc); |
Jason Sams | e4a06c5 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 120 | if (src) { |
| 121 | CHECK_OBJ(src); |
| 122 | src->incSysRef(); |
Jason Sams | 4fd8bb4 | 2010-09-17 13:17:17 -0700 | [diff] [blame] | 123 | } |
Jason Sams | e4a06c5 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 124 | if (dst[0]) { |
| 125 | CHECK_OBJ(dst[0]); |
| 126 | dst[0]->decSysRef(); |
Jason Sams | 4fd8bb4 | 2010-09-17 13:17:17 -0700 | [diff] [blame] | 127 | } |
Jason Sams | e4a06c5 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 128 | *dst = src; |
Jason Sams | 02f62aa | 2010-08-16 12:41:48 -0700 | [diff] [blame] | 129 | } |
Alex Sakhartchouk | ed9f210 | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 130 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 131 | void rsrClearObject(const Context *rsc, const Script *sc, ObjectBase **dst) { |
Steve Block | 3762c31 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 132 | //ALOGE("rsiClearObject %p,%p", vdst, *vdst); |
Jason Sams | e4a06c5 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 133 | if (dst[0]) { |
| 134 | CHECK_OBJ(dst[0]); |
| 135 | dst[0]->decSysRef(); |
Jason Sams | 4fd8bb4 | 2010-09-17 13:17:17 -0700 | [diff] [blame] | 136 | } |
Jason Sams | e4a06c5 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 137 | *dst = NULL; |
Jason Sams | 02f62aa | 2010-08-16 12:41:48 -0700 | [diff] [blame] | 138 | } |
Alex Sakhartchouk | ed9f210 | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 139 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 140 | bool rsrIsObject(const Context *rsc, const Script *sc, const ObjectBase *src) { |
Jason Sams | e4a06c5 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 141 | return src != NULL; |
Jason Sams | 02f62aa | 2010-08-16 12:41:48 -0700 | [diff] [blame] | 142 | } |
| 143 | |
Jason Sams | d64188a | 2010-08-06 16:22:50 -0700 | [diff] [blame] | 144 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 145 | uint32_t rsrToClient(Context *rsc, Script *sc, int cmdID, void *data, int len) { |
Steve Block | 3762c31 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 146 | //ALOGE("SC_toClient %i %i %i", cmdID, len); |
Jason Sams | 1c41517 | 2010-11-08 17:06:46 -0800 | [diff] [blame] | 147 | return rsc->sendMessageToClient(data, RS_MESSAGE_TO_CLIENT_USER, cmdID, len, false); |
Jason Sams | 516c319 | 2009-10-06 13:58:47 -0700 | [diff] [blame] | 148 | } |
| 149 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 150 | uint32_t rsrToClientBlocking(Context *rsc, Script *sc, int cmdID, void *data, int len) { |
Steve Block | 3762c31 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 151 | //ALOGE("SC_toClientBlocking %i %i", cmdID, len); |
Jason Sams | 1c41517 | 2010-11-08 17:06:46 -0800 | [diff] [blame] | 152 | return rsc->sendMessageToClient(data, RS_MESSAGE_TO_CLIENT_USER, cmdID, len, true); |
Jason Sams | 1796651 | 2010-07-28 11:17:53 -0700 | [diff] [blame] | 153 | } |
| 154 | |
Jason Sams | bd2197f | 2009-10-07 18:14:01 -0700 | [diff] [blame] | 155 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 156 | void rsrForEach(Context *rsc, Script *sc, |
| 157 | Script *target, |
| 158 | Allocation *in, Allocation *out, |
| 159 | const void *usr, uint32_t usrBytes, |
Alex Sakhartchouk | ed9f210 | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 160 | const RsScriptCall *call) { |
Stephen Hines | 473a204 | 2012-02-21 20:13:12 -0800 | [diff] [blame] | 161 | target->runForEach(rsc, /* root slot */ 0, in, out, usr, usrBytes, call); |
Jason Sams | f17bccc | 2010-05-28 18:23:22 -0700 | [diff] [blame] | 162 | } |
| 163 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 164 | void rsrAllocationSyncAll(Context *rsc, Script *sc, Allocation *a, RsAllocationUsageType usage) { |
| 165 | a->syncAll(rsc, usage); |
Jason Sams | 1afbf54 | 2011-01-25 21:33:44 -0800 | [diff] [blame] | 166 | } |
| 167 | |
Alex Sakhartchouk | 304b1f5 | 2011-06-14 11:13:19 -0700 | [diff] [blame] | 168 | void rsrAllocationCopy1DRange(Context *rsc, Allocation *dstAlloc, |
| 169 | uint32_t dstOff, |
| 170 | uint32_t dstMip, |
| 171 | uint32_t count, |
| 172 | Allocation *srcAlloc, |
| 173 | uint32_t srcOff, uint32_t srcMip) { |
| 174 | rsi_AllocationCopy2DRange(rsc, dstAlloc, dstOff, 0, |
| 175 | dstMip, 0, count, 1, |
| 176 | srcAlloc, srcOff, 0, srcMip, 0); |
| 177 | } |
| 178 | |
| 179 | void rsrAllocationCopy2DRange(Context *rsc, Allocation *dstAlloc, |
| 180 | uint32_t dstXoff, uint32_t dstYoff, |
| 181 | uint32_t dstMip, uint32_t dstFace, |
| 182 | uint32_t width, uint32_t height, |
| 183 | Allocation *srcAlloc, |
| 184 | uint32_t srcXoff, uint32_t srcYoff, |
| 185 | uint32_t srcMip, uint32_t srcFace) { |
| 186 | rsi_AllocationCopy2DRange(rsc, dstAlloc, dstXoff, dstYoff, |
| 187 | dstMip, dstFace, width, height, |
| 188 | srcAlloc, srcXoff, srcYoff, srcMip, srcFace); |
| 189 | } |
| 190 | |
Jason Sams | fcf7231 | 2011-04-20 15:09:01 -0700 | [diff] [blame] | 191 | const Allocation * rsrGetAllocation(Context *rsc, Script *s, const void *ptr) { |
| 192 | ScriptC *sc = (ScriptC *)s; |
| 193 | return sc->ptrToAllocation(ptr); |
Jason Sams | 1afbf54 | 2011-01-25 21:33:44 -0800 | [diff] [blame] | 194 | } |
| 195 | |
Jason Sams | 1afbf54 | 2011-01-25 21:33:44 -0800 | [diff] [blame] | 196 | } |
Jason Sams | c97bb88 | 2009-07-20 14:31:06 -0700 | [diff] [blame] | 197 | } |
Jason Sams | e4a06c5 | 2011-03-16 16:29:28 -0700 | [diff] [blame] | 198 | |