summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Felt <aixtools@users.noreply.github.com>2019-06-14 00:34:46 +0200
committerMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2019-06-13 15:34:46 -0700
commitd0eeb936d8daf05d7d89f6935e3f4c0dee49c5be (patch)
tree2f49b4e053b4e5ccc2c76e7f0cd85bbdea9d284a
parent838f26402de82640698c38ea9d2be65c6cf780d6 (diff)
downloadcpython-git-d0eeb936d8daf05d7d89f6935e3f4c0dee49c5be.tar.gz
bpo-37077: Add native thread ID (TID) for AIX (GH-13624)
This is the followup for issue36084 https://bugs.python.org/issue37077
-rw-r--r--Doc/library/_thread.rst2
-rw-r--r--Doc/library/threading.rst2
-rw-r--r--Include/pythread.h2
-rw-r--r--Misc/NEWS.d/next/Core and Builtins/2019-05-28-11-47-44.bpo-37077.S1h0Fc.rst2
-rw-r--r--Python/thread_pthread.h9
5 files changed, 12 insertions, 5 deletions
diff --git a/Doc/library/_thread.rst b/Doc/library/_thread.rst
index 5b4fcde669..bd653ab32b 100644
--- a/Doc/library/_thread.rst
+++ b/Doc/library/_thread.rst
@@ -106,7 +106,7 @@ This module defines the following constants and functions:
Its value may be used to uniquely identify this particular thread system-wide
(until the thread terminates, after which the value may be recycled by the OS).
- .. availability:: Windows, FreeBSD, Linux, macOS, OpenBSD, NetBSD.
+ .. availability:: Windows, FreeBSD, Linux, macOS, OpenBSD, NetBSD, AIX.
.. versionadded:: 3.8
diff --git a/Doc/library/threading.rst b/Doc/library/threading.rst
index b4f4814c4a..2907b65f5b 100644
--- a/Doc/library/threading.rst
+++ b/Doc/library/threading.rst
@@ -82,7 +82,7 @@ This module defines the following functions:
Its value may be used to uniquely identify this particular thread system-wide
(until the thread terminates, after which the value may be recycled by the OS).
- .. availability:: Windows, FreeBSD, Linux, macOS, OpenBSD, NetBSD.
+ .. availability:: Windows, FreeBSD, Linux, macOS, OpenBSD, NetBSD, AIX.
.. versionadded:: 3.8
diff --git a/Include/pythread.h b/Include/pythread.h
index 79a9210af3..f22e8c42c5 100644
--- a/Include/pythread.h
+++ b/Include/pythread.h
@@ -26,7 +26,7 @@ PyAPI_FUNC(unsigned long) PyThread_start_new_thread(void (*)(void *), void *);
PyAPI_FUNC(void) _Py_NO_RETURN PyThread_exit_thread(void);
PyAPI_FUNC(unsigned long) PyThread_get_thread_ident(void);
-#if defined(__APPLE__) || defined(__linux__) || defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__NetBSD__) || defined(_WIN32)
+#if defined(__APPLE__) || defined(__linux__) || defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__NetBSD__) || defined(_WIN32) || defined(_AIX)
#define PY_HAVE_THREAD_NATIVE_ID
PyAPI_FUNC(unsigned long) PyThread_get_thread_native_id(void);
#endif
diff --git a/Misc/NEWS.d/next/Core and Builtins/2019-05-28-11-47-44.bpo-37077.S1h0Fc.rst b/Misc/NEWS.d/next/Core and Builtins/2019-05-28-11-47-44.bpo-37077.S1h0Fc.rst
new file mode 100644
index 0000000000..832dfc94ac
--- /dev/null
+++ b/Misc/NEWS.d/next/Core and Builtins/2019-05-28-11-47-44.bpo-37077.S1h0Fc.rst
@@ -0,0 +1,2 @@
+Add :func:`threading.get_native_id` support for AIX.
+Patch by M. Felt
diff --git a/Python/thread_pthread.h b/Python/thread_pthread.h
index 9b4b23bdc7..a36d16c19e 100644
--- a/Python/thread_pthread.h
+++ b/Python/thread_pthread.h
@@ -18,8 +18,10 @@
# include <pthread_np.h> /* pthread_getthreadid_np() */
#elif defined(__OpenBSD__)
# include <unistd.h> /* getthrid() */
-#elif defined(__NetBSD__) /* _lwp_self */
-# include <lwp.h>
+#elif defined(_AIX)
+# include <sys/thread.h> /* thread_self() */
+#elif defined(__NetBSD__)
+# include <lwp.h> /* _lwp_self() */
#endif
/* The POSIX spec requires that use of pthread_attr_setstacksize
@@ -330,6 +332,9 @@ PyThread_get_thread_native_id(void)
#elif defined(__OpenBSD__)
pid_t native_id;
native_id = getthrid();
+#elif defined(_AIX)
+ tid_t native_id;
+ native_id = thread_self();
#elif defined(__NetBSD__)
lwpid_t native_id;
native_id = _lwp_self();