Fixing to allow multiple executions/process.
This commit is contained in:
parent
12d9c3d15e
commit
92a3e19cd9
|
@ -27,9 +27,16 @@ using namespace xe::cpu;
|
||||||
using namespace xe::kernel;
|
using namespace xe::kernel;
|
||||||
|
|
||||||
|
|
||||||
Processor::Processor(xe_pal_ref pal, xe_memory_ref memory) {
|
namespace {
|
||||||
pal_ = xe_pal_retain(pal);
|
void InitializeIfNeeded();
|
||||||
memory_ = xe_memory_retain(memory);
|
void CleanupOnShutdown();
|
||||||
|
|
||||||
|
void InitializeIfNeeded() {
|
||||||
|
static bool has_initialized = false;
|
||||||
|
if (has_initialized) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
has_initialized = true;
|
||||||
|
|
||||||
// TODO(benvanik): only do this once
|
// TODO(benvanik): only do this once
|
||||||
LLVMLinkInInterpreter();
|
LLVMLinkInInterpreter();
|
||||||
|
@ -41,6 +48,21 @@ Processor::Processor(xe_pal_ref pal, xe_memory_ref memory) {
|
||||||
codegen::RegisterEmitCategoryControl();
|
codegen::RegisterEmitCategoryControl();
|
||||||
codegen::RegisterEmitCategoryFPU();
|
codegen::RegisterEmitCategoryFPU();
|
||||||
codegen::RegisterEmitCategoryMemory();
|
codegen::RegisterEmitCategoryMemory();
|
||||||
|
|
||||||
|
atexit(CleanupOnShutdown);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CleanupOnShutdown() {
|
||||||
|
llvm_shutdown();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Processor::Processor(xe_pal_ref pal, xe_memory_ref memory) {
|
||||||
|
pal_ = xe_pal_retain(pal);
|
||||||
|
memory_ = xe_memory_retain(memory);
|
||||||
|
|
||||||
|
InitializeIfNeeded();
|
||||||
}
|
}
|
||||||
|
|
||||||
Processor::~Processor() {
|
Processor::~Processor() {
|
||||||
|
@ -51,7 +73,6 @@ Processor::~Processor() {
|
||||||
}
|
}
|
||||||
|
|
||||||
engine_.reset();
|
engine_.reset();
|
||||||
llvm_shutdown();
|
|
||||||
|
|
||||||
xe_memory_release(memory_);
|
xe_memory_release(memory_);
|
||||||
xe_pal_release(pal_);
|
xe_pal_release(pal_);
|
||||||
|
|
Loading…
Reference in New Issue