mirror of https://github.com/python/cpython
[3.13] gh-125444: Fix illegal instruction for older Arm architectures (GH-125574) (GH-125595)
On Arm v5 it is not possible to get the thread ID via c13 register
hence the illegal instruction. The c13 register started to provide
thread ID since Arm v6K architecture variant. Other variants of
Arm v6 (T2, Z and base) don’t provide the thread ID via c13.
For the sake of simplicity we group v5 and v6 together and
consider that instructions for Arm v7 only.
(cherry picked from commit feda9aa73a
)
Co-authored-by: Diego Russo <diego.russo@arm.com>
This commit is contained in:
parent
e3ae564682
commit
18b9079ddb
|
@ -151,9 +151,9 @@ static inline mi_threadid_t _mi_prim_thread_id(void) mi_attr_noexcept {
|
||||||
// If you test on another platform and it works please send a PR :-)
|
// If you test on another platform and it works please send a PR :-)
|
||||||
// see also https://akkadia.org/drepper/tls.pdf for more info on the TLS register.
|
// see also https://akkadia.org/drepper/tls.pdf for more info on the TLS register.
|
||||||
#elif defined(__GNUC__) && ( \
|
#elif defined(__GNUC__) && ( \
|
||||||
(defined(__GLIBC__) && (defined(__x86_64__) || defined(__i386__) || defined(__arm__) || defined(__aarch64__))) \
|
(defined(__GLIBC__) && (defined(__x86_64__) || defined(__i386__) || (defined(__arm__) && __ARM_ARCH >= 7) || defined(__aarch64__))) \
|
||||||
|| (defined(__APPLE__) && (defined(__x86_64__) || defined(__aarch64__))) \
|
|| (defined(__APPLE__) && (defined(__x86_64__) || defined(__aarch64__))) \
|
||||||
|| (defined(__BIONIC__) && (defined(__x86_64__) || defined(__i386__) || defined(__arm__) || defined(__aarch64__))) \
|
|| (defined(__BIONIC__) && (defined(__x86_64__) || defined(__i386__) || (defined(__arm__) && __ARM_ARCH >= 7) || defined(__aarch64__))) \
|
||||||
|| (defined(__FreeBSD__) && (defined(__x86_64__) || defined(__i386__) || defined(__aarch64__))) \
|
|| (defined(__FreeBSD__) && (defined(__x86_64__) || defined(__i386__) || defined(__aarch64__))) \
|
||||||
|| (defined(__OpenBSD__) && (defined(__x86_64__) || defined(__i386__) || defined(__aarch64__))) \
|
|| (defined(__OpenBSD__) && (defined(__x86_64__) || defined(__i386__) || defined(__aarch64__))) \
|
||||||
)
|
)
|
||||||
|
|
|
@ -259,7 +259,7 @@ _Py_ThreadId(void)
|
||||||
__asm__("movq %%gs:0, %0" : "=r" (tid)); // x86_64 macOSX uses GS
|
__asm__("movq %%gs:0, %0" : "=r" (tid)); // x86_64 macOSX uses GS
|
||||||
#elif defined(__x86_64__)
|
#elif defined(__x86_64__)
|
||||||
__asm__("movq %%fs:0, %0" : "=r" (tid)); // x86_64 Linux, BSD uses FS
|
__asm__("movq %%fs:0, %0" : "=r" (tid)); // x86_64 Linux, BSD uses FS
|
||||||
#elif defined(__arm__)
|
#elif defined(__arm__) && __ARM_ARCH >= 7
|
||||||
__asm__ ("mrc p15, 0, %0, c13, c0, 3\nbic %0, %0, #3" : "=r" (tid));
|
__asm__ ("mrc p15, 0, %0, c13, c0, 3\nbic %0, %0, #3" : "=r" (tid));
|
||||||
#elif defined(__aarch64__) && defined(__APPLE__)
|
#elif defined(__aarch64__) && defined(__APPLE__)
|
||||||
__asm__ ("mrs %0, tpidrro_el0" : "=r" (tid));
|
__asm__ ("mrs %0, tpidrro_el0" : "=r" (tid));
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
Fix illegal instruction for older Arm architectures. Patch by Diego Russo, testing by Ross Burton.
|
Loading…
Reference in New Issue