From: Matthias Klose Date: Sun, 28 Feb 2021 17:03:44 +0000 (+0000) Subject: ctypes-arm X-Git-Tag: archive/raspbian/3.9.2-1+rpi1^2~22 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=f806af5fc02887d46ca2cfd6862b4e3cf8980aad;p=python3.9.git ctypes-arm Gbp-Pq: Name ctypes-arm.diff --- diff --git a/Lib/ctypes/util.py b/Lib/ctypes/util.py index 0c2510e..3907247 100644 --- a/Lib/ctypes/util.py +++ b/Lib/ctypes/util.py @@ -269,16 +269,27 @@ elif os.name == "posix": def _findSoname_ldconfig(name): import struct + # XXX this code assumes that we know all unames and that a single + # ABI is supported per uname; instead we should find what the + # ABI is (e.g. check ABI of current process) or simply ask libc + # to load the library for us + uname = os.uname() + # ARM has a variety of unames, e.g. armv7l + if uname.machine.startswith("arm"): + machine = "arm" if struct.calcsize('l') == 4: - machine = os.uname().machine + '-32' + machine = uname.machine + '-32' else: - machine = os.uname().machine + '-64' + machine = uname.machine + '-64' mach_map = { 'x86_64-64': 'libc6,x86-64', 'ppc64-64': 'libc6,64bit', 'sparc64-64': 'libc6,64bit', 's390x-64': 'libc6,64bit', 'ia64-64': 'libc6,IA-64', + # this actually breaks on biarch or multiarch as the first + # library wins; uname doesn't tell us which ABI we're using + 'arm-32': 'libc6(,hard-float)?', } abi_type = mach_map.get(machine, 'libc6')