1709a0978ae141198018ca9769f8d96292a8928e6Jason Sams/*
2709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * Copyright (C) 2011-2012 The Android Open Source Project
3709a0978ae141198018ca9769f8d96292a8928e6Jason Sams *
4709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * Licensed under the Apache License, Version 2.0 (the "License");
5709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * you may not use this file except in compliance with the License.
6709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * You may obtain a copy of the License at
7709a0978ae141198018ca9769f8d96292a8928e6Jason Sams *
8709a0978ae141198018ca9769f8d96292a8928e6Jason Sams *      http://www.apache.org/licenses/LICENSE-2.0
9709a0978ae141198018ca9769f8d96292a8928e6Jason Sams *
10709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * Unless required by applicable law or agreed to in writing, software
11709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * distributed under the License is distributed on an "AS IS" BASIS,
12709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * See the License for the specific language governing permissions and
14709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * limitations under the License.
15709a0978ae141198018ca9769f8d96292a8928e6Jason Sams */
16709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
17709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsContext.h"
18709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsScriptC.h"
19709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsMatrix4x4.h"
20709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsMatrix3x3.h"
21709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsMatrix2x2.h"
22709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsRuntime.h"
23709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
24709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsCpuCore.h"
25709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsCpuScript.h"
26709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
27709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include <time.h>
28709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
29709a0978ae141198018ca9769f8d96292a8928e6Jason Samsusing namespace android;
30709a0978ae141198018ca9769f8d96292a8928e6Jason Samsusing namespace android::renderscript;
31709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
32709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef float float2 __attribute__((ext_vector_type(2)));
33709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef float float3 __attribute__((ext_vector_type(3)));
34709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef float float4 __attribute__((ext_vector_type(4)));
3560fe47db884673ace2b41c6a037a376bbd0fd670Tim Murraytypedef double double2 __attribute__((ext_vector_type(2)));
3660fe47db884673ace2b41c6a037a376bbd0fd670Tim Murraytypedef double double3 __attribute__((ext_vector_type(3)));
3760fe47db884673ace2b41c6a037a376bbd0fd670Tim Murraytypedef double double4 __attribute__((ext_vector_type(4)));
38709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef char char2 __attribute__((ext_vector_type(2)));
39709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef char char3 __attribute__((ext_vector_type(3)));
40709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef char char4 __attribute__((ext_vector_type(4)));
41709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned char uchar2 __attribute__((ext_vector_type(2)));
42709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned char uchar3 __attribute__((ext_vector_type(3)));
43709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned char uchar4 __attribute__((ext_vector_type(4)));
44709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef short short2 __attribute__((ext_vector_type(2)));
45709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef short short3 __attribute__((ext_vector_type(3)));
46709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef short short4 __attribute__((ext_vector_type(4)));
47709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned short ushort2 __attribute__((ext_vector_type(2)));
48709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned short ushort3 __attribute__((ext_vector_type(3)));
49709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned short ushort4 __attribute__((ext_vector_type(4)));
50709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef int32_t int2 __attribute__((ext_vector_type(2)));
51709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef int32_t int3 __attribute__((ext_vector_type(3)));
52709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef int32_t int4 __attribute__((ext_vector_type(4)));
53709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef uint32_t uint2 __attribute__((ext_vector_type(2)));
54709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef uint32_t uint3 __attribute__((ext_vector_type(3)));
55709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef uint32_t uint4 __attribute__((ext_vector_type(4)));
56709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef long long long2 __attribute__((ext_vector_type(2)));
57709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef long long long3 __attribute__((ext_vector_type(3)));
58709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef long long long4 __attribute__((ext_vector_type(4)));
59709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned long long ulong2 __attribute__((ext_vector_type(2)));
60709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned long long ulong3 __attribute__((ext_vector_type(3)));
61709a0978ae141198018ca9769f8d96292a8928e6Jason Samstypedef unsigned long long ulong4 __attribute__((ext_vector_type(4)));
62709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
63709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
64709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//////////////////////////////////////////////////////////////////////////////
65709a0978ae141198018ca9769f8d96292a8928e6Jason Sams// Message routines
66709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//////////////////////////////////////////////////////////////////////////////
67709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
68709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
69709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugF(const char *s, float f) {
70941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("float %s %f, 0x%08x", s, f, *((int *) (&f)));
71709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
72709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugFv2(const char *s, float f1, float f2) {
73941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("float x2 %s {%f, %f}", s, f1, f2);
74709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
75709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugFv3(const char *s, float f1, float f2, float f3) {
76941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("float x3 %s {%f, %f, %f}", s, f1, f2, f3);
77709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
78709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugFv4(const char *s, float f1, float f2, float f3, float f4) {
79941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("float x4 %s {%f, %f, %f, %f}", s, f1, f2, f3, f4);
80709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
81941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugF2(const char *s, const float2 *f) {
82941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("float2 %s {%f, %f}", s, f->x, f->y);
83709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
84941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugF3(const char *s, const float3 *f) {
85941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("float3 %s {%f, %f, %f}", s, f->x, f->y, f->z);
86709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
87941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugF4(const char *s, const float4 *f) {
88941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("float4 %s {%f, %f, %f, %f}", s, f->x, f->y, f->z, f->w);
89709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
90709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugD(const char *s, double d) {
91941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("double %s %f, 0x%08llx", s, d, *((long long *) (&d)));
92709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
9360fe47db884673ace2b41c6a037a376bbd0fd670Tim Murraystatic void SC_debugD2(const char *s, const double2 *f) {
9460fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray    ALOGD("double2 %s {%f, %f}", s, f->x, f->y);
9560fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray}
9660fe47db884673ace2b41c6a037a376bbd0fd670Tim Murraystatic void SC_debugD3(const char *s, const double3 *f) {
9760fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray    ALOGD("double3 %s {%f, %f, %f}", s, f->x, f->y, f->z);
9860fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray}
9960fe47db884673ace2b41c6a037a376bbd0fd670Tim Murraystatic void SC_debugD4(const char *s, const double4 *f) {
10060fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray    ALOGD("double4 %s {%f, %f, %f, %f}", s, f->x, f->y, f->z, f->w);
10160fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray}
10260fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray
103709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugFM4v4(const char *s, const float *f) {
104941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("matrix4x4 %s {%f, %f, %f, %f", s, f[0], f[4], f[8], f[12]);
105941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("          %s  %f, %f, %f, %f", s, f[1], f[5], f[9], f[13]);
106941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("          %s  %f, %f, %f, %f", s, f[2], f[6], f[10], f[14]);
107941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("          %s  %f, %f, %f, %f}", s, f[3], f[7], f[11], f[15]);
108709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
109709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugFM3v3(const char *s, const float *f) {
110941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("matrix3x3 %s {%f, %f, %f", s, f[0], f[3], f[6]);
111941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("          %s  %f, %f, %f", s, f[1], f[4], f[7]);
112941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("          %s  %f, %f, %f}",s, f[2], f[5], f[8]);
113709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
114709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugFM2v2(const char *s, const float *f) {
115941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("matrix2x2 %s {%f, %f", s, f[0], f[2]);
116941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("          %s  %f, %f}",s, f[1], f[3]);
117709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
118709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugI8(const char *s, char c) {
119941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("char %s %hhd  0x%hhx", s, c, (unsigned char)c);
120709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
121941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugC2(const char *s, const char2 *c) {
122941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("char2 %s {%hhd, %hhd}  0x%hhx 0x%hhx", s, c->x, c->y, (unsigned char)c->x, (unsigned char)c->y);
123709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
124941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugC3(const char *s, const char3 *c) {
125941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("char3 %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);
126709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
127941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugC4(const char *s, const char4 *c) {
128941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("char4 %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);
129709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
130709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugU8(const char *s, unsigned char c) {
131941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("uchar %s %hhu  0x%hhx", s, c, c);
132709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
133941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUC2(const char *s, const uchar2 *c) {
134941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("uchar2 %s {%hhu, %hhu}  0x%hhx 0x%hhx", s, c->x, c->y, c->x, c->y);
135709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
136941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUC3(const char *s, const uchar3 *c) {
137941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("uchar3 %s {%hhu, %hhu, %hhu}  0x%hhx 0x%hhx 0x%hhx", s, c->x, c->y, c->z, c->x, c->y, c->z);
138709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
139941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUC4(const char *s, const uchar4 *c) {
140941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("uchar4 %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);
141709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
142709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugI16(const char *s, short c) {
143941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("short %s %hd  0x%hx", s, c, c);
144709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
145941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugS2(const char *s, const short2 *c) {
146941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("short2 %s {%hd, %hd}  0x%hx 0x%hx", s, c->x, c->y, c->x, c->y);
147709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
148941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugS3(const char *s, const short3 *c) {
149941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("short3 %s {%hd, %hd, %hd}  0x%hx 0x%hx 0x%hx", s, c->x, c->y, c->z, c->x, c->y, c->z);
150709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
151941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugS4(const char *s, const short4 *c) {
152941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("short4 %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);
153709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
154709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugU16(const char *s, unsigned short c) {
155941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("ushort %s %hu  0x%hx", s, c, c);
156709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
157941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUS2(const char *s, const ushort2 *c) {
158941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("ushort2 %s {%hu, %hu}  0x%hx 0x%hx", s, c->x, c->y, c->x, c->y);
159709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
160941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUS3(const char *s, const ushort3 *c) {
161941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("ushort3 %s {%hu, %hu, %hu}  0x%hx 0x%hx 0x%hx", s, c->x, c->y, c->z, c->x, c->y, c->z);
162709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
163941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUS4(const char *s, const ushort4 *c) {
164941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("ushort4 %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);
165709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
166709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugI32(const char *s, int32_t i) {
167941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("int %s %d  0x%x", s, i, i);
168709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
169941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugI2(const char *s, const int2 *i) {
170941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("int2 %s {%d, %d}  0x%x 0x%x", s, i->x, i->y, i->x, i->y);
171709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
172941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugI3(const char *s, const int3 *i) {
173941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("int3 %s {%d, %d, %d}  0x%x 0x%x 0x%x", s, i->x, i->y, i->z, i->x, i->y, i->z);
174709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
175941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugI4(const char *s, const int4 *i) {
176941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("int4 %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);
177709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
178709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugU32(const char *s, uint32_t i) {
179941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("uint %s %u  0x%x", s, i, i);
180709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
181941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUI2(const char *s, const uint2 *i) {
182941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("uint2 %s {%u, %u}  0x%x 0x%x", s, i->x, i->y, i->x, i->y);
183709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
184941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUI3(const char *s, const uint3 *i) {
185941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("uint3 %s {%u, %u, %u}  0x%x 0x%x 0x%x", s, i->x, i->y, i->z, i->x, i->y, i->z);
186709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
187941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUI4(const char *s, const uint4 *i) {
188941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("uint4 %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);
189709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
190709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugLL64(const char *s, long long ll) {
191941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("long %s %lld  0x%llx", s, ll, ll);
192709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
193941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugL2(const char *s, const long2 *ll) {
194941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("long2 %s {%lld, %lld}  0x%llx 0x%llx", s, ll->x, ll->y, ll->x, ll->y);
195709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
196941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugL3(const char *s, const long3 *ll) {
197941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("long3 %s {%lld, %lld, %lld}  0x%llx 0x%llx 0x%llx", s, ll->x, ll->y, ll->z, ll->x, ll->y, ll->z);
198709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
199941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugL4(const char *s, const long4 *ll) {
200941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("long4 %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);
201709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
202709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugULL64(const char *s, unsigned long long ll) {
203941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("ulong %s %llu  0x%llx", s, ll, ll);
204709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
205941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUL2(const char *s, const ulong2 *ll) {
206941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("ulong2 %s {%llu, %llu}  0x%llx 0x%llx", s, ll->x, ll->y, ll->x, ll->y);
207709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
208941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUL3(const char *s, const ulong3 *ll) {
209941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("ulong3 %s {%llu, %llu, %llu}  0x%llx 0x%llx 0x%llx", s, ll->x, ll->y, ll->z, ll->x, ll->y, ll->z);
210709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
211941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Samsstatic void SC_debugUL4(const char *s, const ulong4 *ll) {
212941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("ulong4 %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);
213709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
214709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic void SC_debugP(const char *s, const void *p) {
215941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    ALOGD("void * %s %p", s, p);
216709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
217709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
218709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
219709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//////////////////////////////////////////////////////////////////////////////
220709a0978ae141198018ca9769f8d96292a8928e6Jason Sams// Stub implementation
221709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//////////////////////////////////////////////////////////////////////////////
222709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
223709a0978ae141198018ca9769f8d96292a8928e6Jason Sams// llvm name mangling ref
224709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//  <builtin-type> ::= v  # void
225709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= b  # bool
226709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= c  # char
227709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= a  # signed char
228709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= h  # unsigned char
229709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= s  # short
230709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= t  # unsigned short
231709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= i  # int
232709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= j  # unsigned int
233709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= l  # long
234709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= m  # unsigned long
235709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= x  # long long, __int64
236709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= y  # unsigned long long, __int64
237709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= f  # float
238709a0978ae141198018ca9769f8d96292a8928e6Jason Sams//                 ::= d  # double
239709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
240709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic RsdCpuReference::CpuSymbol gSyms[] = {
241709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "memset", (void *)&memset, true },
242709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "memcpy", (void *)&memcpy, true },
243709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
244709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    // Debug
245709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcf", (void *)&SC_debugF, true },
246709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcff", (void *)&SC_debugFv2, true },
247709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcfff", (void *)&SC_debugFv3, true },
248709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcffff", (void *)&SC_debugFv4, true },
249941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_f", (void *)&SC_debugF2, true },
250941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_f", (void *)&SC_debugF3, true },
251941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_f", (void *)&SC_debugF4, true },
252709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcd", (void *)&SC_debugD, true },
25360fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray    { "_Z7rsDebugPKcPKDv2_d", (void *)&SC_debugD2, true },
25460fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray    { "_Z7rsDebugPKcPKDv3_d", (void *)&SC_debugD3, true },
25560fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray    { "_Z7rsDebugPKcPKDv4_d", (void *)&SC_debugD4, true },
256709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcPK12rs_matrix4x4", (void *)&SC_debugFM4v4, true },
257709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcPK12rs_matrix3x3", (void *)&SC_debugFM3v3, true },
258709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcPK12rs_matrix2x2", (void *)&SC_debugFM2v2, true },
259709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcc", (void *)&SC_debugI8, true },
260941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_c", (void *)&SC_debugC2, true },
261941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_c", (void *)&SC_debugC3, true },
262941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_c", (void *)&SC_debugC4, true },
263709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKch", (void *)&SC_debugU8, true },
264941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_h", (void *)&SC_debugUC2, true },
265941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_h", (void *)&SC_debugUC3, true },
266941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_h", (void *)&SC_debugUC4, true },
267709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcs", (void *)&SC_debugI16, true },
268941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_s", (void *)&SC_debugS2, true },
269941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_s", (void *)&SC_debugS3, true },
270941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_s", (void *)&SC_debugS4, true },
271709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKct", (void *)&SC_debugU16, true },
272941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_t", (void *)&SC_debugUS2, true },
273941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_t", (void *)&SC_debugUS3, true },
274941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_t", (void *)&SC_debugUS4, true },
275709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKci", (void *)&SC_debugI32, true },
276941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_i", (void *)&SC_debugI2, true },
277941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_i", (void *)&SC_debugI3, true },
278941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_i", (void *)&SC_debugI4, true },
279709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcj", (void *)&SC_debugU32, true },
280941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_j", (void *)&SC_debugUI2, true },
281941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_j", (void *)&SC_debugUI3, true },
282941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_j", (void *)&SC_debugUI4, true },
283709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    // Both "long" and "unsigned long" need to be redirected to their
284709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    // 64-bit counterparts, since we have hacked Slang to use 64-bit
285709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    // for "long" on Arm (to be similar to Java).
286709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcl", (void *)&SC_debugLL64, true },
287941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_l", (void *)&SC_debugL2, true },
288941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_l", (void *)&SC_debugL3, true },
289941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_l", (void *)&SC_debugL4, true },
290709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcm", (void *)&SC_debugULL64, true },
291941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_m", (void *)&SC_debugUL2, true },
292941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_m", (void *)&SC_debugUL3, true },
293941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_m", (void *)&SC_debugUL4, true },
294709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcx", (void *)&SC_debugLL64, true },
295941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_x", (void *)&SC_debugL2, true },
296941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_x", (void *)&SC_debugL3, true },
297941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_x", (void *)&SC_debugL4, true },
298709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcy", (void *)&SC_debugULL64, true },
299941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv2_y", (void *)&SC_debugUL2, true },
300941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv3_y", (void *)&SC_debugUL3, true },
301941a61732cb044d0d9e4153dd3ef39d3055673e7Jason Sams    { "_Z7rsDebugPKcPKDv4_y", (void *)&SC_debugUL4, true },
302cbdb6480528fc374144df1ae9c604c9100d33268Tim Murray    { "_Z7rsDebugPKcDv2_y", (void *)&SC_debugUL2, true },
303cbdb6480528fc374144df1ae9c604c9100d33268Tim Murray    { "_Z7rsDebugPKcDv3_y", (void *)&SC_debugUL3, true },
304cbdb6480528fc374144df1ae9c604c9100d33268Tim Murray    { "_Z7rsDebugPKcDv4_y", (void *)&SC_debugUL4, true },
305cbdb6480528fc374144df1ae9c604c9100d33268Tim Murray
306709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { "_Z7rsDebugPKcPKv", (void *)&SC_debugP, true },
307709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
308709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    { NULL, NULL, false }
309709a0978ae141198018ca9769f8d96292a8928e6Jason Sams};
310709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
311709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
312709a0978ae141198018ca9769f8d96292a8928e6Jason Samsvoid * RsdCpuScriptImpl::lookupRuntimeStub(void* pContext, char const* name) {
313709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    RsdCpuScriptImpl *s = (RsdCpuScriptImpl *)pContext;
314709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    const RsdCpuReference::CpuSymbol *syms = gSyms;
315709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    const RsdCpuReference::CpuSymbol *sym = NULL;
316709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
317709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    sym = s->mCtx->symLookup(name);
318709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    if (!sym) {
319709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        sym = s->lookupSymbolMath(name);
320709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    }
321709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    if (!sym) {
322709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        while (syms->fnPtr) {
323709a0978ae141198018ca9769f8d96292a8928e6Jason Sams            if (!strcmp(syms->name, name)) {
324709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                sym = syms;
325709a0978ae141198018ca9769f8d96292a8928e6Jason Sams            }
326709a0978ae141198018ca9769f8d96292a8928e6Jason Sams            syms++;
327709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        }
328709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    }
329709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
330709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    if (sym) {
331709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        s->mIsThreadable &= sym->threadable;
332709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        return sym->fnPtr;
333709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    }
334709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    ALOGE("ScriptC sym lookup failed for %s", name);
335709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    return NULL;
336709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
337709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
338709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
339