|
@ -1,8 +1,5 @@ |
|
|
#include "Cache.h" |
|
|
#include "Cache.h" |
|
|
|
|
|
|
|
|
#include <iostream> |
|
|
|
|
|
#include <cassert> |
|
|
|
|
|
|
|
|
|
|
|
#include "preprocessor/llvm_includes_start.h" |
|
|
#include "preprocessor/llvm_includes_start.h" |
|
|
#include <llvm/IR/Module.h> |
|
|
#include <llvm/IR/Module.h> |
|
|
#include <llvm/IR/LLVMContext.h> |
|
|
#include <llvm/IR/LLVMContext.h> |
|
@ -22,9 +19,6 @@ namespace eth |
|
|
namespace jit |
|
|
namespace jit |
|
|
{ |
|
|
{ |
|
|
|
|
|
|
|
|
//#define CACHE_LOG std::cerr << "CACHE "
|
|
|
|
|
|
#define CACHE_LOG std::ostream(nullptr) |
|
|
|
|
|
|
|
|
|
|
|
namespace |
|
|
namespace |
|
|
{ |
|
|
{ |
|
|
llvm::MemoryBuffer* g_lastObject; |
|
|
llvm::MemoryBuffer* g_lastObject; |
|
@ -43,7 +37,7 @@ std::unique_ptr<llvm::Module> Cache::getObject(std::string const& id) |
|
|
if (g_listener) |
|
|
if (g_listener) |
|
|
g_listener->stateChanged(ExecState::CacheLoad); |
|
|
g_listener->stateChanged(ExecState::CacheLoad); |
|
|
|
|
|
|
|
|
CACHE_LOG << id << ": search\n"; |
|
|
DLOG(cache) << id << ": search\n"; |
|
|
if (!CHECK(!g_lastObject)) |
|
|
if (!CHECK(!g_lastObject)) |
|
|
g_lastObject = nullptr; |
|
|
g_lastObject = nullptr; |
|
|
|
|
|
|
|
@ -72,7 +66,7 @@ std::unique_ptr<llvm::Module> Cache::getObject(std::string const& id) |
|
|
|
|
|
|
|
|
if (g_lastObject) // if object found create fake module
|
|
|
if (g_lastObject) // if object found create fake module
|
|
|
{ |
|
|
{ |
|
|
CACHE_LOG << id << ": found\n"; |
|
|
DLOG(cache) << id << ": found\n"; |
|
|
auto&& context = llvm::getGlobalContext(); |
|
|
auto&& context = llvm::getGlobalContext(); |
|
|
auto module = std::unique_ptr<llvm::Module>(new llvm::Module(id, context)); |
|
|
auto module = std::unique_ptr<llvm::Module>(new llvm::Module(id, context)); |
|
|
auto mainFuncType = llvm::FunctionType::get(llvm::Type::getVoidTy(context), {}, false); |
|
|
auto mainFuncType = llvm::FunctionType::get(llvm::Type::getVoidTy(context), {}, false); |
|
@ -81,7 +75,7 @@ std::unique_ptr<llvm::Module> Cache::getObject(std::string const& id) |
|
|
bb->getInstList().push_back(new llvm::UnreachableInst{context}); |
|
|
bb->getInstList().push_back(new llvm::UnreachableInst{context}); |
|
|
return module; |
|
|
return module; |
|
|
} |
|
|
} |
|
|
CACHE_LOG << id << ": not found\n"; |
|
|
DLOG(cache) << id << ": not found\n"; |
|
|
return nullptr; |
|
|
return nullptr; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -101,7 +95,7 @@ void ObjectCache::notifyObjectCompiled(llvm::Module const* _module, llvm::Memory |
|
|
|
|
|
|
|
|
llvm::sys::path::append(cachePath, id); |
|
|
llvm::sys::path::append(cachePath, id); |
|
|
|
|
|
|
|
|
CACHE_LOG << id << ": write\n"; |
|
|
DLOG(cache) << id << ": write\n"; |
|
|
std::string error; |
|
|
std::string error; |
|
|
llvm::raw_fd_ostream cacheFile(cachePath.c_str(), error, llvm::sys::fs::F_None); |
|
|
llvm::raw_fd_ostream cacheFile(cachePath.c_str(), error, llvm::sys::fs::F_None); |
|
|
cacheFile << _object->getBuffer(); |
|
|
cacheFile << _object->getBuffer(); |
|
@ -109,7 +103,7 @@ void ObjectCache::notifyObjectCompiled(llvm::Module const* _module, llvm::Memory |
|
|
|
|
|
|
|
|
llvm::MemoryBuffer* ObjectCache::getObject(llvm::Module const* _module) |
|
|
llvm::MemoryBuffer* ObjectCache::getObject(llvm::Module const* _module) |
|
|
{ |
|
|
{ |
|
|
CACHE_LOG << _module->getModuleIdentifier() << ": use\n"; |
|
|
DLOG(cache) << _module->getModuleIdentifier() << ": use\n"; |
|
|
auto o = g_lastObject; |
|
|
auto o = g_lastObject; |
|
|
g_lastObject = nullptr; |
|
|
g_lastObject = nullptr; |
|
|
return o; |
|
|
return o; |
|
|