diff options
author | Mikael Djurfeldt <djurfeldt@nada.kth.se> | 2002-12-09 13:42:58 +0000 |
---|---|---|
committer | Mikael Djurfeldt <djurfeldt@nada.kth.se> | 2002-12-09 13:42:58 +0000 |
commit | 9bc4701cd397c375cca4fa77b579af0673e6a584 (patch) | |
tree | d8fc0f895724c0b2ffa78f88f80c58b5690909dc /libguile/pthread-threads.h | |
parent | fc85d095600162567fd0aa563eed9e6eada3e889 (diff) | |
download | guile-9bc4701cd397c375cca4fa77b579af0673e6a584.tar.gz |
* __scm.h (SCM_ALLOW_INTS_ONLY): Removed.
(SCM_NONREC_CRITICAL_SECTION_START,
SCM_NONREC_CRITICAL_SECTION_END, SCM_REC_CRITICAL_SECTION_START,
SCM_REC_CRITICAL_SECTION_END): New macros.
(SCM_CRITICAL_SECTION_START/END): Defined here.
* eval.c: Insert SOURCE_SECTION_START / SOURCE_SECTION_END around
the three calls to scm_m_expand_body.
* gc.h: #include "libguile/pthread-threads.h";
(SCM_FREELIST_CREATE, SCM_FREELIST_LOC): New macros.
* gc.c (scm_i_freelist, scm_i_freelist2): Defined to be of type
scm_t_key;
* gc.c, gc-freelist.c, inline.h: Use SCM_FREELIST_LOC for freelist
access.
* gc-freelist.c (scm_gc_init_freelist): Create freelist keys.
* gc-freelist.c, threads.c (really_launch): Use
SCM_FREELIST_CREATE.
* gc-malloc.c (scm_realloc, scm_gc_register_collectable_memory):
* gc.c (scm_i_expensive_validation_check, scm_gc,
scm_gc_for_newcell): Put threads to sleep before doing GC-related
heap administration so that those pieces of code are executed
single-threaded. We might consider rewriting these code sections
in terms of a "call_gc_code_singly_threaded" construct instead of
calling the pair of scm_i_thread_put_to_sleep () and
scm_i_thread_wake_up (). Also, we would want to have as many of
these sections eleminated.
* init.c (scm_init_guile_1): Call scm_threads_prehistory.
* inline.h: #include "libguile/threads.h"
* pthread-threads.h: Macros now conform more closely to the
pthreads interface. Some of them now take a second argument.
* threads.c, threads.h: Many changes.
* configure.in: Temporarily replaced "copt" threads option with new
option "pthreads".
(USE_PTHREAD_THREADS): Define if pthreads configured.
Diffstat (limited to 'libguile/pthread-threads.h')
-rw-r--r-- | libguile/pthread-threads.h | 63 |
1 files changed, 33 insertions, 30 deletions
diff --git a/libguile/pthread-threads.h b/libguile/pthread-threads.h index 5d68677ce..6e7e1d678 100644 --- a/libguile/pthread-threads.h +++ b/libguile/pthread-threads.h @@ -46,49 +46,52 @@ -/* The pthreads-threads implementation. This is a very simple mapping. +/* The pthreads-threads implementation. This is a direct mapping. */ +/* This is an interface between Guile and the pthreads thread package. */ + #include <pthread.h> -#define scm_t_thread pthread_t +/* MDJ 021209 <djurfeldt@nada.kth.se>: + The separation of the plugin interface and the low-level C API + (currently in threads.h) needs to be completed in a sensible way. + */ + +/* The scm_t_ types are temporarily used both in plugin and low-level API */ +#define scm_t_thread pthread_t -#define scm_thread_create(th,proc,data) \ - pthread_create ((th), NULL, (void *(*)(void *))(proc), (data)) +#define scm_i_plugin_thread_create pthread_create -#define scm_thread_join(th) pthread_join (th, NULL) -#define scm_thread_detach(th) pthread_detach (th) -#define scm_thread_self() pthread_self () +#define scm_i_plugin_thread_join pthread_join +#define scm_i_plugin_thread_detach pthread_detach +#define scm_i_plugin_thread_self pthread_self -#define scm_t_mutex pthread_mutex_t +#define scm_t_mutex pthread_mutex_t -#define scm_mutex_init(mx) pthread_mutex_init (mx, NULL) -#define scm_mutex_destroy(mx) pthread_mutex_destroy (mx) -#define scm_mutex_lock(mx) pthread_mutex_lock (mx) -#define scm_mutex_trylock(mx) pthread_mutex_trylock (mx) -#define scm_mutex_unlock(mx) pthread_mutex_unlock (mx) +#define scm_i_plugin_mutex_init pthread_mutex_init +#define scm_i_plugin_mutex_destroy pthread_mutex_destroy +#define scm_i_plugin_mutex_lock pthread_mutex_lock +#define scm_i_plugin_mutex_trylock pthread_mutex_trylock +#define scm_i_plugin_mutex_unlock pthread_mutex_unlock -#define scm_t_cond pthread_cond_t +#define scm_t_cond pthread_cond_t -#define scm_cond_init(cv) pthread_cond_init (cv, NULL) -#define scm_cond_destroy(cv) pthread_cond_destroy (cv) -#define scm_cond_wait(cv,mx) pthread_cond_wait (cv, mx) -#define scm_cond_timedwait(cv,mx,at) \ - pthread_cond_timedwait (cv, mx, at) -#define scm_cond_signal(cv) pthread_cond_signal (cv) -#define scm_cond_broadcast(cv) \ - pthread_cond_broadcast (cv) +#define scm_i_plugin_cond_init pthread_cond_init +#define scm_i_plugin_cond_destroy pthread_cond_destroy +#define scm_i_plugin_cond_wait pthread_cond_wait +#define scm_i_plugin_cond_timedwait pthread_cond_timedwait +#define scm_i_plugin_cond_signal pthread_cond_signal +#define scm_i_plugin_cond_broadcast pthread_cond_broadcast -#define scm_t_key pthread_key_t +#define scm_t_key pthread_key_t -#define scm_key_create(keyp) pthread_key_create (keyp, NULL) -#define scm_key_delete(key) pthread_key_delete (key) -#define scm_key_setspecific(key, value) \ - pthread_setspecific (key, value) -#define scm_key_getspecific(key) \ - pthread_getspecific (key) +#define scm_i_plugin_key_create pthread_key_create +#define scm_i_plugin_key_delete pthread_key_delete +#define scm_i_plugin_setspecific pthread_setspecific +#define scm_i_plugin_getspecific pthread_getspecific -#define scm_thread_select select +#define scm_i_plugin_select select #endif /* SCM_THREADS_NULL_H */ |