X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=thread.h;h=9740dbaf26223b452bb544e3c5ccb1dcf85ad42c;hb=6f9d8c32c6a78a47c6088f50d7051d779f712ee1;hp=f7ab18c553c4600b78374f92cc3d8db97fc494ff;hpb=631cfb58c2bd693774ee9ffe59908af4423167d4;p=p5sagit%2Fp5-mst-13.2.git diff --git a/thread.h b/thread.h index f7ab18c..9740dba 100644 --- a/thread.h +++ b/thread.h @@ -117,6 +117,7 @@ #define INIT_THREADS cthread_init() #define YIELD cthread_yield() #define ALLOC_THREAD_KEY NOOP +#define FREE_THREAD_KEY NOOP #define SET_THREAD_SELF(thr) (thr->self = cthread_self()) #endif /* I_MACH_CTHREADS */ @@ -251,12 +252,19 @@ # define ALLOC_THREAD_KEY \ STMT_START { \ if (pthread_key_create(&PL_thr_key, 0)) { \ - fprintf(stderr, "panic: pthread_key_create"); \ + PerlIO_printf(PerlIO_stderr(), "panic: pthread_key_create"); \ exit(1); \ } \ } STMT_END #endif +#ifndef FREE_THREAD_KEY +# define FREE_THREAD_KEY \ + STMT_START { \ + pthread_key_delete(PL_thr_key); \ + } STMT_END +#endif + #ifndef THREAD_RET_TYPE # define THREAD_RET_TYPE void * # define THREAD_RET_CAST(p) ((void *)(p))