X-Git-Url: https://pd.if.org/git/?p=nbds;a=blobdiff_plain;f=runtime%2Fruntime.c;h=8056660694888b4b596e66a0c0c01655e2ac01ce;hp=0731bfdc70226d81ba2c87a95d9405a7dcfd500c;hb=fb536c12185fd1e339b5fd479d9ef84554b436df;hpb=3ad1b21110cea1cf04f6acf5500d774bba05a8c8 diff --git a/runtime/runtime.c b/runtime/runtime.c index 0731bfd..8056660 100644 --- a/runtime/runtime.c +++ b/runtime/runtime.c @@ -9,9 +9,6 @@ #include "mem.h" #include "tls.h" -#undef malloc -#undef free - DECLARE_THREAD_LOCAL(tid_, int); typedef struct thread_info { @@ -21,9 +18,9 @@ typedef struct thread_info { } thread_info_t; void nbd_init (void) { - INIT_THREAD_LOCAL(tid_, NULL); + INIT_THREAD_LOCAL(tid_); + SET_THREAD_LOCAL(tid_, 0); mem_init(); - lwt_init(); lwt_thread_init(0); rcu_thread_init(0); } @@ -34,12 +31,12 @@ static void *worker (void *arg) { lwt_thread_init(ti->thread_id); rcu_thread_init(ti->thread_id); void *ret = ti->start_routine(ti->arg); - free(ti); + nbd_free(ti); return ret; } int nbd_thread_create (pthread_t *restrict thread, int thread_id, void *(*start_routine)(void *), void *restrict arg) { - thread_info_t *ti = (thread_info_t *)malloc(sizeof(thread_info_t)); + thread_info_t *ti = (thread_info_t *)nbd_malloc(sizeof(thread_info_t)); ti->thread_id = thread_id; ti->start_routine = start_routine; ti->arg = arg;