summaryrefslogtreecommitdiffstats
path: root/Python/thread_foobar.h
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2014-04-28 19:12:11 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2014-04-28 19:12:11 (GMT)
commit285a163a4ceba7ef9d307f87e5e691732e52b760 (patch)
treefbb2ed132b38434f31fa4eeea1bc8ea4eba8a6a8 /Python/thread_foobar.h
parentc695c95626ad776e3e378a376a7752c2bd039326 (diff)
downloadcpython-285a163a4ceba7ef9d307f87e5e691732e52b760.zip
cpython-285a163a4ceba7ef9d307f87e5e691732e52b760.tar.gz
cpython-285a163a4ceba7ef9d307f87e5e691732e52b760.tar.bz2
Issue #21312: Update the thread_foobar.h template file to include newer threading APIs. Patch by Jack McCracken.
Diffstat (limited to 'Python/thread_foobar.h')
-rw-r--r--Python/thread_foobar.h63
1 files changed, 60 insertions, 3 deletions
diff --git a/Python/thread_foobar.h b/Python/thread_foobar.h
index d2b78c5..ea96f9c 100644
--- a/Python/thread_foobar.h
+++ b/Python/thread_foobar.h
@@ -1,4 +1,3 @@
-
/*
* Initialization.
*/
@@ -61,10 +60,18 @@ PyThread_free_lock(PyThread_type_lock lock)
int
PyThread_acquire_lock(PyThread_type_lock lock, int waitflag)
{
+ return PyThread_acquire_lock_timed(lock, waitflag ? -1 : 0, 0);
+}
+
+PyLockStatus
+PyThread_acquire_lock_timed(PyThread_type_lock lock, PY_TIMEOUT_T microseconds,
+ int intr_flag)
+{
int success;
- dprintf(("PyThread_acquire_lock(%p, %d) called\n", lock, waitflag));
- dprintf(("PyThread_acquire_lock(%p, %d) -> %d\n", lock, waitflag, success));
+ dprintf(("PyThread_acquire_lock_timed(%p, %lld, %d) called\n", lock, microseconds, intr_flag));
+ dprintf(("PyThread_acquire_lock_timed(%p, %lld, %d) -> %d\n",
+ lock, microseconds, intr_flag, success));
return success;
}
@@ -73,3 +80,53 @@ PyThread_release_lock(PyThread_type_lock lock)
{
dprintf(("PyThread_release_lock(%p) called\n", lock));
}
+
+/* The following are only needed if native TLS support exists */
+#define Py_HAVE_NATIVE_TLS
+
+#ifdef Py_HAVE_NATIVE_TLS
+int
+PyThread_create_key(void)
+{
+ int result;
+ return result;
+}
+
+void
+PyThread_delete_key(int key)
+{
+
+}
+
+int
+PyThread_set_key_value(int key, void *value)
+{
+ int ok;
+
+ /* A failure in this case returns -1 */
+ if (!ok)
+ return -1;
+ return 0;
+}
+
+void *
+PyThread_get_key_value(int key)
+{
+ void *result;
+
+ return result;
+}
+
+void
+PyThread_delete_key_value(int key)
+{
+
+}
+
+void
+PyThread_ReInitTLS(void)
+{
+
+}
+
+#endif