11#ifndef PROTEUS_JITENGINEDEVICE_H
12#define PROTEUS_JITENGINEDEVICE_H
30#include <llvm/ADT/SmallPtrSet.h>
31#include <llvm/ADT/SmallVector.h>
32#include <llvm/ADT/StringRef.h>
33#include <llvm/Analysis/CallGraph.h>
34#include <llvm/Analysis/TargetTransformInfo.h>
35#include <llvm/Bitcode/BitcodeWriter.h>
36#include <llvm/CodeGen/CommandFlags.h>
37#include <llvm/CodeGen/MachineModuleInfo.h>
38#include <llvm/Config/llvm-config.h>
39#include <llvm/Demangle/Demangle.h>
40#include <llvm/ExecutionEngine/Orc/ThreadSafeModule.h>
41#include <llvm/IR/Constants.h>
42#include <llvm/IR/GlobalVariable.h>
43#include <llvm/IR/Instruction.h>
44#include <llvm/IR/Instructions.h>
45#include <llvm/IR/LLVMContext.h>
46#include <llvm/IR/LegacyPassManager.h>
47#include <llvm/IR/Module.h>
48#include <llvm/IR/ReplaceConstant.h>
49#include <llvm/IR/Type.h>
50#include <llvm/IR/Verifier.h>
51#include <llvm/IRReader/IRReader.h>
52#include <llvm/Linker/Linker.h>
53#include <llvm/MC/TargetRegistry.h>
54#include <llvm/Object/ELFObjectFile.h>
55#include <llvm/Passes/PassBuilder.h>
56#include <llvm/Support/Error.h>
57#include <llvm/Support/MemoryBuffer.h>
58#include <llvm/Support/MemoryBufferRef.h>
59#include <llvm/Target/TargetMachine.h>
60#include <llvm/Transforms/IPO/Internalize.h>
61#include <llvm/Transforms/Utils/Cloning.h>
62#include <llvm/Transforms/Utils/ModuleUtils.h>
84 std::unique_ptr<LLVMContext> Ctx;
85 SmallVector<std::string> LinkedModuleIds;
87 std::optional<SmallVector<std::unique_ptr<Module>>> ExtractedModules;
88 std::optional<HashT> ExtractedModuleHash;
89 std::optional<CallGraph> ModuleCallGraph;
90 std::unique_ptr<MemoryBuffer> DeviceBinary;
91 std::unordered_map<std::string, GlobalVarInfo> VarNameToGlobalInfo;
97 SmallVector<std::string> &&LinkedModuleIds)
99 LinkedModuleIds(LinkedModuleIds), LinkedModule(nullptr),
100 ExtractedModules(
std::nullopt), ModuleCallGraph(
std::nullopt),
101 DeviceBinary(nullptr) {}
116 if (ExtractedModules->size() == 1) {
117 LinkedModule = ExtractedModules->front().get();
118 if (
auto E = LinkedModule->materializeAll())
125 auto GeneratedLinkedModule =
127 SmallVector<std::unique_ptr<Module>> NewExtractedModules;
128 NewExtractedModules.emplace_back(std::move(GeneratedLinkedModule));
131 LinkedModule = ExtractedModules->front().get();
135 <<
"getLinkedModule " << T.
elapsed() <<
" ms\n");
138 return *LinkedModule;
142 const SmallVector<std::reference_wrapper<Module>>
146 SmallVector<std::reference_wrapper<Module>> ModulesRef;
147 for (
auto &M : ExtractedModules.value())
148 ModulesRef.emplace_back(*M);
153 ExtractedModules = std::move(Modules);
161 return ExtractedModuleHash.value();
165 if (ExtractedModuleHash)
166 ExtractedModuleHash =
hashCombine(ExtractedModuleHash.value(), HashValue);
168 ExtractedModuleHash = HashValue;
172 if (!ModuleCallGraph.has_value()) {
175 ModuleCallGraph.emplace(CallGraph(*LinkedModule));
177 return ModuleCallGraph.value();
184 return DeviceBinary->getMemBufferRef();
187 DeviceBinary = std::move(DeviceBinaryBuffer);
191 LinkedModuleIds.push_back(
ModuleId);
195 const void *DeviceAddr, uint64_t
VarSize) {
196 auto KV = VarNameToGlobalInfo.emplace(
199 auto TraceOut = [&KV]() {
200 auto GlobalName = KV.first->first;
201 auto &GVI = KV.first->second;
204 raw_svector_ostream OS(S);
205 OS <<
"[GVarInfo]: " << GlobalName <<
" HAddr:" << GVI.HostAddr
206 <<
" DevAddr:" << GVI.DevAddr <<
" VarSize:" << GVI.VarSize <<
"\n";
216 return VarNameToGlobalInfo;
223 std::optional<void *> Kernel;
224 std::unique_ptr<LLVMContext> Ctx;
226 ArrayRef<RuntimeConstantInfo *> RCInfoArray;
227 std::optional<std::unique_ptr<Module>> ExtractedModule;
228 std::optional<std::unique_ptr<MemoryBuffer>> Bitcode;
229 std::optional<std::reference_wrapper<BinaryInfo>> BinInfo;
230 std::optional<HashT> StaticHash;
231 std::optional<SmallVector<std::pair<std::string, StringRef>>>
236 ArrayRef<RuntimeConstantInfo *> RCInfoArray)
239 Bitcode{
std::nullopt}, BinInfo(BinInfo),
240 LambdaCalleeInfo(
std::nullopt) {}
244 assert(
Kernel.has_value() &&
"Expected Kernel is inited");
248 const std::string &
getName()
const {
return Name; }
250 bool hasModule()
const {
return ExtractedModule.has_value(); }
251 Module &
getModule()
const {
return *ExtractedModule->get(); }
254 ExtractedModule = std::move(Mod);
258 void setBitcode(std::unique_ptr<MemoryBuffer> ExtractedBitcode) {
259 Bitcode = std::move(ExtractedBitcode);
261 MemoryBufferRef
getBitcode() {
return Bitcode.value()->getMemBufferRef(); }
266 StaticHash =
hash(Name);
267 StaticHash =
hashCombine(StaticHash.value(), ModuleHash);
273 SmallVector<std::pair<std::string, StringRef>> &&LambdaInfo) {
274 LambdaCalleeInfo = std::move(LambdaInfo);
288 void **KernelArgs, uint64_t ShmemSize,
291 std::pair<std::unique_ptr<Module>, std::unique_ptr<MemoryBuffer>>
294 std::unique_ptr<Module> KernelModule =
295 static_cast<ImplT &
>(*this).tryExtractKernelModule(BinInfo,
KernelName,
297 std::unique_ptr<MemoryBuffer> Bitcode =
nullptr;
304 static_cast<ImplT &
>(*this).extractModules(BinInfo);
306 std::unique_ptr<Module> KernelModuleTmp =
nullptr;
310 KernelModule = llvm::CloneModule(LinkedModule);
341 if (&KernelModule->getContext() != &Ctx) {
342 SmallVector<char> CloneBuffer;
343 raw_svector_ostream OS(CloneBuffer);
344 WriteBitcodeToFile(*KernelModule, OS);
345 StringRef CloneStr = StringRef(CloneBuffer.data(), CloneBuffer.size());
346 auto ExpectedKernelModule =
347 parseBitcodeFile(MemoryBufferRef{CloneStr,
KernelName}, Ctx);
348 if (
auto E = ExpectedKernelModule.takeError())
351 KernelModule = std::move(*ExpectedKernelModule);
352 Bitcode = MemoryBuffer::getMemBufferCopy(CloneStr);
356 SmallVector<char> BitcodeBuffer;
357 raw_svector_ostream OS(BitcodeBuffer);
358 WriteBitcodeToFile(*KernelModule, OS);
359 auto BitcodeStr = StringRef{BitcodeBuffer.data(), BitcodeBuffer.size()};
360 Bitcode = MemoryBuffer::getMemBufferCopy(BitcodeStr);
363 return std::make_pair(std::move(KernelModule), std::move(Bitcode));
389 KernelInfo.
setModule(std::move(KernelModule));
390 KernelInfo.
setBitcode(std::move(BitcodeBuffer));
392 <<
"Extract kernel module " << T.
elapsed() <<
" ms\n");
416 SmallVector<RuntimeConstant> &LambdaJitValuesVec) {
424 Module &KernelModule =
getModule(KernelInfo);
426 <<
"=== LAMBDA MATCHING\n"
427 <<
"Caller trigger " << KernelInfo.
getName() <<
" -> "
428 << demangle(KernelInfo.
getName()) <<
"\n");
430 SmallVector<std::pair<std::string, StringRef>> LambdaCalleeInfo;
431 for (
auto &F : KernelModule.getFunctionList()) {
433 <<
" Trying F " << demangle(F.getName().str()) <<
"\n ");
437 LambdaCalleeInfo.emplace_back(F.getName(),
438 OptionalMapIt.value()->first);
445 const SmallVector<RuntimeConstant> &Values =
447 LambdaJitValuesVec.insert(LambdaJitValuesVec.end(), Values.begin(),
460 "Expected non-null device address for global variable");
481 std::optional<std::reference_wrapper<JITKernelInfo>>
500 HashT ModuleHash =
static_cast<ImplT &
>(*this).getModuleHash(BinInfo);
513 for (
auto &[Handle, FatbinInfo] :
JitEngineInfo.FatbinaryMap) {
515 Handle,
reinterpret_cast<FatbinWrapperT *
>(FatbinInfo.FatbinWrapper),
516 FatbinInfo.ModuleId);
518 for (
auto &LinkedBin : FatbinInfo.LinkedBinaries)
520 Handle,
reinterpret_cast<FatbinWrapperT *
>(LinkedBin.FatbinWrapper),
523 for (
auto &
Func : FatbinInfo.Functions)
527 for (
auto &
Var : FatbinInfo.Vars)
538 std::make_unique<CompilerAsync>(
Config::get().ProteusAsyncThreads);
563template <
typename ImplT>
566 JITKernelInfo &KernelInfo, dim3 GridDim, dim3 BlockDim,
void **KernelArgs,
572 SmallVector<RuntimeConstant> RCVec =
573 getRuntimeConstantValues(KernelArgs, KernelInfo.
getRCInfoArray());
575 SmallVector<RuntimeConstant> LambdaJitValuesVec;
579 hash(getStaticHash(KernelInfo), RCVec, LambdaJitValuesVec, GridDim.x,
580 GridDim.y, GridDim.z, BlockDim.x, BlockDim.y, BlockDim.z);
583 CodeCache.lookup(HashValue);
593 std::string KernelMangled = (KernelInfo.
getName() + Suffix);
596 auto CompiledLib = CacheChain->lookup(HashValue);
599 relinkGlobalsObject(CompiledLib->ObjectModule->getMemBufferRef(),
600 BinInfo.getVarNameToGlobalInfo());
603 KernelMangled, CompiledLib->ObjectModule->getBufferStart(),
605 BinInfo.getVarNameToGlobalInfo());
607 CodeCache.insert(HashValue, KernelFunc, KernelInfo.
getName());
614 MemoryBufferRef KernelBitcode = getBitcode(KernelInfo);
615 std::unique_ptr<MemoryBuffer> ObjBuf =
nullptr;
620 if (!AsyncCompiler->isCompilationPending(HashValue)) {
625 KernelBitcode, HashValue, KernelInfo.
getName(), Suffix, BlockDim,
627 BinInfo.getVarNameToGlobalInfo(), GlobalLinkedBinaries, DeviceArch,
636 ObjBuf = AsyncCompiler->takeCompilationResult(
637 HashValue,
Config::get().ProteusAsyncTestBlocking);
640 KernelArgs, ShmemSize, Stream);
645 KernelBitcode, HashValue, KernelInfo.
getName(), Suffix, BlockDim,
647 BinInfo.getVarNameToGlobalInfo(), GlobalLinkedBinaries, DeviceArch,
657 KernelMangled, ObjBuf->getBufferStart(),
659 BinInfo.getVarNameToGlobalInfo());
661 CodeCache.insert(HashValue, KernelFunc, KernelInfo.
getName());
663 CacheChain->store(HashValue,
670template <
typename ImplT>
675 <<
"Register fatbinary Handle " << Handle <<
" FatbinWrapper "
677 <<
" ModuleId " <<
ModuleId <<
"\n");
682 SmallVector<std::string>{});
686 for (
int I = 0; Ptr !=
nullptr;
689 <<
"I " << I <<
" PrelinkedFatbin " << Ptr <<
"\n");
690 GlobalLinkedBinaries.insert(Ptr);
697 SmallVector<std::string>{
ModuleId});
709template <
typename ImplT>
714 <<
" To Handle " << Handle <<
"\n");
719 if (JITKernelInfoMap.contains(
Kernel)) {
721 <<
"Warning: duplicate register function for kernel " +
727 if (!HandleToBinaryInfo.count(Handle))
729 BinaryInfo &BinInfo = HandleToBinaryInfo[Handle];
732 <<
"Register function " <<
KernelName <<
" with binary handle "
735 JITKernelInfoMap[
Kernel] =
739template <
typename ImplT>
745 <<
" Binary " << (
void *)
FatbinWrapper->Binary <<
" ModuleId "
747 if (!HandleToBinaryInfo.count(Handle))
750 HandleToBinaryInfo[Handle].addModuleId(
ModuleId);
void const char * ModuleId
Definition CompilerInterfaceDevice.cpp:36
void * FatbinWrapper
Definition CompilerInterfaceDevice.cpp:35
const void const char * VarName
Definition CompilerInterfaceDevice.cpp:24
auto & JitEngineInfo
Definition CompilerInterfaceDevice.cpp:58
void char * KernelName
Definition CompilerInterfaceDevice.cpp:54
void * Kernel
Definition CompilerInterfaceDevice.cpp:54
const void const char uint64_t VarSize
Definition CompilerInterfaceDevice.cpp:25
const void * HostAddr
Definition CompilerInterfaceDevice.cpp:23
ArrayRef< RuntimeConstantInfo * > RCInfoArray
Definition CompilerInterfaceHost.cpp:26
#define PROTEUS_DBG(x)
Definition Debug.h:9
void getLambdaJitValues(StringRef FnName, SmallVector< RuntimeConstant > &LambdaJitValuesVec)
Definition JitEngineHost.cpp:178
#define TIMESCOPE(x)
Definition TimeTracing.h:59
#define PROTEUS_TIMER_OUTPUT(x)
Definition TimeTracing.h:54
Definition JitEngineDevice.h:81
FatbinWrapperT * getFatbinWrapper() const
Definition JitEngineDevice.h:103
void setExtractedModules(SmallVector< std::unique_ptr< Module > > &Modules)
Definition JitEngineDevice.h:152
std::unordered_map< std::string, GlobalVarInfo > & getVarNameToGlobalInfo()
Definition JitEngineDevice.h:215
MemoryBufferRef getDeviceBinary()
Definition JitEngineDevice.h:181
bool hasModuleHash() const
Definition JitEngineDevice.h:156
std::unique_ptr< LLVMContext > & getLLVMContext()
Definition JitEngineDevice.h:105
Module & getLinkedModule()
Definition JitEngineDevice.h:108
auto & getModuleIds()
Definition JitEngineDevice.h:219
bool hasLinkedModule() const
Definition JitEngineDevice.h:107
bool hasDeviceBinary()
Definition JitEngineDevice.h:180
const SmallVector< std::reference_wrapper< Module > > getExtractedModules() const
Definition JitEngineDevice.h:143
void updateModuleHash(HashT HashValue)
Definition JitEngineDevice.h:164
HashT getModuleHash() const
Definition JitEngineDevice.h:157
void insertGlobalVar(const char *VarName, const void *HostAddr, const void *DeviceAddr, uint64_t VarSize)
Definition JitEngineDevice.h:194
bool hasExtractedModules() const
Definition JitEngineDevice.h:141
void addModuleId(const char *ModuleId)
Definition JitEngineDevice.h:190
CallGraph & getCallGraph()
Definition JitEngineDevice.h:171
BinaryInfo(FatbinWrapperT *FatbinWrapper, SmallVector< std::string > &&LinkedModuleIds)
Definition JitEngineDevice.h:96
void setModuleHash(HashT HashValue)
Definition JitEngineDevice.h:163
void setDeviceBinary(std::unique_ptr< MemoryBuffer > DeviceBinaryBuffer)
Definition JitEngineDevice.h:186
Definition CompilationTask.h:19
std::unique_ptr< MemoryBuffer > compile(CompilationTask &&CT)
Definition CompilerSync.h:21
static CompilerSync & instance()
Definition CompilerSync.h:16
static Config & get()
Definition Config.h:334
bool ProteusRelinkGlobalsByCopy
Definition Config.h:343
bool ProteusDumpLLVMIR
Definition Config.h:342
const CodeGenerationConfig & getCGConfig(llvm::StringRef KName="") const
Definition Config.h:357
std::string toString() const
Definition Hashing.h:29
std::string toMangledSuffix() const
Definition Hashing.h:32
Definition JitEngineDevice.h:222
bool hasBitcode()
Definition JitEngineDevice.h:257
const std::string & getName() const
Definition JitEngineDevice.h:248
void createStaticHash(HashT ModuleHash)
Definition JitEngineDevice.h:265
JITKernelInfo(void *Kernel, BinaryInfo &BinInfo, char const *Name, ArrayRef< RuntimeConstantInfo * > RCInfoArray)
Definition JitEngineDevice.h:235
void * getKernel() const
Definition JitEngineDevice.h:243
bool hasModule() const
Definition JitEngineDevice.h:250
const HashT getStaticHash() const
Definition JitEngineDevice.h:264
BinaryInfo & getBinaryInfo() const
Definition JitEngineDevice.h:252
ArrayRef< RuntimeConstantInfo * > getRCInfoArray() const
Definition JitEngineDevice.h:249
Module & getModule() const
Definition JitEngineDevice.h:251
void setModule(std::unique_ptr< llvm::Module > Mod)
Definition JitEngineDevice.h:253
void setLambdaCalleeInfo(SmallVector< std::pair< std::string, StringRef > > &&LambdaInfo)
Definition JitEngineDevice.h:272
const auto & getLambdaCalleeInfo()
Definition JitEngineDevice.h:271
bool hasLambdaCalleeInfo()
Definition JitEngineDevice.h:270
MemoryBufferRef getBitcode()
Definition JitEngineDevice.h:261
bool hasStaticHash() const
Definition JitEngineDevice.h:263
std::unique_ptr< LLVMContext > & getLLVMContext()
Definition JitEngineDevice.h:247
void setBitcode(std::unique_ptr< MemoryBuffer > ExtractedBitcode)
Definition JitEngineDevice.h:258
Definition JitEngineDevice.h:280
MemoryBufferRef getBitcode(JITKernelInfo &KernelInfo)
Definition JitEngineDevice.h:405
~JitEngineDevice()
Definition JitEngineDevice.h:541
typename DeviceTraits< ImplT >::DeviceError_t DeviceError_t
Definition JitEngineDevice.h:282
void extractModuleAndBitcode(JITKernelInfo &KernelInfo)
Definition JitEngineDevice.h:366
JitEngineDevice()
Definition JitEngineDevice.h:510
std::unique_ptr< CompilerAsync > AsyncCompiler
Definition JitEngineDevice.h:560
std::unordered_map< const void *, BinaryInfo > HandleToBinaryInfo
Definition JitEngineDevice.h:474
DenseMap< const void *, JITKernelInfo > JITKernelInfoMap
Definition JitEngineDevice.h:559
typename DeviceTraits< ImplT >::DeviceStream_t DeviceStream_t
Definition JitEngineDevice.h:283
void finalizeRegistration()
Definition JitEngineDevice.h:701
MemoryCache< KernelFunction_t > CodeCache
Definition JitEngineDevice.h:555
Module & getModule(JITKernelInfo &KernelInfo)
Definition JitEngineDevice.h:395
bool containsJITKernelInfo(const void *Func)
Definition JitEngineDevice.h:477
std::optional< std::reference_wrapper< JITKernelInfo > > getJITKernelInfo(const void *Func)
Definition JitEngineDevice.h:482
std::pair< std::unique_ptr< Module >, std::unique_ptr< MemoryBuffer > > extractKernelModule(BinaryInfo &BinInfo, StringRef KernelName, LLVMContext &Ctx)
Definition JitEngineDevice.h:292
SmallPtrSet< void *, 8 > GlobalLinkedBinaries
Definition JitEngineDevice.h:475
void registerFunction(void *Handle, void *Kernel, char *KernelName, ArrayRef< RuntimeConstantInfo * > RCInfoArray)
Definition JitEngineDevice.h:710
std::optional< ObjectCacheChain > CacheChain
Definition JitEngineDevice.h:556
void registerFatBinary(void *Handle, FatbinWrapperT *FatbinWrapper, const char *ModuleId)
Definition JitEngineDevice.h:671
DeviceError_t compileAndRun(JITKernelInfo &KernelInfo, dim3 GridDim, dim3 BlockDim, void **KernelArgs, uint64_t ShmemSize, typename DeviceTraits< ImplT >::DeviceStream_t Stream)
Definition JitEngineDevice.h:565
void registerLinkedBinary(void *Handle, FatbinWrapperT *FatbinWrapper, const char *ModuleId)
Definition JitEngineDevice.h:740
std::unordered_map< std::string, FatbinWrapperT * > ModuleIdToFatBinary
Definition JitEngineDevice.h:473
typename DeviceTraits< ImplT >::KernelFunction_t KernelFunction_t
Definition JitEngineDevice.h:284
StringRef getDeviceArch() const
Definition JitEngineDevice.h:507
void registerVar(void *Handle, const char *VarName, const void *HostAddr, uint64_t VarSize)
Definition JitEngineDevice.h:452
std::string DeviceArch
Definition JitEngineDevice.h:557
HashT getStaticHash(JITKernelInfo &KernelInfo)
Definition JitEngineDevice.h:489
void getLambdaJitValues(JITKernelInfo &KernelInfo, SmallVector< RuntimeConstant > &LambdaJitValuesVec)
Definition JitEngineDevice.h:415
static JitEngineInfoRegistry & instance()
Definition JitEngineInfoRegistry.h:58
Definition JitEngine.h:32
Definition LambdaRegistry.h:19
std::optional< DenseMap< StringRef, SmallVector< RuntimeConstant > >::iterator > matchJitVariableMap(StringRef FnName)
Definition LambdaRegistry.h:27
const SmallVector< RuntimeConstant > & getJitVariables(StringRef LambdaTypeRef)
Definition LambdaRegistry.h:93
static LambdaRegistry & instance()
Definition LambdaRegistry.h:21
bool empty()
Definition LambdaRegistry.h:97
static llvm::raw_ostream & outs(const std::string &Name)
Definition Logger.h:25
static void trace(llvm::StringRef Msg)
Definition Logger.h:30
static llvm::raw_ostream & logs(const std::string &Name)
Definition Logger.h:19
Definition MemoryCache.h:30
void printStats()
Definition MemoryCache.h:61
void printKernelTrace()
Definition MemoryCache.h:74
Definition TimeTracing.h:40
uint64_t elapsed()
Definition TimeTracing.cpp:51
Definition CompiledLibrary.h:7
Definition MemoryCache.h:26
std::unique_ptr< Module > cloneKernelFromModules(ArrayRef< std::reference_wrapper< Module > > Mods, StringRef EntryName, function_ref< bool(const GlobalValue *)> ShouldCloneDefinition=nullptr)
Definition Cloning.h:513
HashT hash(FirstT &&First, RestTs &&...Rest)
Definition Hashing.h:142
void reportFatalError(const llvm::Twine &Reason, const char *FILE, unsigned Line)
Definition Error.cpp:14
cudaError_t launchKernelDirect(void *KernelFunc, dim3 GridDim, dim3 BlockDim, void **KernelArgs, uint64_t ShmemSize, CUstream Stream)
Definition CoreDeviceCUDA.h:38
cudaError_t launchKernelFunction(CUfunction KernelFunc, dim3 GridDim, dim3 BlockDim, void **KernelArgs, uint64_t ShmemSize, CUstream Stream)
Definition CoreDeviceCUDA.h:78
HashT hashCombine(HashT A, HashT B)
Definition Hashing.h:137
std::string toString(CodegenOption Option)
Definition Config.h:28
void * resolveDeviceGlobalAddr(const void *Addr)
Definition CoreDeviceCUDA.h:26
void internalize(Module &M, StringRef PreserveFunctionName)
Definition CoreLLVM.h:288
CUfunction getKernelFunctionFromImage(StringRef KernelName, const void *Image, bool RelinkGlobalsByCopy, const std::unordered_map< std::string, GlobalVarInfo > &VarNameToGlobalInfo)
Definition CoreDeviceCUDA.h:50
void runCleanupPassPipeline(Module &M)
Definition CoreLLVM.h:230
std::unique_ptr< Module > linkModules(LLVMContext &Ctx, SmallVector< std::unique_ptr< Module > > LinkedModules)
Definition CoreLLVM.h:213
static CacheEntry staticObject(MemoryBufferRef Buf)
Definition ObjectCache.h:31
Definition JitEngineDevice.h:278
Definition JitEngineDevice.h:74
const char * Binary
Definition JitEngineDevice.h:77
void ** PrelinkedFatbins
Definition JitEngineDevice.h:78
int32_t Magic
Definition JitEngineDevice.h:75
int32_t Version
Definition JitEngineDevice.h:76
Definition GlobalVarInfo.h:5