Commit 4e055c08 by Li-Wen Chang Committed by Tianqi Chen

Fix LLVM initialization again (#2399)

parent 00f80d12
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
#ifdef TVM_LLVM_VERSION #ifdef TVM_LLVM_VERSION
#include <tvm/base.h> #include <tvm/base.h>
#include <atomic>
#include <mutex> #include <mutex>
#include "llvm_common.h" #include "llvm_common.h"
...@@ -13,7 +14,7 @@ namespace codegen { ...@@ -13,7 +14,7 @@ namespace codegen {
struct LLVMEnv { struct LLVMEnv {
std::mutex mu; std::mutex mu;
volatile bool all_initialized{false}; std::atomic<bool> all_initialized{false};
static LLVMEnv* Global() { static LLVMEnv* Global() {
static LLVMEnv inst; static LLVMEnv inst;
...@@ -23,15 +24,15 @@ struct LLVMEnv { ...@@ -23,15 +24,15 @@ struct LLVMEnv {
void InitializeLLVM() { void InitializeLLVM() {
LLVMEnv* e = LLVMEnv::Global(); LLVMEnv* e = LLVMEnv::Global();
if (!e->all_initialized) { if (!e->all_initialized.load(std::memory_order::memory_order_acquire)) {
std::lock_guard<std::mutex> lock(e->mu); std::lock_guard<std::mutex> lock(e->mu);
if (!e->all_initialized) { if (!e->all_initialized.load(std::memory_order::memory_order_acquire)) {
llvm::InitializeAllTargetInfos(); llvm::InitializeAllTargetInfos();
llvm::InitializeAllTargets(); llvm::InitializeAllTargets();
llvm::InitializeAllTargetMCs(); llvm::InitializeAllTargetMCs();
llvm::InitializeAllAsmParsers(); llvm::InitializeAllAsmParsers();
llvm::InitializeAllAsmPrinters(); llvm::InitializeAllAsmPrinters();
e->all_initialized = true; e->all_initialized.store(true, std::memory_order::memory_order_release);
} }
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment