blob: 6e9f30337fb9860ada13d59620e838c1c8b9011a [file] [log] [blame]
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001
Fred Drake3cf4d2b2000-07-09 00:55:06 +00002#ifndef Py_PYTHREAD_H
3#define Py_PYTHREAD_H
4
Guido van Rossum65d5b571998-12-21 19:32:43 +00005typedef void *PyThread_type_lock;
6typedef void *PyThread_type_sema;
Sjoerd Mullenderd10d8291992-09-11 15:19:27 +00007
8#ifdef __cplusplus
9extern "C" {
10#endif
11
Antoine Pitrou810023d2010-12-15 22:59:16 +000012/* Return status codes for Python lock acquisition. Chosen for maximum
13 * backwards compatibility, ie failure -> 0, success -> 1. */
14typedef enum PyLockStatus {
15 PY_LOCK_FAILURE = 0,
16 PY_LOCK_ACQUIRED = 1,
17 PY_LOCK_INTR
18} PyLockStatus;
19
Mark Hammond91a681d2002-08-12 07:21:58 +000020PyAPI_FUNC(void) PyThread_init_thread(void);
21PyAPI_FUNC(long) PyThread_start_new_thread(void (*)(void *), void *);
22PyAPI_FUNC(void) PyThread_exit_thread(void);
Mark Hammond91a681d2002-08-12 07:21:58 +000023PyAPI_FUNC(long) PyThread_get_thread_ident(void);
Guido van Rossum1984f1e1992-08-04 12:41:02 +000024
Mark Hammond91a681d2002-08-12 07:21:58 +000025PyAPI_FUNC(PyThread_type_lock) PyThread_allocate_lock(void);
26PyAPI_FUNC(void) PyThread_free_lock(PyThread_type_lock);
27PyAPI_FUNC(int) PyThread_acquire_lock(PyThread_type_lock, int);
Guido van Rossum1984f1e1992-08-04 12:41:02 +000028#define WAIT_LOCK 1
29#define NOWAIT_LOCK 0
Antoine Pitrou7c3e5772010-04-14 15:44:10 +000030
31/* PY_TIMEOUT_T is the integral type used to specify timeouts when waiting
32 on a lock (see PyThread_acquire_lock_timed() below).
33 PY_TIMEOUT_MAX is the highest usable value (in microseconds) of that
34 type, and depends on the system threading API.
Victor Stinner754851f2011-04-19 23:58:51 +020035
Antoine Pitrou7c3e5772010-04-14 15:44:10 +000036 NOTE: this isn't the same value as `_thread.TIMEOUT_MAX`. The _thread
37 module exposes a higher-level API, with timeouts expressed in seconds
38 and floating-point numbers allowed.
39*/
40#if defined(HAVE_LONG_LONG)
41#define PY_TIMEOUT_T PY_LONG_LONG
42#define PY_TIMEOUT_MAX PY_LLONG_MAX
43#else
44#define PY_TIMEOUT_T long
45#define PY_TIMEOUT_MAX LONG_MAX
46#endif
47
48/* In the NT API, the timeout is a DWORD and is expressed in milliseconds */
49#if defined (NT_THREADS)
Hirokazu Yamamotof13c6d82010-09-11 22:35:24 +000050#if (Py_LL(0xFFFFFFFF) * 1000 < PY_TIMEOUT_MAX)
Antoine Pitrou7c3e5772010-04-14 15:44:10 +000051#undef PY_TIMEOUT_MAX
Hirokazu Yamamotof13c6d82010-09-11 22:35:24 +000052#define PY_TIMEOUT_MAX (Py_LL(0xFFFFFFFF) * 1000)
Antoine Pitrou7c3e5772010-04-14 15:44:10 +000053#endif
54#endif
55
56/* If microseconds == 0, the call is non-blocking: it returns immediately
57 even when the lock can't be acquired.
58 If microseconds > 0, the call waits up to the specified duration.
59 If microseconds < 0, the call waits until success (or abnormal failure)
Antoine Pitrou810023d2010-12-15 22:59:16 +000060
Antoine Pitrou7c3e5772010-04-14 15:44:10 +000061 microseconds must be less than PY_TIMEOUT_MAX. Behaviour otherwise is
Antoine Pitrou810023d2010-12-15 22:59:16 +000062 undefined.
63
64 If intr_flag is true and the acquire is interrupted by a signal, then the
65 call will return PY_LOCK_INTR. The caller may reattempt to acquire the
66 lock.
67*/
68PyAPI_FUNC(PyLockStatus) PyThread_acquire_lock_timed(PyThread_type_lock,
69 PY_TIMEOUT_T microseconds,
70 int intr_flag);
71
Mark Hammond91a681d2002-08-12 07:21:58 +000072PyAPI_FUNC(void) PyThread_release_lock(PyThread_type_lock);
Guido van Rossum1984f1e1992-08-04 12:41:02 +000073
Thomas Wouters0e3f5912006-08-11 14:57:12 +000074PyAPI_FUNC(size_t) PyThread_get_stacksize(void);
75PyAPI_FUNC(int) PyThread_set_stacksize(size_t);
76
Victor Stinnerd5c355c2011-04-30 14:53:09 +020077PyAPI_FUNC(PyObject*) PyThread_GetInfo(void);
Victor Stinner754851f2011-04-19 23:58:51 +020078
Mark Hammond8d98d2c2003-04-19 15:41:53 +000079/* Thread Local Storage (TLS) API */
Mark Hammond91a681d2002-08-12 07:21:58 +000080PyAPI_FUNC(int) PyThread_create_key(void);
81PyAPI_FUNC(void) PyThread_delete_key(int);
82PyAPI_FUNC(int) PyThread_set_key_value(int, void *);
83PyAPI_FUNC(void *) PyThread_get_key_value(int);
Mark Hammond8d98d2c2003-04-19 15:41:53 +000084PyAPI_FUNC(void) PyThread_delete_key_value(int key);
Guido van Rossuma027efa1997-05-05 20:56:21 +000085
Benjamin Petersone68df0f2008-06-13 00:26:50 +000086/* Cleanup after a fork */
87PyAPI_FUNC(void) PyThread_ReInitTLS(void);
88
Sjoerd Mullenderd10d8291992-09-11 15:19:27 +000089#ifdef __cplusplus
90}
91#endif
92
Guido van Rossumd023a781999-03-24 19:02:09 +000093#endif /* !Py_PYTHREAD_H */