/*
* Copyright (C) 2011-2012 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef RSD_CPU_SCRIPT_H
#define RSD_CPU_SCRIPT_H
#include <rs_hal.h>
#include <rsRuntime.h>
#ifndef RS_COMPATIBILITY_LIB
#include <utility>
#endif
#include "rsCpuCore.h"
#include <string>
namespace bcinfo {
class MetadataExtractor;
} // namespace bcinfo
namespace android {
namespace renderscript {
class ScriptExecutable;
class RsdCpuScriptImpl : public RsdCpuReferenceImpl::CpuScript {
public:
bool init(char const *resName, char const *cacheDir,
uint8_t const *bitcode, size_t bitcodeSize, uint32_t flags,
char const *bccPluginName = nullptr);
void populateScript(Script *) override;
void invokeFunction(uint32_t slot, const void *params, size_t paramLength) override;
int invokeRoot() override;
virtual void preLaunch(uint32_t slot, const Allocation ** ains,
uint32_t inLen, Allocation * aout, const void * usr,
uint32_t usrLen, const RsScriptCall *sc);
virtual void postLaunch(uint32_t slot, const Allocation ** ains,
uint32_t inLen, Allocation * aout,
const void * usr, uint32_t usrLen,
const RsScriptCall *sc);
void invokeForEach(uint32_t slot,
const Allocation ** ains,
uint32_t inLen,
Allocation* aout,
const void* usr,
uint32_t usrLen,
const RsScriptCall* sc) override;
void invokeReduce(uint32_t slot,
const Allocation ** ains, uint32_t inLen,
Allocation* aout,
const RsScriptCall* sc) override;
void invokeInit() override;
void invokeFreeChildren() override;
void setGlobalVar(uint32_t slot, const void *data, size_t dataLength) override;
void getGlobalVar(uint32_t slot, void *data, size_t dataLength) override;
void setGlobalVarWithElemDims(uint32_t slot, const void *data, size_t dataLength,
const Element *e, const uint32_t *dims,
size_t dimLength) override;
void setGlobalBind(uint32_t slot, Allocation *data) override;
void setGlobalObj(uint32_t slot, ObjectBase *data) override;
const char* getFieldName(uint32_t slot) const;
~RsdCpuScriptImpl() override;
RsdCpuScriptImpl(RsdCpuReferenceImpl *ctx, const Script *s);
const Script * getScript() {return mScript;}
bool forEachMtlsSetup(const Allocation ** ains, uint32_t inLen,
Allocation * aout, const void * usr, uint32_t usrLen,
const RsScriptCall *sc, MTLaunchStructForEach *mtls);
virtual void forEachKernelSetup(uint32_t slot, MTLaunchStructForEach *mtls);
// Build an MTLaunchStruct suitable for launching a general reduce-style kernel.
bool reduceMtlsSetup(const Allocation ** ains, uint32_t inLen, const Allocation *aout,
const RsScriptCall *sc, MTLaunchStructReduce *mtls);
// Finalize an MTLaunchStruct for launching a general reduce-style kernel.
virtual void reduceKernelSetup(uint32_t slot, MTLaunchStructReduce *mtls);
const RsdCpuReference::CpuSymbol * lookupSymbolMath(const char *sym);
static void * lookupRuntimeStub(void* pContext, char const* name);
Allocation * getAllocationForPointer(const void *ptr) const override;
bool storeRSInfoFromSO();
int getGlobalEntries() const override;
const char * getGlobalName(int i) const override;
const void * getGlobalAddress(int i) const override;
size_t getGlobalSize(int i) const override;
uint32_t getGlobalProperties(int i) const override;
protected:
RsdCpuReferenceImpl *mCtx;
const Script *mScript;
void *mScriptSO;
#ifndef RS_COMPATIBILITY_LIB
// Returns the path to the core library we'll use.
const char* findCoreLib(const bcinfo::MetadataExtractor& bitCodeMetaData, const char* bitcode,
size_t bitcodeSize);
#endif
RootFunc_t mRoot;
RootFunc_t mRootExpand;
InitOrDtorFunc_t mInit;
InitOrDtorFunc_t mFreeChildren;
ScriptExecutable* mScriptExec;
Allocation **mBoundAllocs;
void * mIntrinsicData;
bool mIsThreadable;
public:
static const char* BCC_EXE_PATH;
const char* getBitcodeFilePath() const { return mBitcodeFilePath.c_str(); }
private:
bool setUpMtlsDimensions(MTLaunchStructCommon *mtls,
const RsLaunchDimensions &baseDim,
const RsScriptCall *sc);
std::string mBitcodeFilePath;
uint32_t mBuildChecksum;
bool mChecksumNeeded;
};
Allocation * rsdScriptGetAllocationForPointer(
const Context *dc,
const Script *script,
const void *);
uint32_t constructBuildChecksum(uint8_t const *bitcode, size_t bitcodeSize,
const char *commandLine,
const char ** bccFiles, size_t numFiles);
} // namespace renderscript
#ifdef __LP64__
#define SYSLIBPATH "/system/lib64"
#define SYSLIBPATH_BC "/system/lib64"
#define SYSLIBPATH_VENDOR "/system/vendor/lib64"
#elif defined(BUILD_ARM_FOR_X86) && defined(__arm__)
#define SYSLIBPATH "/system/lib/arm"
#define SYSLIBPATH_BC "/system/lib"
#define SYSLIBPATH_VENDOR "/system/vendor/lib/arm"
#else
#define SYSLIBPATH "/system/lib"
#define SYSLIBPATH_BC "/system/lib"
#define SYSLIBPATH_VENDOR "/system/vendor/lib"
#endif
} // namespace android
namespace {
inline bool is_force_recompile() {
char buf[PROP_VALUE_MAX];
// Re-compile if floating point precision has been overridden.
android::renderscript::property_get("debug.rs.precision", buf, "");
if (buf[0] != '\0') {
return true;
}
// Re-compile if debug.rs.forcerecompile is set.
android::renderscript::property_get("debug.rs.forcerecompile", buf, "0");
if ((::strcmp(buf, "1") == 0) || (::strcmp(buf, "true") == 0)) {
return true;
} else {
return false;
}
}
} // anonymous namespace
#endif // RSD_CPU_SCRIPT_H