summaryrefslogtreecommitdiffstats
path: root/package/python/python-2.7-015-distutils-cross-compilation-support.patch
blob: 7fd404e54e23674e99cfa8f1b8a9ef6ca770df0e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
Add some cross-compilation fixes to distutils

Inspired by work done by Marc Kleine-Budde <mkl@pengutronix.de> in
PTXdist.

Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
---
 Lib/distutils/sysconfig.py |    7 ++++---
 1 files changed, 4 insertions(+), 3 deletions(-)

Index: b/Lib/distutils/sysconfig.py
===================================================================
--- a/Lib/distutils/sysconfig.py
+++ b/Lib/distutils/sysconfig.py
@@ -18,14 +18,38 @@
 
 from distutils.errors import DistutilsPlatformError
 
-# These are needed in a couple of spots, so just compute them once.
-PREFIX = os.path.normpath(sys.prefix)
-EXEC_PREFIX = os.path.normpath(sys.exec_prefix)
+if os.environ.get('CROSS_COMPILING') == 'yes':
+    _sysroot=os.environ.get('_python_sysroot')
+    PREFIX = os.path.normpath(_sysroot + os.environ.get('_python_prefix'))
+    EXEC_PREFIX = os.path.normpath(_sysroot + os.environ.get('_python_exec_prefix'))
+    # In the cross-compilation case, we have two cases:
+    #
+    #  1/ We're currently cross-compiling Python itself. In this case,
+    #  EXECUTABLE_DIRNAME should point to the source directory of the
+    #  target Python, so that the rest of the code, especially the
+    #  _python_build() function will properly understand that we are
+    #  building Python itself. In this case, _python_srcdir is
+    #  defined.
+    #
+    #  2/ We're currently cross-compiling third party Python
+    #  modules. In this case, EXECUTABLE_DIRNAME should point to where
+    #  the target python executable is installed in the sysroot, so
+    #  that the proper Makefile is going to be read. In this case,
+    #  _python_srcdir is not defined.
+    #
+    if os.environ.get('_python_srcdir') is not None:
+        EXECUTABLE_DIRNAME = os.environ.get('_python_srcdir')
+    else:
+        EXECUTABLE_DIRNAME = os.path.join(_sysroot, "usr/bin")
+else:
+    PREFIX = os.path.normpath(sys.prefix)
+    EXEC_PREFIX = os.path.normpath(sys.exec_prefix)
+    EXECUTABLE_DIRNAME = os.path.dirname(os.path.realpath(sys.executable))
 
 # Path to the base directory of the project. On Windows the binary may
 # live in project/PCBuild9.  If we're dealing with an x64 Windows build,
 # it'll live in project/PCbuild/amd64.
-project_base = os.path.dirname(os.path.abspath(sys.executable))
+project_base = EXECUTABLE_DIRNAME
 if os.name == "nt" and "pcbuild" in project_base[-8:].lower():
     project_base = os.path.abspath(os.path.join(project_base, os.path.pardir))
 # PC/VS7.1
@@ -74,7 +98,7 @@
 
     if os.name == "posix":
         if python_build:
-            buildir = os.path.dirname(sys.executable)
+            buildir = EXECUTABLE_DIRNAME
             if plat_specific:
                 # python.h is located in the buildir
                 inc_dir = buildir
@@ -245,7 +269,7 @@
 def get_makefile_filename():
     """Return full pathname of installed Makefile from the Python build."""
     if python_build:
-        return os.path.join(os.path.dirname(sys.executable), "Makefile")
+        return os.path.join(EXECUTABLE_DIRNAME, "Makefile")
     lib_dir = get_python_lib(plat_specific=1, standard_lib=1)
     return os.path.join(lib_dir, "config", "Makefile")
 
@@ -311,6 +335,11 @@
             # `$$' is a literal `$' in make
             tmpv = v.replace('$$', '')
 
+            # Adjust prefix and exec_prefix when we're cross compiling
+            if os.environ.get('CROSS_COMPILING') == "yes":
+                if n == "prefix" or n == "exec_prefix":
+                    v = _sysroot + v
+
             if "$" in tmpv:
                 notdone[n] = v
             else:
Index: b/configure.in
===================================================================
--- a/configure.in
+++ b/configure.in
@@ -4342,6 +4342,20 @@
 CROSS_COMPILING=$cross_compiling
 AC_SUBST(CROSS_COMPILING)
 
+#
+# Cross compiling
+#
+# special RUNSHARED
+if test "$cross_compiling" = "yes"; then
+    RUNSHARED="\
+               CROSS_COMPILING=yes \
+               _python_cross_host=${ac_cv_host} \
+               _python_srcdir=\"\$(srcdir)\" \
+               _python_prefix=\"\$(prefix)\" \
+               _python_exec_prefix=\"\$(exec_prefix)\""
+fi
+
+
 # generate output files
 AC_CONFIG_FILES(Makefile.pre Modules/Setup.config Misc/python.pc)
 AC_CONFIG_FILES([Modules/ld_so_aix], [chmod +x Modules/ld_so_aix])
Index: b/Lib/distutils/command/build_ext.py
===================================================================
--- a/Lib/distutils/command/build_ext.py
+++ b/Lib/distutils/command/build_ext.py
@@ -237,7 +237,7 @@
         if ((sys.platform.startswith('linux') or sys.platform.startswith('gnu')
              or sys.platform.startswith('sunos'))
             and sysconfig.get_config_var('Py_ENABLE_SHARED')):
-            if sys.executable.startswith(os.path.join(sys.exec_prefix, "bin")):
+            if not sysconfig.python_build:
                 # building third party extensions
                 self.library_dirs.append(sysconfig.get_config_var('LIBDIR'))
             else:
OpenPOWER on IntegriCloud