Merge pull request #91178 from FRidh/ldshared
python3: improve cross-compilation of extension modules, fixes #91171
This commit is contained in:
commit
9c3a585731
@ -0,0 +1,33 @@
|
|||||||
|
From 1911995b1a1252d80bf2b9651840e185a1a6baf5 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Hong Xu <hong@topbug.net>
|
||||||
|
Date: Thu, 25 Jul 2019 10:25:55 -0700
|
||||||
|
Subject: [PATCH] On all posix systems, not just Darwin, set LDSHARED (if not
|
||||||
|
set) according to CC
|
||||||
|
|
||||||
|
This patch is slightly different from https://bugs.python.org/issue24935
|
||||||
|
, except that we now handle LDSHARED according to CC on all posix
|
||||||
|
systems, not just Darwin or Linux.
|
||||||
|
---
|
||||||
|
Lib/distutils/sysconfig.py | 4 ++--
|
||||||
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/Lib/distutils/sysconfig.py b/Lib/distutils/sysconfig.py
|
||||||
|
index 37feae5df7..9fdce6896d 100644
|
||||||
|
--- a/Lib/distutils/sysconfig.py
|
||||||
|
+++ b/Lib/distutils/sysconfig.py
|
||||||
|
@@ -199,10 +199,10 @@ def customize_compiler(compiler):
|
||||||
|
|
||||||
|
if 'CC' in os.environ:
|
||||||
|
newcc = os.environ['CC']
|
||||||
|
- if (sys.platform == 'darwin'
|
||||||
|
+ if (os.name == 'posix'
|
||||||
|
and 'LDSHARED' not in os.environ
|
||||||
|
and ldshared.startswith(cc)):
|
||||||
|
- # On OS X, if CC is overridden, use that as the default
|
||||||
|
+ # On POSIX systems, if CC is overridden, use that as the default
|
||||||
|
# command for LDSHARED as well
|
||||||
|
ldshared = newcc + ldshared[len(cc):]
|
||||||
|
cc = newcc
|
||||||
|
--
|
||||||
|
2.25.1
|
||||||
|
|
@ -140,6 +140,9 @@ in with passthru; stdenv.mkDerivation {
|
|||||||
sha256 = "1h18lnpx539h5lfxyk379dxwr8m2raigcjixkf133l4xy3f4bzi2";
|
sha256 = "1h18lnpx539h5lfxyk379dxwr8m2raigcjixkf133l4xy3f4bzi2";
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
] ++ [
|
||||||
|
# LDSHARED now uses $CC instead of gcc. Fixes cross-compilation of extension modules.
|
||||||
|
./3.8/0001-On-all-posix-systems-not-just-Darwin-set-LDSHARED-if.patch
|
||||||
];
|
];
|
||||||
|
|
||||||
postPatch = ''
|
postPatch = ''
|
||||||
|
@ -20,10 +20,6 @@ stdenv.mkDerivation rec {
|
|||||||
|
|
||||||
# for python cross-compiling
|
# for python cross-compiling
|
||||||
_PYTHON_HOST_PLATFORM = stdenv.hostPlatform.config;
|
_PYTHON_HOST_PLATFORM = stdenv.hostPlatform.config;
|
||||||
# The i686 case is a quick hack; I don't know what's wrong.
|
|
||||||
postConfigure = stdenv.lib.optionalString (!stdenv.isi686) ''
|
|
||||||
export LDSHARED="$LD -shared"
|
|
||||||
'';
|
|
||||||
|
|
||||||
# gcc bug with -O1 on ARM with gcc 4.8
|
# gcc bug with -O1 on ARM with gcc 4.8
|
||||||
# This should be fine on all platforms so apply universally
|
# This should be fine on all platforms so apply universally
|
||||||
|
Loading…
x
Reference in New Issue
Block a user