3 This is intended to be usable independently from Python.
4 The implementation for system foobar is in a file thread_foobar.h
5 which is included by this file dependent on config settings.
6 Stuff shared by all thread_*.h files is collected here. */
11 #ifndef _POSIX_THREADS
12 /* This means pthreads are not implemented in libc headers, hence the macro
13 not present in unistd.h. But they still can be implemented as an external
14 library (e.g. gnu pth in pthread emulation) */
15 # ifdef HAVE_PTHREAD_H
16 # include <pthread.h> /* _POSIX_THREADS */
20 #ifndef DONT_HAVE_STDIO_H
27 #ifndef HAVE_PTHREAD_H /* XXX Need to check in configure.in */
34 #ifndef _POSIX_THREADS
41 #define SOLARIS_THREADS
44 #if defined(sun) && !defined(SOLARIS_THREADS)
48 /* Check if we're running on HP-UX and _SC_THREADS is defined. If so, then
49 enough of the Posix threads package is implimented to support python
52 This is valid for HP-UX 11.23 running on an ia64 system. If needed, add
53 a check of __ia64 to verify that we're running on a ia64 system instead
58 #define _POSIX_THREADS
62 #endif /* _POSIX_THREADS */
66 static int thread_debug
= 0;
67 #define dprintf(args) (void)((thread_debug & 1) && printf args)
68 #define d2printf(args) ((thread_debug & 8) && printf args)
71 #define d2printf(args)
74 static int initialized
;
76 static void PyThread__init_thread(void); /* Forward */
79 PyThread_init_thread(void)
82 char *p
= Py_GETENV("PYTHONTHREADDEBUG");
86 thread_debug
= atoi(p
);
94 dprintf(("PyThread_init_thread called\n"));
95 PyThread__init_thread();
98 /* Support for runtime thread stack size tuning.
99 A value of 0 means using the platform's default stack size
100 or the size specified by the THREAD_STACK_SIZE macro. */
101 static size_t _pythread_stacksize
= 0;
104 #include "thread_sgi.h"
107 #ifdef SOLARIS_THREADS
108 #include "thread_solaris.h"
112 #include "thread_lwp.h"
116 #include "thread_pth.h"
117 #undef _POSIX_THREADS
120 #ifdef _POSIX_THREADS
121 #include "thread_pthread.h"
125 #include "thread_cthread.h"
129 #include "thread_nt.h"
133 #include "thread_os2.h"
137 #include "thread_plan9.h"
140 #ifdef ATHEOS_THREADS
141 #include "thread_atheos.h"
145 #ifdef FOOBAR_THREADS
146 #include "thread_foobar.h"
150 /* return the current thread stack size */
152 PyThread_get_stacksize(void)
154 return _pythread_stacksize
;
157 /* Only platforms defining a THREAD_SET_STACKSIZE() macro
158 in thread_<platform>.h support changing the stack size.
159 Return 0 if stack size is valid,
160 -1 if stack size value is invalid,
161 -2 if setting stack size is not supported. */
163 PyThread_set_stacksize(size_t size
)
165 #if defined(THREAD_SET_STACKSIZE)
166 return THREAD_SET_STACKSIZE(size
);
172 #ifndef Py_HAVE_NATIVE_TLS
173 /* If the platform has not supplied a platform specific
174 TLS implementation, provide our own.
176 This code stolen from "thread_sgi.h", where it was the only
177 implementation of an existing Python TLS API.
179 /* ------------------------------------------------------------------------
180 Per-thread data ("key") support.
182 Use PyThread_create_key() to create a new key. This is typically shared
185 Use PyThread_set_key_value(thekey, value) to associate void* value with
186 thekey in the current thread. Each thread has a distinct mapping of thekey
187 to a void* value. Caution: if the current thread already has a mapping
188 for thekey, value is ignored.
190 Use PyThread_get_key_value(thekey) to retrieve the void* value associated
191 with thekey in the current thread. This returns NULL if no value is
192 associated with thekey in the current thread.
194 Use PyThread_delete_key_value(thekey) to forget the current thread's associated
195 value for thekey. PyThread_delete_key(thekey) forgets the values associated
196 with thekey across *all* threads.
198 While some of these functions have error-return values, none set any
201 None of the functions does memory management on behalf of the void* values.
202 You need to allocate and deallocate them yourself. If the void* values
203 happen to be PyObject*, these functions don't do refcount operations on
206 The GIL does not need to be held when calling these functions; they supply
207 their own locking. This isn't true of PyThread_create_key(), though (see
210 There's a hidden assumption that PyThread_create_key() will be called before
211 any of the other functions are called. There's also a hidden assumption
212 that calls to PyThread_create_key() are serialized externally.
213 ------------------------------------------------------------------------ */
215 /* A singly-linked list of struct key objects remembers all the key->value
216 * associations. File static keyhead heads the list. keymutex is used
217 * to enforce exclusion internally.
220 /* Next record in the list, or NULL if this is the last record. */
223 /* The thread id, according to PyThread_get_thread_ident(). */
226 /* The key and its associated value. */
231 static struct key
*keyhead
= NULL
;
232 static PyThread_type_lock keymutex
= NULL
;
233 static int nkeys
= 0; /* PyThread_create_key() hands out nkeys+1 next */
236 * If the current thread has a mapping for key, the appropriate struct key*
237 * is returned. NB: value is ignored in this case!
238 * If there is no mapping for key in the current thread, then:
239 * If value is NULL, NULL is returned.
240 * Else a mapping of key to value is created for the current thread,
241 * and a pointer to a new struct key* is returned; except that if
242 * malloc() can't find room for a new struct key*, NULL is returned.
243 * So when value==NULL, this acts like a pure lookup routine, and when
244 * value!=NULL, this acts like dict.setdefault(), returning an existing
245 * mapping if one exists, else creating a new mapping.
247 * Caution: this used to be too clever, trying to hold keymutex only
248 * around the "p->next = keyhead; keyhead = p" pair. That allowed
249 * another thread to mutate the list, via key deletion, concurrent with
250 * find_key() crawling over the list. Hilarity ensued. For example, when
251 * the for-loop here does "p = p->next", p could end up pointing at a
252 * record that PyThread_delete_key_value() was concurrently free()'ing.
253 * That could lead to anything, from failing to find a key that exists, to
254 * segfaults. Now we lock the whole routine.
257 find_key(int key
, void *value
)
259 struct key
*p
, *prev_p
;
260 long id
= PyThread_get_thread_ident();
264 PyThread_acquire_lock(keymutex
, 1);
266 for (p
= keyhead
; p
!= NULL
; p
= p
->next
) {
267 if (p
->id
== id
&& p
->key
== key
)
269 /* Sanity check. These states should never happen but if
270 * they do we must abort. Otherwise we'll end up spinning in
271 * in a tight loop with the lock held. A similar check is done
272 * in pystate.c tstate_delete_common(). */
274 Py_FatalError("tls find_key: small circular list(!)");
276 if (p
->next
== keyhead
)
277 Py_FatalError("tls find_key: circular list(!)");
283 p
= (struct key
*)malloc(sizeof(struct key
));
292 PyThread_release_lock(keymutex
);
296 /* Return a new key. This must be called before any other functions in
297 * this family, and callers must arrange to serialize calls to this
298 * function. No violations are detected.
301 PyThread_create_key(void)
303 /* All parts of this function are wrong if it's called by multiple
304 * threads simultaneously.
306 if (keymutex
== NULL
)
307 keymutex
= PyThread_allocate_lock();
311 /* Forget the associations for key across *all* threads. */
313 PyThread_delete_key(int key
)
317 PyThread_acquire_lock(keymutex
, 1);
319 while ((p
= *q
) != NULL
) {
323 /* NB This does *not* free p->value! */
328 PyThread_release_lock(keymutex
);
331 /* Confusing: If the current thread has an association for key,
332 * value is ignored, and 0 is returned. Else an attempt is made to create
333 * an association of key to value for the current thread. 0 is returned
334 * if that succeeds, but -1 is returned if there's not enough memory
335 * to create the association. value must not be NULL.
338 PyThread_set_key_value(int key
, void *value
)
342 assert(value
!= NULL
);
343 p
= find_key(key
, value
);
350 /* Retrieve the value associated with key in the current thread, or NULL
351 * if the current thread doesn't have an association for key.
354 PyThread_get_key_value(int key
)
356 struct key
*p
= find_key(key
, NULL
);
364 /* Forget the current thread's association for key, if any. */
366 PyThread_delete_key_value(int key
)
368 long id
= PyThread_get_thread_ident();
371 PyThread_acquire_lock(keymutex
, 1);
373 while ((p
= *q
) != NULL
) {
374 if (p
->key
== key
&& p
->id
== id
) {
377 /* NB This does *not* free p->value! */
383 PyThread_release_lock(keymutex
);
386 /* Forget everything not associated with the current thread id.
387 * This function is called from PyOS_AfterFork(). It is necessary
388 * because other thread ids which were in use at the time of the fork
389 * may be reused for new threads created in the forked process.
392 PyThread_ReInitTLS(void)
394 long id
= PyThread_get_thread_ident();
400 /* As with interpreter_lock in PyEval_ReInitThreads()
401 we just create a new lock without freeing the old one */
402 keymutex
= PyThread_allocate_lock();
404 /* Delete all keys which do not match the current thread id */
406 while ((p
= *q
) != NULL
) {
410 /* NB This does *not* free p->value! */
417 #endif /* Py_HAVE_NATIVE_TLS */