blob: 4d2f2c32a19ca2f9dad19914668ef2c0fcdb8690 [file] [log] [blame]
Guido van Rossum34679b71993-01-26 13:33:44 +00001
Guido van Rossum1d5735e1994-08-30 08:27:36 +00002/* Thread package.
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. */
7
Martin v. Löwiscdc44512002-01-12 11:05:12 +00008#include "Python.h"
Guido van Rossum1d5735e1994-08-30 08:27:36 +00009
Matthias Klosea2542be2004-08-16 11:35:51 +000010#ifndef _POSIX_THREADS
11/* This means pthreads are not implemented in libc headers, hence the macro
12 not present in unistd.h. But they still can be implemented as an external
13 library (e.g. gnu pth in pthread emulation) */
14# ifdef HAVE_PTHREAD_H
15# include <pthread.h> /* _POSIX_THREADS */
16# endif
17#endif
18
Guido van Rossum2571cc81999-04-07 16:07:23 +000019#ifndef DONT_HAVE_STDIO_H
Guido van Rossum1d5735e1994-08-30 08:27:36 +000020#include <stdio.h>
Guido van Rossum2571cc81999-04-07 16:07:23 +000021#endif
Guido van Rossum1d5735e1994-08-30 08:27:36 +000022
Guido van Rossum1d5735e1994-08-30 08:27:36 +000023#include <stdlib.h>
Guido van Rossum1d5735e1994-08-30 08:27:36 +000024
Guido van Rossum49b56061998-10-01 20:42:43 +000025#include "pythread.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +000026
Guido van Rossum1d5735e1994-08-30 08:27:36 +000027#ifndef _POSIX_THREADS
28
Guido van Rossum539c6622005-09-14 17:49:54 +000029/* Check if we're running on HP-UX and _SC_THREADS is defined. If so, then
Ezio Melotti13925002011-03-16 11:05:33 +020030 enough of the Posix threads package is implemented to support python
Guido van Rossum539c6622005-09-14 17:49:54 +000031 threads.
32
33 This is valid for HP-UX 11.23 running on an ia64 system. If needed, add
Martin Panter7462b6492015-11-02 03:37:02 +000034 a check of __ia64 to verify that we're running on an ia64 system instead
Guido van Rossum539c6622005-09-14 17:49:54 +000035 of a pa-risc system.
36*/
37#ifdef __hpux
38#ifdef _SC_THREADS
39#define _POSIX_THREADS
40#endif
41#endif
42
Sjoerd Mullender66bca321993-12-03 16:54:45 +000043#endif /* _POSIX_THREADS */
Guido van Rossum1984f1e1992-08-04 12:41:02 +000044
Guido van Rossum1984f1e1992-08-04 12:41:02 +000045
Guido van Rossum408027e1996-12-30 16:17:54 +000046#ifdef Py_DEBUG
Guido van Rossum1d5735e1994-08-30 08:27:36 +000047static int thread_debug = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000048#define dprintf(args) (void)((thread_debug & 1) && printf args)
49#define d2printf(args) ((thread_debug & 8) && printf args)
Guido van Rossum1d5735e1994-08-30 08:27:36 +000050#else
51#define dprintf(args)
52#define d2printf(args)
53#endif
54
Guido van Rossum1984f1e1992-08-04 12:41:02 +000055static int initialized;
56
Thomas Wouters8ec68fd2000-07-24 14:39:50 +000057static void PyThread__init_thread(void); /* Forward */
Sjoerd Mullenderaee8bc11992-09-02 11:25:37 +000058
Thomas Wouters73e5a5b2006-06-08 15:35:45 +000059void
60PyThread_init_thread(void)
Sjoerd Mullenderaee8bc11992-09-02 11:25:37 +000061{
Guido van Rossum408027e1996-12-30 16:17:54 +000062#ifdef Py_DEBUG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000063 char *p = Py_GETENV("PYTHONTHREADDEBUG");
Sjoerd Mullender66bca321993-12-03 16:54:45 +000064
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000065 if (p) {
66 if (*p)
67 thread_debug = atoi(p);
68 else
69 thread_debug = 1;
70 }
Guido van Rossum408027e1996-12-30 16:17:54 +000071#endif /* Py_DEBUG */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000072 if (initialized)
73 return;
74 initialized = 1;
75 dprintf(("PyThread_init_thread called\n"));
76 PyThread__init_thread();
Sjoerd Mullenderaee8bc11992-09-02 11:25:37 +000077}
78
Eric Snow05351c12017-09-05 21:43:08 -070079/* Support for runtime thread stack size tuning.
80 A value of 0 means using the platform's default stack size
81 or the size specified by the THREAD_STACK_SIZE macro. */
82static size_t _pythread_stacksize = 0;
83
Masayuki Yamamotoaa0aa042017-07-03 20:34:38 +090084#if defined(_POSIX_THREADS)
85# define PYTHREAD_NAME "pthread"
86# include "thread_pthread.h"
87#elif defined(NT_THREADS)
88# define PYTHREAD_NAME "nt"
89# include "thread_nt.h"
90#else
91# error "Require native thread feature. See https://bugs.python.org/issue30832"
Guido van Rossumc3f82b61995-01-17 16:29:31 +000092#endif
93
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +000094
Thomas Wouters0e3f5912006-08-11 14:57:12 +000095/* return the current thread stack size */
96size_t
97PyThread_get_stacksize(void)
98{
Eric Snow05351c12017-09-05 21:43:08 -070099 return _pythread_stacksize;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000100}
101
102/* Only platforms defining a THREAD_SET_STACKSIZE() macro
103 in thread_<platform>.h support changing the stack size.
104 Return 0 if stack size is valid,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000105 -1 if stack size value is invalid,
106 -2 if setting stack size is not supported. */
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000107int
108PyThread_set_stacksize(size_t size)
109{
110#if defined(THREAD_SET_STACKSIZE)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000111 return THREAD_SET_STACKSIZE(size);
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000112#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000113 return -2;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000114#endif
115}
116
Mark Hammond8d98d2c2003-04-19 15:41:53 +0000117
Tim Petersfda787f2004-10-09 22:33:09 +0000118/* ------------------------------------------------------------------------
119Per-thread data ("key") support.
Mark Hammond8d98d2c2003-04-19 15:41:53 +0000120
Tim Petersfda787f2004-10-09 22:33:09 +0000121Use PyThread_create_key() to create a new key. This is typically shared
122across threads.
123
124Use PyThread_set_key_value(thekey, value) to associate void* value with
125thekey in the current thread. Each thread has a distinct mapping of thekey
126to a void* value. Caution: if the current thread already has a mapping
127for thekey, value is ignored.
128
129Use PyThread_get_key_value(thekey) to retrieve the void* value associated
130with thekey in the current thread. This returns NULL if no value is
131associated with thekey in the current thread.
132
133Use PyThread_delete_key_value(thekey) to forget the current thread's associated
134value for thekey. PyThread_delete_key(thekey) forgets the values associated
135with thekey across *all* threads.
136
137While some of these functions have error-return values, none set any
138Python exception.
139
140None of the functions does memory management on behalf of the void* values.
141You need to allocate and deallocate them yourself. If the void* values
142happen to be PyObject*, these functions don't do refcount operations on
143them either.
144
145The GIL does not need to be held when calling these functions; they supply
146their own locking. This isn't true of PyThread_create_key(), though (see
147next paragraph).
148
149There's a hidden assumption that PyThread_create_key() will be called before
150any of the other functions are called. There's also a hidden assumption
151that calls to PyThread_create_key() are serialized externally.
152------------------------------------------------------------------------ */
153
Victor Stinner754851f2011-04-19 23:58:51 +0200154
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200155PyDoc_STRVAR(threadinfo__doc__,
156"sys.thread_info\n\
157\n\
158A struct sequence holding information about the thread implementation.");
159
160static PyStructSequence_Field threadinfo_fields[] = {
161 {"name", "name of the thread implementation"},
162 {"lock", "name of the lock implementation"},
163 {"version", "name and version of the thread library"},
164 {0}
165};
166
167static PyStructSequence_Desc threadinfo_desc = {
168 "sys.thread_info", /* name */
169 threadinfo__doc__, /* doc */
170 threadinfo_fields, /* fields */
171 3
172};
173
174static PyTypeObject ThreadInfoType;
175
Victor Stinner754851f2011-04-19 23:58:51 +0200176PyObject*
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200177PyThread_GetInfo(void)
Victor Stinner754851f2011-04-19 23:58:51 +0200178{
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200179 PyObject *threadinfo, *value;
180 int pos = 0;
Victor Stinnere07f5222011-04-20 12:23:26 +0200181#if (defined(_POSIX_THREADS) && defined(HAVE_CONFSTR) \
182 && defined(_CS_GNU_LIBPTHREAD_VERSION))
Victor Stinner754851f2011-04-19 23:58:51 +0200183 char buffer[255];
184 int len;
Victor Stinnere07f5222011-04-20 12:23:26 +0200185#endif
Victor Stinner754851f2011-04-19 23:58:51 +0200186
Victor Stinner1c8f0592013-07-22 22:24:54 +0200187 if (ThreadInfoType.tp_name == 0) {
188 if (PyStructSequence_InitType2(&ThreadInfoType, &threadinfo_desc) < 0)
189 return NULL;
190 }
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200191
192 threadinfo = PyStructSequence_New(&ThreadInfoType);
193 if (threadinfo == NULL)
Victor Stinner754851f2011-04-19 23:58:51 +0200194 return NULL;
195
196 value = PyUnicode_FromString(PYTHREAD_NAME);
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200197 if (value == NULL) {
198 Py_DECREF(threadinfo);
199 return NULL;
200 }
201 PyStructSequence_SET_ITEM(threadinfo, pos++, value);
Victor Stinner754851f2011-04-19 23:58:51 +0200202
203#ifdef _POSIX_THREADS
204#ifdef USE_SEMAPHORES
205 value = PyUnicode_FromString("semaphore");
206#else
207 value = PyUnicode_FromString("mutex+cond");
208#endif
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200209 if (value == NULL) {
210 Py_DECREF(threadinfo);
Victor Stinner754851f2011-04-19 23:58:51 +0200211 return NULL;
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200212 }
213#else
214 Py_INCREF(Py_None);
215 value = Py_None;
216#endif
217 PyStructSequence_SET_ITEM(threadinfo, pos++, value);
Victor Stinner754851f2011-04-19 23:58:51 +0200218
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200219#if (defined(_POSIX_THREADS) && defined(HAVE_CONFSTR) \
220 && defined(_CS_GNU_LIBPTHREAD_VERSION))
221 value = NULL;
Victor Stinner754851f2011-04-19 23:58:51 +0200222 len = confstr(_CS_GNU_LIBPTHREAD_VERSION, buffer, sizeof(buffer));
Victor Stinner98ea54c2014-08-15 23:30:40 +0200223 if (1 < len && (size_t)len < sizeof(buffer)) {
Victor Stinner754851f2011-04-19 23:58:51 +0200224 value = PyUnicode_DecodeFSDefaultAndSize(buffer, len-1);
225 if (value == NULL)
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200226 PyErr_Clear();
Victor Stinner754851f2011-04-19 23:58:51 +0200227 }
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200228 if (value == NULL)
Victor Stinner754851f2011-04-19 23:58:51 +0200229#endif
Victor Stinnerd5c355c2011-04-30 14:53:09 +0200230 {
231 Py_INCREF(Py_None);
232 value = Py_None;
233 }
234 PyStructSequence_SET_ITEM(threadinfo, pos++, value);
235 return threadinfo;
Victor Stinner754851f2011-04-19 23:58:51 +0200236}