blob: 7b8d55767cc2de8fae31e012b1a4b52b19109bb8 [file] [log] [blame]
Jason Sams709a0972012-11-15 18:18:04 -08001/*
2 * Copyright (C) 2011-2012 The Android Open Source Project
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"
19#include "rsMatrix4x4.h"
20#include "rsMatrix3x3.h"
21#include "rsMatrix2x2.h"
22#include "rsRuntime.h"
23
Jason Sams709a0972012-11-15 18:18:04 -080024#include "rsCpuCore.h"
25#include "rsCpuScript.h"
26
27#include <time.h>
28
Tim Murray0b575de2013-03-15 15:56:43 -070029#ifndef RS_SERVER
30#include "utils/Timers.h"
31#endif
32
Jason Sams709a0972012-11-15 18:18:04 -080033using namespace android;
34using namespace android::renderscript;
35
36typedef float float2 __attribute__((ext_vector_type(2)));
37typedef float float3 __attribute__((ext_vector_type(3)));
38typedef float float4 __attribute__((ext_vector_type(4)));
39typedef char char2 __attribute__((ext_vector_type(2)));
40typedef char char3 __attribute__((ext_vector_type(3)));
41typedef char char4 __attribute__((ext_vector_type(4)));
42typedef unsigned char uchar2 __attribute__((ext_vector_type(2)));
43typedef unsigned char uchar3 __attribute__((ext_vector_type(3)));
44typedef unsigned char uchar4 __attribute__((ext_vector_type(4)));
45typedef short short2 __attribute__((ext_vector_type(2)));
46typedef short short3 __attribute__((ext_vector_type(3)));
47typedef short short4 __attribute__((ext_vector_type(4)));
48typedef unsigned short ushort2 __attribute__((ext_vector_type(2)));
49typedef unsigned short ushort3 __attribute__((ext_vector_type(3)));
50typedef unsigned short ushort4 __attribute__((ext_vector_type(4)));
51typedef int32_t int2 __attribute__((ext_vector_type(2)));
52typedef int32_t int3 __attribute__((ext_vector_type(3)));
53typedef int32_t int4 __attribute__((ext_vector_type(4)));
54typedef uint32_t uint2 __attribute__((ext_vector_type(2)));
55typedef uint32_t uint3 __attribute__((ext_vector_type(3)));
56typedef uint32_t uint4 __attribute__((ext_vector_type(4)));
57typedef long long long2 __attribute__((ext_vector_type(2)));
58typedef long long long3 __attribute__((ext_vector_type(3)));
59typedef long long long4 __attribute__((ext_vector_type(4)));
60typedef unsigned long long ulong2 __attribute__((ext_vector_type(2)));
61typedef unsigned long long ulong3 __attribute__((ext_vector_type(3)));
62typedef unsigned long long ulong4 __attribute__((ext_vector_type(4)));
63
64
65//////////////////////////////////////////////////////////////////////////////
66// Message routines
67//////////////////////////////////////////////////////////////////////////////
68
69
Jason Sams709a0972012-11-15 18:18:04 -080070static void SC_debugF(const char *s, float f) {
71 ALOGD("%s %f, 0x%08x", s, f, *((int *) (&f)));
72}
73static void SC_debugFv2(const char *s, float f1, float f2) {
74 ALOGD("%s {%f, %f}", s, f1, f2);
75}
76static void SC_debugFv3(const char *s, float f1, float f2, float f3) {
77 ALOGD("%s {%f, %f, %f}", s, f1, f2, f3);
78}
79static void SC_debugFv4(const char *s, float f1, float f2, float f3, float f4) {
80 ALOGD("%s {%f, %f, %f, %f}", s, f1, f2, f3, f4);
81}
82static void SC_debugF2(const char *s, float2 f) {
83 ALOGD("%s {%f, %f}", s, f.x, f.y);
84}
85static void SC_debugF3(const char *s, float3 f) {
86 ALOGD("%s {%f, %f, %f}", s, f.x, f.y, f.z);
87}
88static void SC_debugF4(const char *s, float4 f) {
89 ALOGD("%s {%f, %f, %f, %f}", s, f.x, f.y, f.z, f.w);
90}
91static void SC_debugD(const char *s, double d) {
92 ALOGD("%s %f, 0x%08llx", s, d, *((long long *) (&d)));
93}
94static void SC_debugFM4v4(const char *s, const float *f) {
95 ALOGD("%s {%f, %f, %f, %f", s, f[0], f[4], f[8], f[12]);
96 ALOGD("%s %f, %f, %f, %f", s, f[1], f[5], f[9], f[13]);
97 ALOGD("%s %f, %f, %f, %f", s, f[2], f[6], f[10], f[14]);
98 ALOGD("%s %f, %f, %f, %f}", s, f[3], f[7], f[11], f[15]);
99}
100static void SC_debugFM3v3(const char *s, const float *f) {
101 ALOGD("%s {%f, %f, %f", s, f[0], f[3], f[6]);
102 ALOGD("%s %f, %f, %f", s, f[1], f[4], f[7]);
103 ALOGD("%s %f, %f, %f}",s, f[2], f[5], f[8]);
104}
105static void SC_debugFM2v2(const char *s, const float *f) {
106 ALOGD("%s {%f, %f", s, f[0], f[2]);
107 ALOGD("%s %f, %f}",s, f[1], f[3]);
108}
109static void SC_debugI8(const char *s, char c) {
110 ALOGD("%s %hhd 0x%hhx", s, c, (unsigned char)c);
111}
112static void SC_debugC2(const char *s, char2 c) {
113 ALOGD("%s {%hhd, %hhd} 0x%hhx 0x%hhx", s, c.x, c.y, (unsigned char)c.x, (unsigned char)c.y);
114}
115static void SC_debugC3(const char *s, char3 c) {
116 ALOGD("%s {%hhd, %hhd, %hhd} 0x%hhx 0x%hhx 0x%hhx", s, c.x, c.y, c.z, (unsigned char)c.x, (unsigned char)c.y, (unsigned char)c.z);
117}
118static void SC_debugC4(const char *s, char4 c) {
119 ALOGD("%s {%hhd, %hhd, %hhd, %hhd} 0x%hhx 0x%hhx 0x%hhx 0x%hhx", s, c.x, c.y, c.z, c.w, (unsigned char)c.x, (unsigned char)c.y, (unsigned char)c.z, (unsigned char)c.w);
120}
121static void SC_debugU8(const char *s, unsigned char c) {
122 ALOGD("%s %hhu 0x%hhx", s, c, c);
123}
124static void SC_debugUC2(const char *s, uchar2 c) {
125 ALOGD("%s {%hhu, %hhu} 0x%hhx 0x%hhx", s, c.x, c.y, c.x, c.y);
126}
127static void SC_debugUC3(const char *s, uchar3 c) {
128 ALOGD("%s {%hhu, %hhu, %hhu} 0x%hhx 0x%hhx 0x%hhx", s, c.x, c.y, c.z, c.x, c.y, c.z);
129}
130static void SC_debugUC4(const char *s, uchar4 c) {
131 ALOGD("%s {%hhu, %hhu, %hhu, %hhu} 0x%hhx 0x%hhx 0x%hhx 0x%hhx", s, c.x, c.y, c.z, c.w, c.x, c.y, c.z, c.w);
132}
133static void SC_debugI16(const char *s, short c) {
134 ALOGD("%s %hd 0x%hx", s, c, c);
135}
136static void SC_debugS2(const char *s, short2 c) {
137 ALOGD("%s {%hd, %hd} 0x%hx 0x%hx", s, c.x, c.y, c.x, c.y);
138}
139static void SC_debugS3(const char *s, short3 c) {
140 ALOGD("%s {%hd, %hd, %hd} 0x%hx 0x%hx 0x%hx", s, c.x, c.y, c.z, c.x, c.y, c.z);
141}
142static void SC_debugS4(const char *s, short4 c) {
143 ALOGD("%s {%hd, %hd, %hd, %hd} 0x%hx 0x%hx 0x%hx 0x%hx", s, c.x, c.y, c.z, c.w, c.x, c.y, c.z, c.w);
144}
145static void SC_debugU16(const char *s, unsigned short c) {
146 ALOGD("%s %hu 0x%hx", s, c, c);
147}
148static void SC_debugUS2(const char *s, ushort2 c) {
149 ALOGD("%s {%hu, %hu} 0x%hx 0x%hx", s, c.x, c.y, c.x, c.y);
150}
151static void SC_debugUS3(const char *s, ushort3 c) {
152 ALOGD("%s {%hu, %hu, %hu} 0x%hx 0x%hx 0x%hx", s, c.x, c.y, c.z, c.x, c.y, c.z);
153}
154static void SC_debugUS4(const char *s, ushort4 c) {
155 ALOGD("%s {%hu, %hu, %hu, %hu} 0x%hx 0x%hx 0x%hx 0x%hx", s, c.x, c.y, c.z, c.w, c.x, c.y, c.z, c.w);
156}
157static void SC_debugI32(const char *s, int32_t i) {
158 ALOGD("%s %d 0x%x", s, i, i);
159}
160static void SC_debugI2(const char *s, int2 i) {
161 ALOGD("%s {%d, %d} 0x%x 0x%x", s, i.x, i.y, i.x, i.y);
162}
163static void SC_debugI3(const char *s, int3 i) {
164 ALOGD("%s {%d, %d, %d} 0x%x 0x%x 0x%x", s, i.x, i.y, i.z, i.x, i.y, i.z);
165}
166static void SC_debugI4(const char *s, int4 i) {
167 ALOGD("%s {%d, %d, %d, %d} 0x%x 0x%x 0x%x 0x%x", s, i.x, i.y, i.z, i.w, i.x, i.y, i.z, i.w);
168}
169static void SC_debugU32(const char *s, uint32_t i) {
170 ALOGD("%s %u 0x%x", s, i, i);
171}
172static void SC_debugUI2(const char *s, uint2 i) {
173 ALOGD("%s {%u, %u} 0x%x 0x%x", s, i.x, i.y, i.x, i.y);
174}
175static void SC_debugUI3(const char *s, uint3 i) {
176 ALOGD("%s {%u, %u, %u} 0x%x 0x%x 0x%x", s, i.x, i.y, i.z, i.x, i.y, i.z);
177}
178static void SC_debugUI4(const char *s, uint4 i) {
179 ALOGD("%s {%u, %u, %u, %u} 0x%x 0x%x 0x%x 0x%x", s, i.x, i.y, i.z, i.w, i.x, i.y, i.z, i.w);
180}
181static void SC_debugLL64(const char *s, long long ll) {
182 ALOGD("%s %lld 0x%llx", s, ll, ll);
183}
184static void SC_debugL2(const char *s, long2 ll) {
185 ALOGD("%s {%lld, %lld} 0x%llx 0x%llx", s, ll.x, ll.y, ll.x, ll.y);
186}
187static void SC_debugL3(const char *s, long3 ll) {
188 ALOGD("%s {%lld, %lld, %lld} 0x%llx 0x%llx 0x%llx", s, ll.x, ll.y, ll.z, ll.x, ll.y, ll.z);
189}
190static void SC_debugL4(const char *s, long4 ll) {
191 ALOGD("%s {%lld, %lld, %lld, %lld} 0x%llx 0x%llx 0x%llx 0x%llx", s, ll.x, ll.y, ll.z, ll.w, ll.x, ll.y, ll.z, ll.w);
192}
193static void SC_debugULL64(const char *s, unsigned long long ll) {
194 ALOGD("%s %llu 0x%llx", s, ll, ll);
195}
196static void SC_debugUL2(const char *s, ulong2 ll) {
197 ALOGD("%s {%llu, %llu} 0x%llx 0x%llx", s, ll.x, ll.y, ll.x, ll.y);
198}
199static void SC_debugUL3(const char *s, ulong3 ll) {
200 ALOGD("%s {%llu, %llu, %llu} 0x%llx 0x%llx 0x%llx", s, ll.x, ll.y, ll.z, ll.x, ll.y, ll.z);
201}
202static void SC_debugUL4(const char *s, ulong4 ll) {
203 ALOGD("%s {%llu, %llu, %llu, %llu} 0x%llx 0x%llx 0x%llx 0x%llx", s, ll.x, ll.y, ll.z, ll.w, ll.x, ll.y, ll.z, ll.w);
204}
205static void SC_debugP(const char *s, const void *p) {
206 ALOGD("%s %p", s, p);
207}
208
209
210//////////////////////////////////////////////////////////////////////////////
211// Stub implementation
212//////////////////////////////////////////////////////////////////////////////
213
214// llvm name mangling ref
215// <builtin-type> ::= v # void
216// ::= b # bool
217// ::= c # char
218// ::= a # signed char
219// ::= h # unsigned char
220// ::= s # short
221// ::= t # unsigned short
222// ::= i # int
223// ::= j # unsigned int
224// ::= l # long
225// ::= m # unsigned long
226// ::= x # long long, __int64
227// ::= y # unsigned long long, __int64
228// ::= f # float
229// ::= d # double
230
231static RsdCpuReference::CpuSymbol gSyms[] = {
232 { "memset", (void *)&memset, true },
233 { "memcpy", (void *)&memcpy, true },
234
235 // Debug
236 { "_Z7rsDebugPKcf", (void *)&SC_debugF, true },
237 { "_Z7rsDebugPKcff", (void *)&SC_debugFv2, true },
238 { "_Z7rsDebugPKcfff", (void *)&SC_debugFv3, true },
239 { "_Z7rsDebugPKcffff", (void *)&SC_debugFv4, true },
240 { "_Z7rsDebugPKcDv2_f", (void *)&SC_debugF2, true },
241 { "_Z7rsDebugPKcDv3_f", (void *)&SC_debugF3, true },
242 { "_Z7rsDebugPKcDv4_f", (void *)&SC_debugF4, true },
243 { "_Z7rsDebugPKcd", (void *)&SC_debugD, true },
244 { "_Z7rsDebugPKcPK12rs_matrix4x4", (void *)&SC_debugFM4v4, true },
245 { "_Z7rsDebugPKcPK12rs_matrix3x3", (void *)&SC_debugFM3v3, true },
246 { "_Z7rsDebugPKcPK12rs_matrix2x2", (void *)&SC_debugFM2v2, true },
247 { "_Z7rsDebugPKcc", (void *)&SC_debugI8, true },
248 { "_Z7rsDebugPKcDv2_c", (void *)&SC_debugC2, true },
249 { "_Z7rsDebugPKcDv3_c", (void *)&SC_debugC3, true },
250 { "_Z7rsDebugPKcDv4_c", (void *)&SC_debugC4, true },
251 { "_Z7rsDebugPKch", (void *)&SC_debugU8, true },
252 { "_Z7rsDebugPKcDv2_h", (void *)&SC_debugUC2, true },
253 { "_Z7rsDebugPKcDv3_h", (void *)&SC_debugUC3, true },
254 { "_Z7rsDebugPKcDv4_h", (void *)&SC_debugUC4, true },
255 { "_Z7rsDebugPKcs", (void *)&SC_debugI16, true },
256 { "_Z7rsDebugPKcDv2_s", (void *)&SC_debugS2, true },
257 { "_Z7rsDebugPKcDv3_s", (void *)&SC_debugS3, true },
258 { "_Z7rsDebugPKcDv4_s", (void *)&SC_debugS4, true },
259 { "_Z7rsDebugPKct", (void *)&SC_debugU16, true },
260 { "_Z7rsDebugPKcDv2_t", (void *)&SC_debugUS2, true },
261 { "_Z7rsDebugPKcDv3_t", (void *)&SC_debugUS3, true },
262 { "_Z7rsDebugPKcDv4_t", (void *)&SC_debugUS4, true },
263 { "_Z7rsDebugPKci", (void *)&SC_debugI32, true },
264 { "_Z7rsDebugPKcDv2_i", (void *)&SC_debugI2, true },
265 { "_Z7rsDebugPKcDv3_i", (void *)&SC_debugI3, true },
266 { "_Z7rsDebugPKcDv4_i", (void *)&SC_debugI4, true },
267 { "_Z7rsDebugPKcj", (void *)&SC_debugU32, true },
268 { "_Z7rsDebugPKcDv2_j", (void *)&SC_debugUI2, true },
269 { "_Z7rsDebugPKcDv3_j", (void *)&SC_debugUI3, true },
270 { "_Z7rsDebugPKcDv4_j", (void *)&SC_debugUI4, true },
271 // Both "long" and "unsigned long" need to be redirected to their
272 // 64-bit counterparts, since we have hacked Slang to use 64-bit
273 // for "long" on Arm (to be similar to Java).
274 { "_Z7rsDebugPKcl", (void *)&SC_debugLL64, true },
275 { "_Z7rsDebugPKcDv2_l", (void *)&SC_debugL2, true },
276 { "_Z7rsDebugPKcDv3_l", (void *)&SC_debugL3, true },
277 { "_Z7rsDebugPKcDv4_l", (void *)&SC_debugL4, true },
278 { "_Z7rsDebugPKcm", (void *)&SC_debugULL64, true },
279 { "_Z7rsDebugPKcDv2_m", (void *)&SC_debugUL2, true },
280 { "_Z7rsDebugPKcDv3_m", (void *)&SC_debugUL3, true },
281 { "_Z7rsDebugPKcDv4_m", (void *)&SC_debugUL4, true },
282 { "_Z7rsDebugPKcx", (void *)&SC_debugLL64, true },
283 { "_Z7rsDebugPKcDv2_x", (void *)&SC_debugL2, true },
284 { "_Z7rsDebugPKcDv3_x", (void *)&SC_debugL3, true },
285 { "_Z7rsDebugPKcDv4_x", (void *)&SC_debugL4, true },
286 { "_Z7rsDebugPKcy", (void *)&SC_debugULL64, true },
287 { "_Z7rsDebugPKcDv2_y", (void *)&SC_debugUL2, true },
288 { "_Z7rsDebugPKcDv3_y", (void *)&SC_debugUL3, true },
289 { "_Z7rsDebugPKcDv4_y", (void *)&SC_debugUL4, true },
290 { "_Z7rsDebugPKcPKv", (void *)&SC_debugP, true },
291
292 { NULL, NULL, false }
293};
294
295
296void * RsdCpuScriptImpl::lookupRuntimeStub(void* pContext, char const* name) {
297 RsdCpuScriptImpl *s = (RsdCpuScriptImpl *)pContext;
298 const RsdCpuReference::CpuSymbol *syms = gSyms;
299 const RsdCpuReference::CpuSymbol *sym = NULL;
300
301 sym = s->mCtx->symLookup(name);
302 if (!sym) {
303 sym = s->lookupSymbolMath(name);
304 }
305 if (!sym) {
306 while (syms->fnPtr) {
307 if (!strcmp(syms->name, name)) {
308 sym = syms;
309 }
310 syms++;
311 }
312 }
313
314 if (sym) {
315 s->mIsThreadable &= sym->threadable;
316 return sym->fnPtr;
317 }
318 ALOGE("ScriptC sym lookup failed for %s", name);
319 return NULL;
320}
321
322