summaryrefslogtreecommitdiff
path: root/libguile/pthread-threads.h
diff options
context:
space:
mode:
authorMikael Djurfeldt <djurfeldt@nada.kth.se>2002-12-09 13:42:58 +0000
committerMikael Djurfeldt <djurfeldt@nada.kth.se>2002-12-09 13:42:58 +0000
commit9bc4701cd397c375cca4fa77b579af0673e6a584 (patch)
treed8fc0f895724c0b2ffa78f88f80c58b5690909dc /libguile/pthread-threads.h
parentfc85d095600162567fd0aa563eed9e6eada3e889 (diff)
downloadguile-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.h63
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 */