rsCpuScript.h revision 40e35cdbe217ec8bf9fc3c69873c7d62fc14158f
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
389ab5094dd32352b33e251e540934f6e814c5fa5bJean-Luc Brouilletnamespace bcinfo {
399ab5094dd32352b33e251e540934f6e814c5fa5bJean-Luc Brouillet    class MetadataExtractor;
409ab5094dd32352b33e251e540934f6e814c5fa5bJean-Luc Brouillet}
419ab5094dd32352b33e251e540934f6e814c5fa5bJean-Luc Brouillet
42709a0978ae141198018ca9769f8d96292a8928e6Jason Samsnamespace android {
43709a0978ae141198018ca9769f8d96292a8928e6Jason Samsnamespace renderscript {
44709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
45709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
46709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
47709a0978ae141198018ca9769f8d96292a8928e6Jason Samsclass RsdCpuScriptImpl : public RsdCpuReferenceImpl::CpuScript {
48709a0978ae141198018ca9769f8d96292a8928e6Jason Samspublic:
49709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    typedef void (*outer_foreach_t)(
50709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        const RsForEachStubParamStruct *,
51709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        uint32_t x1, uint32_t x2,
52709a0978ae141198018ca9769f8d96292a8928e6Jason Sams        uint32_t instep, uint32_t outstep);
53110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#ifdef RS_COMPATIBILITY_LIB
54110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    typedef void (* InvokeFunc_t)(void);
55110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    typedef void (* ForEachFunc_t)(void);
56110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    typedef int (* RootFunc_t)(void);
57110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    typedef void (*WorkerCallback_t)(void *usr, uint32_t idx);
58110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#endif
59709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
60709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bool init(char const *resName, char const *cacheDir,
61005113297b19ed256b6db9d6bc293ed9266899fcStephen Hines              uint8_t const *bitcode, size_t bitcodeSize, uint32_t flags,
62005113297b19ed256b6db9d6bc293ed9266899fcStephen Hines              char const *bccPluginName = NULL);
63709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void populateScript(Script *);
64709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
65709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void invokeFunction(uint32_t slot, const void *params, size_t paramLength);
66709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual int invokeRoot();
6717e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams    virtual void preLaunch(uint32_t slot, const Allocation * ain,
6817e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams                           Allocation * aout, const void * usr,
6917e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams                           uint32_t usrLen, const RsScriptCall *sc);
7017e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams    virtual void postLaunch(uint32_t slot, const Allocation * ain,
7117e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams                            Allocation * aout, const void * usr,
7217e3cdc24776d8fdbf1ce16287b9b4dcd516708fJason Sams                            uint32_t usrLen, const RsScriptCall *sc);
73709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void invokeForEach(uint32_t slot,
74709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       const Allocation * ain,
75709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       Allocation * aout,
76709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       const void * usr,
77709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       uint32_t usrLen,
78709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                       const RsScriptCall *sc);
79709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void invokeInit();
80709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void invokeFreeChildren();
81709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
82709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void setGlobalVar(uint32_t slot, const void *data, size_t dataLength);
839c64239ebbfa4170190ede812e69150035e008e0Tim Murray    virtual void getGlobalVar(uint32_t slot, void *data, size_t dataLength);
84709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void setGlobalVarWithElemDims(uint32_t slot, const void *data, size_t dataLength,
85ac8d146a41f18afad5314ac8af440d6aedbe20bfStephen Hines                                  const Element *e, const uint32_t *dims, size_t dimLength);
86709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void setGlobalBind(uint32_t slot, Allocation *data);
87709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void setGlobalObj(uint32_t slot, ObjectBase *data);
88709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
89709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
90709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual ~RsdCpuScriptImpl();
91709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    RsdCpuScriptImpl(RsdCpuReferenceImpl *ctx, const Script *s);
92709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
93709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    const Script * getScript() {return mScript;}
94709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
95709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    void forEachMtlsSetup(const Allocation * ain, Allocation * aout,
96709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                          const void * usr, uint32_t usrLen,
97709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                          const RsScriptCall *sc, MTLaunchStruct *mtls);
98709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual void forEachKernelSetup(uint32_t slot, MTLaunchStruct *mtls);
99709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
100709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
101709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    const RsdCpuReference::CpuSymbol * lookupSymbolMath(const char *sym);
102709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    static void * lookupRuntimeStub(void* pContext, char const* name);
103709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
104709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    virtual Allocation * getAllocationForPointer(const void *ptr) const;
105709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
106cadfac411e6690e39de36c4f9e94deb9b7d2d08eJason Sams#ifndef RS_COMPATIBILITY_LIB
107f218bf115af4ae4fd79adbb8842608b308a4cf07Stephen Hines    virtual  void * getRSExecutable() { return mExecutable; }
108cadfac411e6690e39de36c4f9e94deb9b7d2d08eJason Sams#endif
109709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
110709a0978ae141198018ca9769f8d96292a8928e6Jason Samsprotected:
111709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    RsdCpuReferenceImpl *mCtx;
112709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    const Script *mScript;
113709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
114110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#ifndef RS_COMPATIBILITY_LIB
11540e35cdbe217ec8bf9fc3c69873c7d62fc14158fJean-Luc Brouillet    // Returns the path to the core library we'll use.
11640e35cdbe217ec8bf9fc3c69873c7d62fc14158fJean-Luc Brouillet    const char* findCoreLib(const bcinfo::MetadataExtractor& bitCodeMetaData, const char* bitcode,
1179ab5094dd32352b33e251e540934f6e814c5fa5bJean-Luc Brouillet                            size_t bitcodeSize);
118709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    int (*mRoot)();
119709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    int (*mRootExpand)();
120709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    void (*mInit)();
121709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    void (*mFreeChildren)();
122709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
12329809d1f95d4cd4cbc6b2f9384b3321759691e13Tim Murray    std::vector<std::pair<const char *, uint32_t> > mExportedForEachFuncList;
12429809d1f95d4cd4cbc6b2f9384b3321759691e13Tim Murray
125709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bcc::BCCContext *mCompilerContext;
126709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bcc::RSCompilerDriver *mCompilerDriver;
12725e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines    bcc::CompilerRTSymbolResolver mCompilerRuntime;
12825e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines    bcc::LookupFunctionSymbolResolver<void *> mRSRuntime;
12925e3af55a43faddced1a9931574dfdc3cc8ad8fdStephen Hines    bcc::SymbolResolverProxy mResolver;
130709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bcc::RSExecutable *mExecutable;
131110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#else
132110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    void *mScriptSO;
133110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    RootFunc_t mRoot;
134110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    RootFunc_t mRootExpand;
135110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    InvokeFunc_t mInit;
136110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    InvokeFunc_t mFreeChildren;
137110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    InvokeFunc_t *mInvokeFunctions;
138110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    ForEachFunc_t *mForEachFunctions;
139110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams
140110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    void **mFieldAddress;
141110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    bool *mFieldIsObject;
142110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    uint32_t *mForEachSignatures;
143110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams
144110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    // for populate script
145110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    //int mVersionMajor;
146110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    //int mVersionMinor;
147110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    size_t mExportedVariableCount;
148110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams    size_t mExportedFunctionCount;
149110f181b7966212a36ef18016f9b81c7322d0a2fJason Sams#endif
150709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
151709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    Allocation **mBoundAllocs;
152709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    void * mIntrinsicData;
153709a0978ae141198018ca9769f8d96292a8928e6Jason Sams    bool mIsThreadable;
154709a0978ae141198018ca9769f8d96292a8928e6Jason Sams};
155709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
156709a0978ae141198018ca9769f8d96292a8928e6Jason SamsAllocation * rsdScriptGetAllocationForPointer(
157709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                        const Context *dc,
158709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                        const Script *script,
159709a0978ae141198018ca9769f8d96292a8928e6Jason Sams                        const void *);
160709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
161709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
162709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
163709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
164709a0978ae141198018ca9769f8d96292a8928e6Jason Sams}
165709a0978ae141198018ca9769f8d96292a8928e6Jason Sams
166709a0978ae141198018ca9769f8d96292a8928e6Jason Sams#endif
167