X-Git-Url: https://pd.if.org/git/?p=nbds;a=blobdiff_plain;f=include%2Ftls.h;h=c496dab9faac6e14a205e771db558ecbd55bbd34;hp=865e6da26bed635a94493b53d9c72007856e7259;hb=75b0d2f02f548b3a1e4daba8b0d55eea2fb24e92;hpb=052506ff082f134f00834f666653819e18d9bddf diff --git a/include/tls.h b/include/tls.h index 865e6da..c496dab 100644 --- a/include/tls.h +++ b/include/tls.h @@ -9,9 +9,9 @@ #define TLS_H #ifdef __ELF__ // use gcc thread-local storage (i.e. __thread variables) -#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 DECLARE_THREAD_LOCAL(name, type) __thread type name +#define INIT_THREAD_LOCAL(name) +#define SET_THREAD_LOCAL(name, value) name = value #define LOCALIZE_THREAD_LOCAL(name, type) #else//!__ELF__ @@ -22,10 +22,16 @@ #define INIT_THREAD_LOCAL(name) \ do { \ - if (pthread_key_create(&name##_KEY, NULL) != 0) { assert(FALSE); } \ + if (pthread_key_create(&name##_KEY, NULL) != 0) { \ + assert("error initializing thread local variable " #name, FALSE); \ + } \ } while (0) -#define SET_THREAD_LOCAL(name, value) pthread_setspecific(name##_KEY, (void *)(size_t)value); +#define SET_THREAD_LOCAL(name, value) \ + do { \ + name = value; \ + pthread_setspecific(name##_KEY, (void *)(size_t)value); \ + } while (0); #define LOCALIZE_THREAD_LOCAL(name, type) type name = (type)(size_t)pthread_getspecific(name##_KEY)