RSCompilerDriver.h revision f2ac3176c351cd80bce77fe1488f3de2d0789c1b
1/*
2 * Copyright 2012, The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 *     http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef BCC_RS_COMPILER_DRIVER_H
18#define BCC_RS_COMPILER_DRIVER_H
19
20#include "bcc/ExecutionEngine/CompilerRTSymbolResolver.h"
21#include "bcc/ExecutionEngine/SymbolResolvers.h"
22#include "bcc/ExecutionEngine/SymbolResolverProxy.h"
23#include "bcc/Renderscript/RSInfo.h"
24#include "bcc/Renderscript/RSCompiler.h"
25#include "bcc/Renderscript/RSScript.h"
26
27namespace bcc {
28
29class BCCContext;
30class CompilerConfig;
31class RSCompilerDriver;
32class RSExecutable;
33
34// Type signature for dynamically loaded initialization of an RSCompilerDriver.
35typedef void (*RSCompilerDriverInit_t) (bcc::RSCompilerDriver *);
36// Name of the function that we attempt to dynamically load/execute.
37#define RS_COMPILER_DRIVER_INIT_FN rsCompilerDriverInit
38
39class RSCompilerDriver {
40private:
41  CompilerConfig *mConfig;
42  RSCompiler mCompiler;
43
44  // Are we compiling under an RS debug context with additional checks?
45  bool mDebugContext;
46
47  // Callback before linking with the runtime library.
48  RSLinkRuntimeCallback mLinkRuntimeCallback;
49
50  // Do we merge global variables on ARM using LLVM's optimization pass?
51  // Disabling LLVM's global merge pass allows static globals to be correctly
52  // emitted to ELF. This can result in decreased performance due to increased
53  // register pressure, but it does make the resulting code easier to debug
54  // and work with.
55  bool mEnableGlobalMerge;
56
57  // Setup the compiler config for the given script. Return true if mConfig has
58  // been changed and false if it remains unchanged.
59  bool setupConfig(const RSScript &pScript);
60
61  // Compiles the provided bitcode, placing the binary at pOutputPath.
62  // - If saveInfoFile is true, it also stores the RSInfo data in a file with a path derived from
63  //   pOutputPath.
64  // - pSourceHash and commandLineToEmbed are values to embed in the RSInfo for future cache
65  //   invalidation decision.
66  // - If pDumpIR is true, a ".ll" file will also be created.
67  Compiler::ErrorCode compileScript(RSScript& pScript, const char* pScriptName,
68                                    const char* pOutputPath, const char* pRuntimePath,
69                                    const RSInfo::DependencyHashTy& pSourceHash,
70                                    const char* commandLineToEmbed, bool saveInfoFile, bool pDumpIR);
71
72public:
73  RSCompilerDriver(bool pUseCompilerRT = true);
74  ~RSCompilerDriver();
75
76  RSCompiler *getCompiler() {
77    return &mCompiler;
78  }
79
80  void setConfig(CompilerConfig *config) {
81    mConfig = config;
82  }
83
84  void setDebugContext(bool v) {
85    mDebugContext = v;
86  }
87
88  void setLinkRuntimeCallback(RSLinkRuntimeCallback c) {
89    mLinkRuntimeCallback = c;
90  }
91
92  RSLinkRuntimeCallback getLinkRuntimeCallback() const {
93    return mLinkRuntimeCallback;
94  }
95
96  // This function enables/disables merging of global static variables.
97  // Note that it only takes effect on ARM architectures (other architectures
98  // do not offer this option).
99  void setEnableGlobalMerge(bool v) {
100    mEnableGlobalMerge = v;
101  }
102
103  bool getEnableGlobalMerge() const {
104    return mEnableGlobalMerge;
105  }
106
107  // FIXME: This method accompany with loadScript and compileScript should
108  //        all be const-methods. They're not now because the getAddress() in
109  //        SymbolResolverInterface is not a const-method.
110  // Returns true if script is successfully compiled.
111  bool build(BCCContext& pContext, const char* pCacheDir, const char* pResName,
112             const char* pBitcode, size_t pBitcodeSize, const char* commandLine,
113             const char* pRuntimePath, RSLinkRuntimeCallback pLinkRuntimeCallback = NULL,
114             bool pDumpIR = false);
115
116  // Returns true if script is successfully compiled.
117  bool buildForCompatLib(RSScript &pScript, const char *pOut, const char *pRuntimePath);
118
119  // Tries to load the the compiled bit code at pCacheDir of the given name.  It checks that
120  // the file has been compiled from the same bit code and with the same compile arguments as
121  // provided.
122  static RSExecutable* loadScript(const char* pCacheDir, const char* pResName, const char* pBitcode,
123                                  size_t pBitcodeSize, const char* expectedCompileCommandLine,
124                                  SymbolResolverProxy& pResolver);
125};
126
127} // end namespace bcc
128
129#endif // BCC_RS_COMPILER_DRIVER_H
130