mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-14 07:30:32 +02:00
threading / with_guile refactor to use more GC_stack_base
* libguile/init.h: * libguile/init.c (scm_i_init_guile): Change arg to this internal function from SCM_STACKITEM* to void*. Actually it's a struct GC_stack_base*. * libguile/bdw-gc.h: Don't do pthread redirects, because we don't want to affect applications' pthread_* bindings. * libguile/pthread-threads.h (scm_i_pthread_create) (scm_i_pthread_detach, scm_i_pthread_exit, scm_i_pthread_cancel) (scm_i_pthread_sigmask): Do pthread redirects here, in this internal header. * libguile/threads.h: Remove declaration of internal scm_i_with_guile_and_parent. Remove declaration of undefined scm_threads_init_first_thread. Make declaration of internal scm_threads_prehistory actually internal, and take a void* (actually a struct GC_stack_base*). * libguile/threads.c (GC_get_stack_base): Implement a shim if this function is unavailable, and fold in the implementations of get_thread_stack_base. (GC_call_with_stack_base): Actually implement. (guilify_self_1): Take a GC_stack_base* as an arg. (scm_i_init_thread_for_guile): Likewise, and set up libgc for registration of other threads. (scm_init_guile): Use GC_get_stack_base instead of our own guesswork. (with_guile_and_parent, scm_i_with_guile_and_parent): Rework to trampoline through a GC_call_with_stack_base. (scm_threads_prehistory): Pass the "base" arg on to guilify_self_1.
This commit is contained in:
parent
2a6f90e524
commit
12c1d8616d
6 changed files with 163 additions and 152 deletions
|
@ -3,7 +3,7 @@
|
|||
#ifndef SCM_PTHREADS_THREADS_H
|
||||
#define SCM_PTHREADS_THREADS_H
|
||||
|
||||
/* Copyright (C) 2002, 2005, 2006 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 2002, 2005, 2006, 2011 Free Software Foundation, Inc.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public License
|
||||
|
@ -29,24 +29,24 @@
|
|||
#include <pthread.h>
|
||||
#include <sched.h>
|
||||
|
||||
/* `libgc' intercepts pthread calls by defining wrapping macros. */
|
||||
/* `libgc' defines wrapper procedures for pthread calls. */
|
||||
#include "libguile/bdw-gc.h"
|
||||
|
||||
/* Threads
|
||||
*/
|
||||
#define scm_i_pthread_t pthread_t
|
||||
#define scm_i_pthread_self pthread_self
|
||||
#define scm_i_pthread_create pthread_create
|
||||
#define scm_i_pthread_detach pthread_detach
|
||||
#define scm_i_pthread_exit pthread_exit
|
||||
#define scm_i_pthread_cancel pthread_cancel
|
||||
#define scm_i_pthread_create GC_pthread_create
|
||||
#define scm_i_pthread_detach GC_pthread_detach
|
||||
#define scm_i_pthread_exit GC_pthread_exit
|
||||
#define scm_i_pthread_cancel GC_pthread_cancel
|
||||
#define scm_i_pthread_cleanup_push pthread_cleanup_push
|
||||
#define scm_i_pthread_cleanup_pop pthread_cleanup_pop
|
||||
#define scm_i_sched_yield sched_yield
|
||||
|
||||
/* Signals
|
||||
*/
|
||||
#define scm_i_pthread_sigmask pthread_sigmask
|
||||
#define scm_i_pthread_sigmask GC_pthread_sigmask
|
||||
|
||||
/* Mutexes
|
||||
*/
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue