Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'master' of git+ssh://scm.gforge.inria.fr//gitroot/simgrid/simgrid
authorFrederic Suter <frederic.suter@cc.in2p3.fr>
Thu, 20 Jul 2017 09:59:42 +0000 (11:59 +0200)
committerFrederic Suter <frederic.suter@cc.in2p3.fr>
Thu, 20 Jul 2017 09:59:42 +0000 (11:59 +0200)
include/xbt/xbt_os_thread.h
src/kernel/context/ContextThread.cpp

index e73022d..fa4c014 100644 (file)
@@ -31,8 +31,6 @@ typedef struct xbt_os_thread_ *xbt_os_thread_t;
 XBT_PUBLIC(xbt_os_thread_t) xbt_os_thread_create(const char *name, pvoid_f_pvoid_t start_routine, void *param, void *data);
 XBT_PUBLIC(void) xbt_os_thread_exit(int *retcode);
 XBT_PUBLIC(void) xbt_os_thread_detach(xbt_os_thread_t thread);
-#define xbt_os_thread_cleanup_push(routine, arg) pthread_cleanup_push(routine, arg)
-#define xbt_os_thread_cleanup_pop(execute) pthread_cleanup_pop(execute)
 
 XBT_PUBLIC(xbt_os_thread_t) xbt_os_thread_self(void);
 XBT_PUBLIC(const char *) xbt_os_thread_self_name(void);
index 012fbcc..85ac35a 100644 (file)
@@ -200,9 +200,9 @@ void ThreadContext::stop()
     xbt_os_sem_release(smx_ctx_thread_sem);
 
   // Signal to the maestro that it has finished:
-  xbt_os_thread_cleanup_push((void (*)(void*))xbt_os_sem_release, this->end_);
+  xbt_os_sem_release(this->end_);
+
   xbt_os_thread_exit(nullptr);
-  xbt_os_thread_cleanup_pop(0);
 }
 
 void ThreadContext::suspend()