From 2002f1f84797c2c46d0634eabd5ac5fd61e13d73 Mon Sep 17 00:00:00 2001 From: Andy Wingo Date: Fri, 13 May 2011 13:33:59 +0200 Subject: [PATCH] refactor do_thread_exit cleanup handler invocation * libguile/threads.c (do_thread_exit): Redo cleanup handler call so as not to shove a SCM into a pointer. --- libguile/threads.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/libguile/threads.c b/libguile/threads.c index f49696b1d..def92811b 100644 --- a/libguile/threads.c +++ b/libguile/threads.c @@ -607,6 +607,13 @@ typedef struct { #define SCM_MUTEXP(x) SCM_SMOB_PREDICATE (scm_tc16_mutex, x) #define SCM_MUTEX_DATA(x) ((fat_mutex *) SCM_SMOB_DATA (x)) +static SCM +call_cleanup (void *data) +{ + SCM *proc_p = data; + return scm_call_0 (*proc_p); +} + /* Perform thread tear-down, in guile mode. */ static void * @@ -624,7 +631,7 @@ do_thread_exit (void *v) t->cleanup_handler = SCM_BOOL_F; t->result = scm_internal_catch (SCM_BOOL_T, - (scm_t_catch_body) scm_call_0, ptr, + call_cleanup, &ptr, scm_handle_by_message_noexit, NULL); }