diff options
Diffstat (limited to 'llvm/lib/Support/Threading.cpp')
| -rw-r--r-- | llvm/lib/Support/Threading.cpp | 54 | 
1 files changed, 1 insertions, 53 deletions
| diff --git a/llvm/lib/Support/Threading.cpp b/llvm/lib/Support/Threading.cpp index 61f8ee5be5b3..55e97d60af7a 100644 --- a/llvm/lib/Support/Threading.cpp +++ b/llvm/lib/Support/Threading.cpp @@ -15,6 +15,7 @@  #include "llvm/ADT/Optional.h"  #include "llvm/Config/config.h"  #include "llvm/Support/Host.h" +#include "llvm/Support/thread.h"  #include <cassert>  #include <errno.h> @@ -38,13 +39,6 @@ bool llvm::llvm_is_multithreaded() {  #if LLVM_ENABLE_THREADS == 0 ||                                                \      (!defined(_WIN32) && !defined(HAVE_PTHREAD_H)) -// Support for non-Win32, non-pthread implementation. -void llvm::llvm_execute_on_thread(void (*Fn)(void *), void *UserData, -                                  llvm::Optional<unsigned> StackSizeInBytes) { -  (void)StackSizeInBytes; -  Fn(UserData); -} -  uint64_t llvm::get_threadid() { return 0; }  uint32_t llvm::get_max_thread_name_length() { return 0; } @@ -60,25 +54,6 @@ unsigned llvm::ThreadPoolStrategy::compute_thread_count() const {    return 1;  } -#if LLVM_ENABLE_THREADS == 0 -void llvm::llvm_execute_on_thread_async( -    llvm::unique_function<void()> Func, -    llvm::Optional<unsigned> StackSizeInBytes) { -  (void)Func; -  (void)StackSizeInBytes; -  report_fatal_error("Spawning a detached thread doesn't make sense with no " -                     "threading support"); -} -#else -// Support for non-Win32, non-pthread implementation. -void llvm::llvm_execute_on_thread_async( -    llvm::unique_function<void()> Func, -    llvm::Optional<unsigned> StackSizeInBytes) { -  (void)StackSizeInBytes; -  std::thread(std::move(Func)).detach(); -} -#endif -  #else  int computeHostNumHardwareThreads(); @@ -95,17 +70,6 @@ unsigned llvm::ThreadPoolStrategy::compute_thread_count() const {    return std::min((unsigned)MaxThreadCount, ThreadsRequested);  } -namespace { -struct SyncThreadInfo { -  void (*UserFn)(void *); -  void *UserData; -}; - -using AsyncThreadInfo = llvm::unique_function<void()>; - -enum class JoiningPolicy { Join, Detach }; -} // namespace -  // Include the platform-specific parts of this class.  #ifdef LLVM_ON_UNIX  #include "Unix/Threading.inc" @@ -114,22 +78,6 @@ enum class JoiningPolicy { Join, Detach };  #include "Windows/Threading.inc"  #endif -void llvm::llvm_execute_on_thread(void (*Fn)(void *), void *UserData, -                                  llvm::Optional<unsigned> StackSizeInBytes) { - -  SyncThreadInfo Info = {Fn, UserData}; -  llvm_execute_on_thread_impl(threadFuncSync, &Info, StackSizeInBytes, -                              JoiningPolicy::Join); -} - -void llvm::llvm_execute_on_thread_async( -    llvm::unique_function<void()> Func, -    llvm::Optional<unsigned> StackSizeInBytes) { -  llvm_execute_on_thread_impl(&threadFuncAsync, -                              new AsyncThreadInfo(std::move(Func)), -                              StackSizeInBytes, JoiningPolicy::Detach); -} -  #endif  Optional<ThreadPoolStrategy> | 
