mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-15 05:24:01 +00:00
Re-apply r211287: Remove support for LLVM runtime multi-threading.
I'll fix the problems in libclang and other projects in ways that don't require <mutex> until we sort out the cygwin situation. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@211900 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -7,7 +7,8 @@
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
//
|
||||
// This file implements llvm_start_multithreaded() and friends.
|
||||
// This file defines helper functions for running LLVM in a multi-threaded
|
||||
// environment.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
@ -19,38 +20,14 @@
|
||||
|
||||
using namespace llvm;
|
||||
|
||||
static bool multithreaded_mode = false;
|
||||
|
||||
bool llvm::llvm_start_multithreaded() {
|
||||
bool llvm::llvm_is_multithreaded() {
|
||||
#if LLVM_ENABLE_THREADS != 0
|
||||
assert(!multithreaded_mode && "Already multithreaded!");
|
||||
multithreaded_mode = true;
|
||||
|
||||
// We fence here to ensure that all initialization is complete BEFORE we
|
||||
// return from llvm_start_multithreaded().
|
||||
sys::MemoryFence();
|
||||
return true;
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
|
||||
void llvm::llvm_stop_multithreaded() {
|
||||
#if LLVM_ENABLE_THREADS != 0
|
||||
assert(multithreaded_mode && "Not currently multithreaded!");
|
||||
|
||||
// We fence here to insure that all threaded operations are complete BEFORE we
|
||||
// return from llvm_stop_multithreaded().
|
||||
sys::MemoryFence();
|
||||
|
||||
multithreaded_mode = false;
|
||||
#endif
|
||||
}
|
||||
|
||||
bool llvm::llvm_is_multithreaded() {
|
||||
return multithreaded_mode;
|
||||
}
|
||||
|
||||
#if LLVM_ENABLE_THREADS != 0 && defined(HAVE_PTHREAD_H)
|
||||
#include <pthread.h>
|
||||
|
||||
|
Reference in New Issue
Block a user