/* * Copyright 2010, 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 BCC_SCRIPTCOMPILED_H #define BCC_SCRIPTCOMPILED_H #include "Compiler.h" #include "Script.h" #include <bcc/bcc.h> #include <list> #include <map> #include <string> #include <utility> #include <vector> namespace llvm { class Module; } namespace bcc { class ScriptCompiled { friend class Compiler; friend class CodeEmitter; private: typedef std::list<std::pair<std::string, std::string> > PragmaList; typedef std::list<void*> ExportVarList; typedef std::list<void*> ExportFuncList; typedef std::map<std::string, FuncInfo *> FuncInfoMap; typedef std::list<uint32_t> ObjectSlotList; private: Script *mpOwner; Compiler mCompiler; ExportVarList mExportVars; std::vector<std::string> mExportVarsName; std::vector<std::string> mExportFuncsName; ExportFuncList mExportFuncs; PragmaList mPragmas; ObjectSlotList mObjectSlots; FuncInfoMap mEmittedFunctions; #if USE_OLD_JIT char *mContext; // Context of BCC script (code and data) #endif public: ScriptCompiled(Script *owner) : mpOwner(owner), mCompiler(this) #if USE_OLD_JIT , mContext(NULL) #endif { } ~ScriptCompiled(); llvm::Module *parseBitcodeFile(llvm::MemoryBuffer *MEM) { return mCompiler.parseBitcodeFile(MEM); } int readModule(llvm::Module *module) { return mCompiler.readModule(module); } int linkModule(llvm::Module *module) { return mCompiler.linkModule(module); } int compile(bool compileOnly) { return mCompiler.compile(compileOnly); } char const *getCompilerErrorMessage() { return mCompiler.getErrorMessage(); } void *lookup(const char *name); size_t getExportVarCount() const { return mExportVars.size(); } size_t getExportFuncCount() const { return mExportFuncs.size(); } size_t getPragmaCount() const { return mPragmas.size(); } size_t getFuncCount() const { return mEmittedFunctions.size(); } size_t getObjectSlotCount() const { return mObjectSlots.size(); } void getExportVarList(size_t varListSize, void **varList); void getExportFuncList(size_t funcListSize, void **funcList); void getExportVarNameList(std::vector<std::string> &varList); void getExportFuncNameList(std::vector<std::string> &funcList); void getPragmaList(size_t pragmaListSize, char const **keyList, char const **valueList); void getFuncInfoList(size_t funcInfoListSize, FuncInfo *funcInfoList); void getObjectSlotList(size_t objectSlotListSize, uint32_t *objectSlotList); std::vector<char const *> const & getUserDefinedExternalSymbols() const { return mpOwner->getUserDefinedExternalSymbols(); } #if USE_OLD_JIT char *getContext() { return mContext; } #endif #if USE_MCJIT const char *getELF() const { return &*mCompiler.getELF().begin(); } size_t getELFSize() const { return mCompiler.getELF().size(); } #endif void registerSymbolCallback(BCCSymbolLookupFn pFn, void *pContext) { mCompiler.registerSymbolCallback(pFn, pContext); } }; } // namespace bcc #endif // BCC_SCRIPTCOMPILED_H