diff options
author | Tim Northover <t.p.northover@gmail.com> | 2021-07-08 14:59:47 +0100 |
---|---|---|
committer | Tim Northover <t.p.northover@gmail.com> | 2021-07-08 14:59:47 +0100 |
commit | 2bf5e8d953ededbc208bd4c116c9d6331d73f0f0 (patch) | |
tree | 6f0e1d1dce203f49fd943933ea271edbb56bee75 /llvm/lib/Support/Unix/Threading.inc | |
parent | 727e1c9be3a5b20c6b502f056d74a681689049d7 (diff) | |
download | llvm-2bf5e8d953ededbc208bd4c116c9d6331d73f0f0.zip llvm-2bf5e8d953ededbc208bd4c116c9d6331d73f0f0.tar.gz llvm-2bf5e8d953ededbc208bd4c116c9d6331d73f0f0.tar.bz2 |
Revert "Support: add llvm::thread class that supports specifying stack size."
It's causing build failures because DefaultStackSize isn't defined everywhere
it should be and I need time to investigate.
Diffstat (limited to 'llvm/lib/Support/Unix/Threading.inc')
-rw-r--r-- | llvm/lib/Support/Unix/Threading.inc | 52 |
1 files changed, 25 insertions, 27 deletions
diff --git a/llvm/lib/Support/Unix/Threading.inc b/llvm/lib/Support/Unix/Threading.inc index 2131def..667d023 100644 --- a/llvm/lib/Support/Unix/Threading.inc +++ b/llvm/lib/Support/Unix/Threading.inc @@ -48,9 +48,22 @@ #include <unistd.h> // For syscall() #endif -pthread_t -llvm::llvm_execute_on_thread_impl(void *(*ThreadFunc)(void *), void *Arg, - llvm::Optional<unsigned> StackSizeInBytes) { +static void *threadFuncSync(void *Arg) { + SyncThreadInfo *TI = static_cast<SyncThreadInfo *>(Arg); + TI->UserFn(TI->UserData); + return nullptr; +} + +static void *threadFuncAsync(void *Arg) { + std::unique_ptr<AsyncThreadInfo> Info(static_cast<AsyncThreadInfo *>(Arg)); + (*Info)(); + return nullptr; +} + +static void +llvm_execute_on_thread_impl(void *(*ThreadFunc)(void *), void *Arg, + llvm::Optional<unsigned> StackSizeInBytes, + JoiningPolicy JP) { int errnum; // Construct the attributes object. @@ -77,33 +90,18 @@ llvm::llvm_execute_on_thread_impl(void *(*ThreadFunc)(void *), void *Arg, if ((errnum = ::pthread_create(&Thread, &Attr, ThreadFunc, Arg)) != 0) ReportErrnumFatal("pthread_create failed", errnum); - return Thread; -} - -void llvm::llvm_thread_detach_impl(pthread_t Thread) { - int errnum; - - if ((errnum = ::pthread_detach(Thread)) != 0) { - ReportErrnumFatal("pthread_detach failed", errnum); - } -} - -void llvm::llvm_thread_join_impl(pthread_t Thread) { - int errnum; - - if ((errnum = ::pthread_join(Thread, nullptr)) != 0) { - ReportErrnumFatal("pthread_join failed", errnum); + if (JP == JoiningPolicy::Join) { + // Wait for the thread + if ((errnum = ::pthread_join(Thread, nullptr)) != 0) { + ReportErrnumFatal("pthread_join failed", errnum); + } + } else if (JP == JoiningPolicy::Detach) { + if ((errnum = ::pthread_detach(Thread)) != 0) { + ReportErrnumFatal("pthread_detach failed", errnum); + } } } -pthread_t llvm::llvm_thread_get_id_impl(pthread_t Thread) { - return Thread; -} - -pthread_t llvm::llvm_thread_get_current_id_impl() { - return ::pthread_self(); -} - uint64_t llvm::get_threadid() { #if defined(__APPLE__) // Calling "mach_thread_self()" bumps the reference count on the thread |