mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
ThreadLocal: Move Unix-specific code out of Support/ThreadLocal.cpp
Just a cleanup, no functionality change is intended. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@224227 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3acb2035ba
commit
1691fa27d7
@ -35,54 +35,10 @@ void *ThreadLocalImpl::getInstance() {
|
||||
void **pd = reinterpret_cast<void**>(&data);
|
||||
return *pd;
|
||||
}
|
||||
void ThreadLocalImpl::removeInstance() {
|
||||
setInstance(0);
|
||||
}
|
||||
}
|
||||
#else
|
||||
|
||||
#if defined(HAVE_PTHREAD_H) && defined(HAVE_PTHREAD_GETSPECIFIC)
|
||||
|
||||
#include <cassert>
|
||||
#include <pthread.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
namespace llvm {
|
||||
using namespace sys;
|
||||
|
||||
ThreadLocalImpl::ThreadLocalImpl() : data() {
|
||||
static_assert(sizeof(pthread_key_t) <= sizeof(data), "size too big");
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
int errorcode = pthread_key_create(key, nullptr);
|
||||
assert(errorcode == 0);
|
||||
(void) errorcode;
|
||||
}
|
||||
|
||||
ThreadLocalImpl::~ThreadLocalImpl() {
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
int errorcode = pthread_key_delete(*key);
|
||||
assert(errorcode == 0);
|
||||
(void) errorcode;
|
||||
}
|
||||
|
||||
void ThreadLocalImpl::setInstance(const void* d) {
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
int errorcode = pthread_setspecific(*key, d);
|
||||
assert(errorcode == 0);
|
||||
(void) errorcode;
|
||||
}
|
||||
|
||||
void *ThreadLocalImpl::getInstance() {
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
return pthread_getspecific(*key);
|
||||
}
|
||||
|
||||
void ThreadLocalImpl::removeInstance() {
|
||||
setInstance(nullptr);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
#elif defined(LLVM_ON_UNIX)
|
||||
#include "Unix/ThreadLocal.inc"
|
||||
#elif defined( LLVM_ON_WIN32)
|
||||
@ -90,4 +46,3 @@ void ThreadLocalImpl::removeInstance() {
|
||||
#else
|
||||
#warning Neither LLVM_ON_UNIX nor LLVM_ON_WIN32 set in Support/ThreadLocal.cpp
|
||||
#endif
|
||||
#endif
|
||||
|
@ -16,6 +16,48 @@
|
||||
//=== is guaranteed to work on *all* UNIX variants.
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#if defined(HAVE_PTHREAD_H) && defined(HAVE_PTHREAD_GETSPECIFIC)
|
||||
|
||||
#include <cassert>
|
||||
#include <pthread.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
namespace llvm {
|
||||
using namespace sys;
|
||||
|
||||
ThreadLocalImpl::ThreadLocalImpl() : data() {
|
||||
static_assert(sizeof(pthread_key_t) <= sizeof(data), "size too big");
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
int errorcode = pthread_key_create(key, nullptr);
|
||||
assert(errorcode == 0);
|
||||
(void) errorcode;
|
||||
}
|
||||
|
||||
ThreadLocalImpl::~ThreadLocalImpl() {
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
int errorcode = pthread_key_delete(*key);
|
||||
assert(errorcode == 0);
|
||||
(void) errorcode;
|
||||
}
|
||||
|
||||
void ThreadLocalImpl::setInstance(const void* d) {
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
int errorcode = pthread_setspecific(*key, d);
|
||||
assert(errorcode == 0);
|
||||
(void) errorcode;
|
||||
}
|
||||
|
||||
void *ThreadLocalImpl::getInstance() {
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
return pthread_getspecific(*key);
|
||||
}
|
||||
|
||||
void ThreadLocalImpl::removeInstance() {
|
||||
setInstance(nullptr);
|
||||
}
|
||||
|
||||
}
|
||||
#else
|
||||
namespace llvm {
|
||||
using namespace sys;
|
||||
ThreadLocalImpl::ThreadLocalImpl() : data() { }
|
||||
@ -24,3 +66,4 @@ void ThreadLocalImpl::setInstance(const void* d) { data = const_cast<void*>(d);}
|
||||
void *ThreadLocalImpl::getInstance() { return data; }
|
||||
void ThreadLocalImpl::removeInstance() { setInstance(0); }
|
||||
}
|
||||
#endif
|
||||
|
Loading…
x
Reference in New Issue
Block a user