X-Git-Url: https://pd.if.org/git/?p=nbds;a=blobdiff_plain;f=include%2Ftls.h;h=865e6da26bed635a94493b53d9c72007856e7259;hp=def2becfd51ce352c5aa1449a652c225973b3281;hb=d26bac75802a324ed98c8d3d88cfb9eb87b3b35a;hpb=4a7804bd08c790fc3c4233312e4b485c3302fe02 diff --git a/include/tls.h b/include/tls.h index def2bec..865e6da 100644 --- a/include/tls.h +++ b/include/tls.h @@ -12,7 +12,7 @@ #define DECLARE_THREAD_LOCAL (name, type) type name #define INIT_THREAD_LOCAL (name, value) name = value #define SET_THREAD_LOCAL (name, value) name = value -#define LOCALIZE_THREAD_LOCAL(name, type) extern __thread type name +#define LOCALIZE_THREAD_LOCAL(name, type) #else//!__ELF__ @@ -20,15 +20,14 @@ #define DECLARE_THREAD_LOCAL(name, type) pthread_key_t name##_KEY -#define INIT_THREAD_LOCAL(name, value) \ +#define INIT_THREAD_LOCAL(name) \ do { \ - if (pthread_key_create(&name##_KEY, (void *)(size_t)value) != 0) { assert(FALSE); } \ + if (pthread_key_create(&name##_KEY, NULL) != 0) { assert(FALSE); } \ } while (0) #define SET_THREAD_LOCAL(name, value) pthread_setspecific(name##_KEY, (void *)(size_t)value); -#define LOCALIZE_THREAD_LOCAL(name, type) \ - extern pthread_key_t name##_KEY; type name = (type)(size_t)pthread_getspecific(name##_KEY) +#define LOCALIZE_THREAD_LOCAL(name, type) type name = (type)(size_t)pthread_getspecific(name##_KEY) #endif//__ELF__ #endif//TLS_H