rsCpuScript.h revision 29809d1f95d4cd4cbc6b2f9384b3321759691e13
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#ifndef RSD_BCC_H
18709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#define RSD_BCC_H
19709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
20709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include <rs_hal.h>
21709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include <rsRuntime.h>
22709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
2325e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines#ifndef RS_COMPATIBILITY_LIB
2425e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines#include <bcc/ExecutionEngine/CompilerRTSymbolResolver.h>
2525e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines#include <bcc/ExecutionEngine/SymbolResolverProxy.h>
2629809d1f95d4cd4cbc6b2f9384b3321759691e13Tim Murray#include <vector>
2729809d1f95d4cd4cbc6b2f9384b3321759691e13Tim Murray#include <utility>
2825e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines#endif
2925e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines
30709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#include "rsCpuCore.h"
31709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
32709a0978ae141198018ca9769f8d96292a8928e6Jason Samsnamespace bcc {
33709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    class BCCContext;
34709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    class RSCompilerDriver;
35709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    class RSExecutable;
36709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
37709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
38709a0978ae141198018ca9769f8d96292a8928e6Jason Samsnamespace android {
39709a0978ae141198018ca9769f8d96292a8928e6Jason Samsnamespace renderscript {
40709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
41709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
42709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
43709a0978ae141198018ca9769f8d96292a8928e6Jason Samsclass RsdCpuScriptImpl : public RsdCpuReferenceImpl::CpuScript {
44709a0978ae141198018ca9769f8d96292a8928e6Jason Samspublic:
45709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    typedef void (*outer_foreach_t)(
46709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        const RsForEachStubParamStruct *,
47709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        uint32_t x1, uint32_t x2,
48709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        uint32_t instep, uint32_t outstep);
49110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#ifdef RS_COMPATIBILITY_LIB
50110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    typedef void (* InvokeFunc_t)(void);
51110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    typedef void (* ForEachFunc_t)(void);
52110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    typedef int (* RootFunc_t)(void);
53110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    typedef void (*WorkerCallback_t)(void *usr, uint32_t idx);
54110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#endif
55709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
56709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bool init(char const *resName, char const *cacheDir,
57005113297b19ed256b6db9d6bc293ed9266899fcStephen Hines              uint8_t const *bitcode, size_t bitcodeSize, uint32_t flags,
58005113297b19ed256b6db9d6bc293ed9266899fcStephen Hines              char const *bccPluginName = NULL);
59709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void populateScript(Script *);
60709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
61709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void invokeFunction(uint32_t slot, const void *params, size_t paramLength);
62709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual int invokeRoot();
6317e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams    virtual void preLaunch(uint32_t slot, const Allocation * ain,
6417e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams                           Allocation * aout, const void * usr,
6517e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams                           uint32_t usrLen, const RsScriptCall *sc);
6617e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams    virtual void postLaunch(uint32_t slot, const Allocation * ain,
6717e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams                            Allocation * aout, const void * usr,
6817e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams                            uint32_t usrLen, const RsScriptCall *sc);
69709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void invokeForEach(uint32_t slot,
70709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       const Allocation * ain,
71709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       Allocation * aout,
72709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       const void * usr,
73709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       uint32_t usrLen,
74709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       const RsScriptCall *sc);
75709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void invokeInit();
76709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void invokeFreeChildren();
77709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
78709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void setGlobalVar(uint32_t slot, const void *data, size_t dataLength);
799c64239ebbfa4170190ede812e69150035e008e0Tim Murray    virtual void getGlobalVar(uint32_t slot, void *data, size_t dataLength);
80709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void setGlobalVarWithElemDims(uint32_t slot, const void *data, size_t dataLength,
81709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                                  const Element *e, const size_t *dims, size_t dimLength);
82709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void setGlobalBind(uint32_t slot, Allocation *data);
83709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void setGlobalObj(uint32_t slot, ObjectBase *data);
84709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
85709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
86709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual ~RsdCpuScriptImpl();
87709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    RsdCpuScriptImpl(RsdCpuReferenceImpl *ctx, const Script *s);
88709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
89709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    const Script * getScript() {return mScript;}
90709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
91709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    void forEachMtlsSetup(const Allocation * ain, Allocation * aout,
92709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                          const void * usr, uint32_t usrLen,
93709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                          const RsScriptCall *sc, MTLaunchStruct *mtls);
94709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void forEachKernelSetup(uint32_t slot, MTLaunchStruct *mtls);
95709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
96709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
97709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    const RsdCpuReference::CpuSymbol * lookupSymbolMath(const char *sym);
98709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    static void * lookupRuntimeStub(void* pContext, char const* name);
99709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
100709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual Allocation * getAllocationForPointer(const void *ptr) const;
101709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
102e195a3f57ace3b66d313a6ee88c6e93d5c9d87f4Tim Murray#ifndef FAKE_ARM64_BUILD
103cadfac411e6690e39de36c4f9e94deb9b7d2d08eJason Sams#ifndef RS_COMPATIBILITY_LIB
104f218bf115af4ae4fd79adbb8842608b308a4cf07Stephen Hines    virtual  void * getRSExecutable() { return mExecutable; }
105cadfac411e6690e39de36c4f9e94deb9b7d2d08eJason Sams#endif
106e195a3f57ace3b66d313a6ee88c6e93d5c9d87f4Tim Murray#else
107e195a3f57ace3b66d313a6ee88c6e93d5c9d87f4Tim Murray    virtual void* getRSExecutable() { return NULL; }
108e195a3f57ace3b66d313a6ee88c6e93d5c9d87f4Tim Murray#endif
109709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
110709a0978ae141198018ca9769f8d96292a8928e6Jason Samsprotected:
111709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    RsdCpuReferenceImpl *mCtx;
112709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    const Script *mScript;
113709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
114e195a3f57ace3b66d313a6ee88c6e93d5c9d87f4Tim Murray#ifndef FAKE_ARM64_BUILD
115110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#ifndef RS_COMPATIBILITY_LIB
116709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    int (*mRoot)();
117709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    int (*mRootExpand)();
118709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    void (*mInit)();
119709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    void (*mFreeChildren)();
120709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
12129809d1f95d4cd4cbc6b2f9384b3321759691e13Tim Murray    std::vector<std::pair<const char *, uint32_t> > mExportedForEachFuncList;
12229809d1f95d4cd4cbc6b2f9384b3321759691e13Tim Murray
123709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bcc::BCCContext *mCompilerContext;
124709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bcc::RSCompilerDriver *mCompilerDriver;
12525e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines    bcc::CompilerRTSymbolResolver mCompilerRuntime;
12625e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines    bcc::LookupFunctionSymbolResolver<void *> mRSRuntime;
12725e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines    bcc::SymbolResolverProxy mResolver;
128709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bcc::RSExecutable *mExecutable;
129110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#else
130110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    void *mScriptSO;
131110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    RootFunc_t mRoot;
132110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    RootFunc_t mRootExpand;
133110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    InvokeFunc_t mInit;
134110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    InvokeFunc_t mFreeChildren;
135110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    InvokeFunc_t *mInvokeFunctions;
136110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    ForEachFunc_t *mForEachFunctions;
137110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams
138110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    void **mFieldAddress;
139110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    bool *mFieldIsObject;
140110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    uint32_t *mForEachSignatures;
141110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams
142110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    // for populate script
143110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    //int mVersionMajor;
144110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    //int mVersionMinor;
145110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    size_t mExportedVariableCount;
146110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    size_t mExportedFunctionCount;
147110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#endif
148e195a3f57ace3b66d313a6ee88c6e93d5c9d87f4Tim Murray#endif
149709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
150709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    Allocation **mBoundAllocs;
151709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    void * mIntrinsicData;
152709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bool mIsThreadable;
153709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
154709a0978ae141198018ca9769f8d96292a8928e6Jason Sams};
155709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
156709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
157709a0978ae141198018ca9769f8d96292a8928e6Jason SamsAllocation * rsdScriptGetAllocationForPointer(
158709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                        const Context *dc,
159709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                        const Script *script,
160709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                        const void *);
161709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
162709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
163709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
164709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
165709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
166709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
167709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#endif
168