11#ifndef PROTEUS_JITCACHE_HPP
12#define PROTEUS_JITCACHE_HPP
23#include <llvm/ADT/DenseMap.h>
24#include <llvm/ADT/SmallVector.h>
25#include <llvm/ADT/StringRef.h>
26#include <llvm/Config/llvm-config.h>
38 auto It = CacheMap.find(HashValue);
39 if (It == CacheMap.end())
42 It->second.NumExecs++;
45 return It->second.FunctionPtr;
49 [[maybe_unused]] StringRef FnName) {
50#if PROTEUS_ENABLE_DEBUG
51 if (CacheMap.count(HashValue))
55 auto &CacheEntry = CacheMap[HashValue];
56 CacheEntry.FunctionPtr = FunctionPtr;
57 CacheEntry.NumExecs = 1;
58 CacheEntry.NumHits = 0;
60#if PROTEUS_ENABLE_DEBUG
61 CacheEntry.FnName = FnName.str();
68 printf(
"JitCache hits %lu total %lu\n", Hits, Accesses);
69 for (
const auto &[HashValue, JCE] : CacheMap) {
70 std::cout <<
"HashValue " << HashValue.toString() <<
" NumExecs "
71 << JCE.NumExecs <<
" NumHits " << JCE.NumHits;
72#if PROTEUS_ENABLE_DEBUG
73 printf(
" FnName %s", JCE.FnName.c_str());
82 struct JitCacheEntry {
83 Function_t FunctionPtr;
86#if PROTEUS_ENABLE_DEBUG
91 std::unordered_map<HashT, JitCacheEntry> CacheMap;
95 uint64_t Accesses = 0;
#define PROTEUS_FATAL_ERROR(x)
Definition Error.h:7
#define TIMESCOPE(x)
Definition TimeTracing.hpp:64
Definition Hashing.hpp:20
Definition JitCache.hpp:32
void insert(HashT &HashValue, Function_t FunctionPtr, StringRef FnName)
Definition JitCache.hpp:48
Function_t lookup(HashT &HashValue)
Definition JitCache.hpp:34
void printStats()
Definition JitCache.hpp:65
JitCache()
Definition JitCache.hpp:79
Definition CppJitModule.cpp:21