187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams/* 2709a0978ae141198018ca9769f8d96292a8928e6Jason Sams * Copyright (C) 2011-2012 The Android Open Source Project 387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * 487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * Licensed under the Apache License, Version 2.0 (the "License"); 587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * you may not use this file except in compliance with the License. 687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * You may obtain a copy of the License at 787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * 887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * http://www.apache.org/licenses/LICENSE-2.0 987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * 1087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * Unless required by applicable law or agreed to in writing, software 1187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * distributed under the License is distributed on an "AS IS" BASIS, 1287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * See the License for the specific language governing permissions and 1487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams * limitations under the License. 1587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams */ 1687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 1743cfc0cbe6e6e8f585a0ae5f1d9cc2859ab1dda7Stephen Hines#if !defined(RS_SERVER) && !defined(RS_COMPATIBILITY_LIB) 1872f4f4cec34098e179ad5d257b07df3a514fcae2Glenn Kasten#include <cutils/compiler.h> 190b575de8ed0b628d84d256f5846500b0385979bdTim Murray#endif 2072f4f4cec34098e179ad5d257b07df3a514fcae2Glenn Kasten 2187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams#include "rsContext.h" 2287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams#include "rsScriptC.h" 2387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams#include "rsMatrix4x4.h" 2487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams#include "rsMatrix3x3.h" 2587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams#include "rsMatrix2x2.h" 2687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 27709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsCpuCore.h" 28709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsCpuScript.h" 2987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 3087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsusing namespace android; 3187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsusing namespace android::renderscript; 3287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 33d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray#define EXPORT_F32_FN_F32(func) \ 34d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray float __attribute__((overloadable)) SC_##func(float v) { \ 35d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray return func(v); \ 36d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray } 37d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray 38d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray#define EXPORT_F32_FN_F32_F32(func) \ 39d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray float __attribute__((overloadable)) SC_##func(float t, float v) { \ 40d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray return func(t, v); \ 41d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray } 4287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 4387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams////////////////////////////////////////////////////////////////////////////// 4487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// Float util 4587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams////////////////////////////////////////////////////////////////////////////// 4687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 47d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray// Handle missing Gingerbread functions like tgammaf. 48d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murrayfloat SC_tgammaf(float x) { 4911418c87254f0cbffa910fe8f105b7da92452487Stephen Hines#ifdef RS_COMPATIBILITY_LIB 50d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray return tgamma(x); 5111418c87254f0cbffa910fe8f105b7da92452487Stephen Hines#else 5211418c87254f0cbffa910fe8f105b7da92452487Stephen Hines return tgammaf(x); 5311418c87254f0cbffa910fe8f105b7da92452487Stephen Hines#endif 54d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray} 55d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray 56d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murrayuint32_t SC_abs_i32(int32_t v) {return abs(v);} 5787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 5887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixLoadRotate(Matrix4x4 *m, float rot, float x, float y, float z) { 5987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->loadRotate(rot, x, y, z); 6087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 6187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixLoadScale(Matrix4x4 *m, float x, float y, float z) { 6287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->loadScale(x, y, z); 6387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 6487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixLoadTranslate(Matrix4x4 *m, float x, float y, float z) { 6587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->loadTranslate(x, y, z); 6687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 6787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixRotate(Matrix4x4 *m, float rot, float x, float y, float z) { 6887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->rotate(rot, x, y, z); 6987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 7087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixScale(Matrix4x4 *m, float x, float y, float z) { 7187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->scale(x, y, z); 7287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 7387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixTranslate(Matrix4x4 *m, float x, float y, float z) { 7487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->translate(x, y, z); 7587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 7687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 7787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixLoadOrtho(Matrix4x4 *m, float l, float r, float b, float t, float n, float f) { 7887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->loadOrtho(l, r, b, t, n, f); 7987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 8087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixLoadFrustum(Matrix4x4 *m, float l, float r, float b, float t, float n, float f) { 8187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->loadFrustum(l, r, b, t, n, f); 8287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 8387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixLoadPerspective(Matrix4x4 *m, float fovy, float aspect, float near, float far) { 8487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->loadPerspective(fovy, aspect, near, far); 8587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 8687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 8787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic bool SC_MatrixInverse_4x4(Matrix4x4 *m) { 8887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams return m->inverse(); 8987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 9087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic bool SC_MatrixInverseTranspose_4x4(Matrix4x4 *m) { 9187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams return m->inverseTranspose(); 9287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 9387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixTranspose_4x4(Matrix4x4 *m) { 9487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->transpose(); 9587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 9687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixTranspose_3x3(Matrix3x3 *m) { 9787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->transpose(); 9887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 9987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic void SC_MatrixTranspose_2x2(Matrix2x2 *m) { 10087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams m->transpose(); 10187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 10287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 103b93cb42b4b8511d244ec8df4559fdc5c0b2de1bfStephen Hinesfloat SC_randf2(float min, float max) { 10487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams float r = (float)rand(); 105b8fa756a727b7816ed4a6c9f9dbadb548f7fa80fJason Sams r /= RAND_MAX; 10687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams r = r * (max - min) + min; 107b8fa756a727b7816ed4a6c9f9dbadb548f7fa80fJason Sams return r; 10887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 10987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 11087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Samsstatic float SC_frac(float v) { 11187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams int i = (int)floor(v); 11287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams return fmin(v - i, 0x1.fffffep-1f); 11387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 11487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 115d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray#ifdef RS_COMPATIBILITY_LIB 116d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(acosf) 117d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(acoshf) 118d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(asinf) 119d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(asinhf) 120d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(atanf) 121d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(atan2f) 122d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(atanhf) 123d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(cbrtf) 124d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(ceilf) 125d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(copysignf) 126d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(cosf) 127d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(coshf) 128d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(erfcf) 129d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(erff) 130d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(expf) 131d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(exp2f) 132d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(expm1f) 133d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(fdimf) 134d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(floorf) 135d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murrayfloat SC_fmaf(float u, float t, float v) {return fmaf(u, t, v);} 136d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(fmaxf) 137d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(fminf) 138d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(fmodf) 139d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murrayfloat SC_frexpf(float v, int* ptr) {return frexpf(v, ptr);} 140d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(hypotf) 141d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(ilogbf) 142d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murrayfloat SC_ldexpf(float v, int i) {return ldexpf(v, i);} 143d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(lgammaf) 144d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murrayfloat SC_lgammaf_r(float v, int* ptr) {return lgammaf_r(v, ptr);} 145d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(logf) 146d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(log10f) 147d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(log1pf) 148d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(logbf) 149d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murrayfloat SC_modff(float v, float* ptr) {return modff(v, ptr);} 150d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(nextafterf) 151d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(powf) 152d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32_F32(remainderf) 153d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murrayfloat SC_remquof(float t, float v, int* ptr) {return remquof(t, v, ptr);} 154d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(rintf) 155d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(roundf) 156d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(sinf) 157d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(sinhf) 158d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(sqrtf) 159d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(tanf) 160d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(tanhf) 161d6f1f46b2929ed56c73ba32357cde31b82972fbeTim MurrayEXPORT_F32_FN_F32(truncf) 162cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesfloat __attribute__((overloadable)) rsFrac(float f) { 163cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines return SC_frac(f); 164cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 165cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixLoadRotate(rs_matrix4x4 *m, 166cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float rot, float x, float y, float z) { 167cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixLoadRotate((Matrix4x4 *) m, rot, x, y, z); 168cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 169cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixLoadScale(rs_matrix4x4 *m, 170cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float x, float y, float z) { 171cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixLoadScale((Matrix4x4 *) m, x, y, z); 172cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 173cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixLoadTranslate(rs_matrix4x4 *m, 174cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float x, float y, float z) { 175cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixLoadTranslate((Matrix4x4 *) m, x, y, z); 176cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 177cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixRotate(rs_matrix4x4 *m, float rot, 178cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float x, float y, float z) { 179cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixRotate((Matrix4x4 *) m, rot, x, y, z); 180cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 181cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixScale(rs_matrix4x4 *m, float x, 182cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float y, float z) { 183cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixScale((Matrix4x4 *) m, x, y, z); 184cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 185cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixTranslate(rs_matrix4x4 *m, float x, 186cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float y, float z) { 187cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixTranslate((Matrix4x4 *) m, x, y, z); 188cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 189cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixLoadOrtho(rs_matrix4x4 *m, float l, 190cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float r, float b, float t, float n, float f) { 191cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixLoadOrtho((Matrix4x4 *) m, l, r, b, t, n, f); 192cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 193cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixLoadFrustum(rs_matrix4x4 *m, 194cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float l, float r, float b, float t, float n, float f) { 195cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixLoadFrustum((Matrix4x4 *) m, l, r, b, t, n, f); 196cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 197cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixLoadPerspective(rs_matrix4x4 *m, 198cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines float fovy, float aspect, float near, float far) { 199cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixLoadPerspective((Matrix4x4 *) m, fovy, aspect, near, far); 200cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 201cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesbool __attribute__((overloadable)) rsMatrixInverse(rs_matrix4x4 *m) { 202cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines return SC_MatrixInverse_4x4((Matrix4x4 *) m); 203cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 204cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesbool __attribute__((overloadable)) rsMatrixInverseTranspose(rs_matrix4x4 *m) { 205cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines return SC_MatrixInverseTranspose_4x4((Matrix4x4 *) m); 206cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 207cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixTranspose(rs_matrix4x4 *m) { 208cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixTranspose_4x4((Matrix4x4 *) m); 209cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 210cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixTranspose(rs_matrix3x3 *m) { 211cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixTranspose_3x3((Matrix3x3 *) m); 212cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 213cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hinesvoid __attribute__((overloadable)) rsMatrixTranspose(rs_matrix2x2 *m) { 214cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines SC_MatrixTranspose_2x2((Matrix2x2 *) m); 215cadee38f6940e5584d3ec3398a21bd2a494361e2Stephen Hines} 216d6f1f46b2929ed56c73ba32357cde31b82972fbeTim Murray#endif 21787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 21887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams////////////////////////////////////////////////////////////////////////////// 21987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// Class implementation 22087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams////////////////////////////////////////////////////////////////////////////// 22187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 22287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// llvm name mangling ref 22387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// <builtin-type> ::= v # void 22487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= b # bool 22587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= c # char 22687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= a # signed char 22787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= h # unsigned char 22887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= s # short 22987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= t # unsigned short 23087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= i # int 23187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= j # unsigned int 23287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= l # long 23387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= m # unsigned long 23487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= x # long long, __int64 23587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= y # unsigned long long, __int64 23687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= f # float 23787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams// ::= d # double 23887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 239709a0978ae141198018ca9769f8d96292a8928e6Jason Samsstatic RsdCpuReference::CpuSymbol gSyms[] = { 24087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4acosf", (void *)&acosf, true }, 24187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5acoshf", (void *)&acoshf, true }, 24287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4asinf", (void *)&asinf, true }, 24387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5asinhf", (void *)&asinhf, true }, 24487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4atanf", (void *)&atanf, true }, 24587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5atan2ff", (void *)&atan2f, true }, 24687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5atanhf", (void *)&atanhf, true }, 24787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4cbrtf", (void *)&cbrtf, true }, 24887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4ceilf", (void *)&ceilf, true }, 24987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z8copysignff", (void *)©signf, true }, 25087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z3cosf", (void *)&cosf, true }, 25187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4coshf", (void *)&coshf, true }, 25287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4erfcf", (void *)&erfcf, true }, 25387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z3erff", (void *)&erff, true }, 25487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z3expf", (void *)&expf, true }, 25587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4exp2f", (void *)&exp2f, true }, 2566a9cc720f106358880eb33f2ea48fe5f5d6d0c37Tim Murray { "exp2f", (void *)&exp2f, true }, 25787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5expm1f", (void *)&expm1f, true }, 25887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4fdimff", (void *)&fdimf, true }, 25987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5floorf", (void *)&floorf, true }, 26087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z3fmafff", (void *)&fmaf, true }, 26187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4fmaxff", (void *)&fmaxf, true }, 26287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4fminff", (void *)&fminf, true }, // float fmin(float, float) 26387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4fmodff", (void *)&fmodf, true }, 26487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5frexpfPi", (void *)&frexpf, true }, 26587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5hypotff", (void *)&hypotf, true }, 26687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5ilogbf", (void *)&ilogbf, true }, 26787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5ldexpfi", (void *)&ldexpf, true }, 26887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z6lgammaf", (void *)&lgammaf, true }, 26987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z6lgammafPi", (void *)&lgammaf_r, true }, 27087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z3logf", (void *)&logf, true }, 27187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5log10f", (void *)&log10f, true }, 27287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5log1pf", (void *)&log1pf, true }, 27387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4logbf", (void *)&logbf, true }, 27487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4modffPf", (void *)&modff, true }, 27587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams //{ "_Z3nanj", (void *)&SC_nan, true }, 27687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z9nextafterff", (void *)&nextafterf, true }, 27787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z3powff", (void *)&powf, true }, 27860fe47db884673ace2b41c6a037a376bbd0fd670Tim Murray { "powf", (void *)&powf, true }, 27987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z9remainderff", (void *)&remainderf, true }, 28087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z6remquoffPi", (void *)&remquof, true }, 28187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4rintf", (void *)&rintf, true }, 28287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5roundf", (void *)&roundf, true }, 28387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z3sinf", (void *)&sinf, true }, 28487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4sinhf", (void *)&sinhf, true }, 28587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4sqrtf", (void *)&sqrtf, true }, 28687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z3tanf", (void *)&tanf, true }, 28787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z4tanhf", (void *)&tanhf, true }, 28811418c87254f0cbffa910fe8f105b7da92452487Stephen Hines { "_Z6tgammaf", (void *)&SC_tgammaf, true }, 28987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z5truncf", (void *)&truncf, true }, 29087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 29187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams //{ "smoothstep", (void *)&, true }, 29287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 29387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams // matrix 29487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z18rsMatrixLoadRotateP12rs_matrix4x4ffff", (void *)&SC_MatrixLoadRotate, true }, 29587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z17rsMatrixLoadScaleP12rs_matrix4x4fff", (void *)&SC_MatrixLoadScale, true }, 29687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z21rsMatrixLoadTranslateP12rs_matrix4x4fff", (void *)&SC_MatrixLoadTranslate, true }, 29787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z14rsMatrixRotateP12rs_matrix4x4ffff", (void *)&SC_MatrixRotate, true }, 29887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z13rsMatrixScaleP12rs_matrix4x4fff", (void *)&SC_MatrixScale, true }, 29987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z17rsMatrixTranslateP12rs_matrix4x4fff", (void *)&SC_MatrixTranslate, true }, 30087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 30187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z17rsMatrixLoadOrthoP12rs_matrix4x4ffffff", (void *)&SC_MatrixLoadOrtho, true }, 30287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z19rsMatrixLoadFrustumP12rs_matrix4x4ffffff", (void *)&SC_MatrixLoadFrustum, true }, 30387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z23rsMatrixLoadPerspectiveP12rs_matrix4x4ffff", (void *)&SC_MatrixLoadPerspective, true }, 30487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 30587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z15rsMatrixInverseP12rs_matrix4x4", (void *)&SC_MatrixInverse_4x4, true }, 30687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z24rsMatrixInverseTransposeP12rs_matrix4x4", (void *)&SC_MatrixInverseTranspose_4x4, true }, 30787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z17rsMatrixTransposeP12rs_matrix4x4", (void *)&SC_MatrixTranspose_4x4, true }, 308c84b56e55737376b43a00531bffacae7d4716a31yuyan { "_Z17rsMatrixTransposeP12rs_matrix3x3", (void *)&SC_MatrixTranspose_3x3, true }, 309c84b56e55737376b43a00531bffacae7d4716a31yuyan { "_Z17rsMatrixTransposeP12rs_matrix2x2", (void *)&SC_MatrixTranspose_2x2, true }, 31087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 31187fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams // RS Math 31287fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z6rsRandff", (void *)&SC_randf2, true }, 31387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { "_Z6rsFracf", (void *)&SC_frac, true }, 31487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 31587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams { NULL, NULL, false } 31687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams}; 31787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 318709a0978ae141198018ca9769f8d96292a8928e6Jason Samsconst RsdCpuReference::CpuSymbol * RsdCpuScriptImpl::lookupSymbolMath(const char *sym) { 319709a0978ae141198018ca9769f8d96292a8928e6Jason Sams const RsdCpuReference::CpuSymbol *syms = gSyms; 32087fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 321709a0978ae141198018ca9769f8d96292a8928e6Jason Sams while (syms->fnPtr) { 322709a0978ae141198018ca9769f8d96292a8928e6Jason Sams if (!strcmp(syms->name, sym)) { 32387fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams return syms; 32487fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams } 32587fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams syms++; 32687fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams } 32787fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams return NULL; 32887fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams} 32987fe59a2f4d4c74539bfa0bff5f9a7e320e99415Jason Sams 330