diff options
| author | Michael Lippautz <michael.lippautz@gmail.com> | 2011-05-03 18:40:34 +0200 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-05-04 15:06:34 +0100 |
| commit | b5adb300dda792d128e9d1a7c33646437dbe73e4 (patch) | |
| tree | 276d40e0b035a6016ac60c9e403f40d952e01074 | |
| parent | d2e078aa046ae6c4f169695f546cf229db5be1f7 (diff) | |
| download | poky-b5adb300dda792d128e9d1a7c33646437dbe73e4.tar.gz | |
python: Unbreak Python third-party extensions
This patch fixes compilation/linking of python third-party extensions, i.e.
Extensions that ship with C code.
Problem:
Python uses distutils(-native) to compile third-party extensions. distutils
uses its own sysconfig module to get the options for compiling and linking.
Since third-party extensions have to be linked against this libpython it
important that -L points into staging. This is not the case because
distutils.sysconfig uses a special Makefile that is shipped with python
determine the paths. The Makefile is the same that would be used on the
target to build third-party extensions. It therefore points into /usr/lib
instead of staging.
Solution:
Stage a modified version of the Makefile where the paths (incdir, libdir) have
been replaced by ones that point into staging.
Side-problem:
The recipe actually should not stage files itself in do_compile, but rather
handle everything that needs to be staged in do_install. This is currently not
possible because python compiles itself using distutils-native. Distutils on
the other hand does only allow to add a path, but not to substitute it,
requiring a staged Makefile and libpython.so before the actual python
compilation is triggered.
The second step to solve this would be to either patch distutils, or split
python into python-initial and python. The -initial part could create the
Makefile and the library, while the main part focuses on the target.
For further references see:
http://lists.linuxtogo.org/pipermail/openembedded-core/2011-May/001752.html
(From OE-Core rev: 413e7e5a5d6db45a6fbca5044246d6696d9d5711)
Signed-off-by: Michael Lippautz <michael.lippautz@gmail.com>
Acked-by: Martin Jansa <Martin.Jansa@gmail.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rw-r--r-- | meta/recipes-devtools/python/python_2.6.6.bb | 41 |
1 files changed, 27 insertions, 14 deletions
diff --git a/meta/recipes-devtools/python/python_2.6.6.bb b/meta/recipes-devtools/python/python_2.6.6.bb index a641ddd617..65875ff34a 100644 --- a/meta/recipes-devtools/python/python_2.6.6.bb +++ b/meta/recipes-devtools/python/python_2.6.6.bb | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | require python.inc | 1 | require python.inc |
| 2 | DEPENDS = "python-native db gdbm openssl readline sqlite3 zlib" | 2 | DEPENDS = "python-native db gdbm openssl readline sqlite3 zlib" |
| 3 | DEPENDS_sharprom = "python-native db readline zlib gdbm openssl" | 3 | DEPENDS_sharprom = "python-native db readline zlib gdbm openssl" |
| 4 | PR = "${INC_PR}.2" | 4 | PR = "${INC_PR}.3" |
| 5 | LIC_FILES_CHKSUM = "file://LICENSE;md5=38fdd546420fab09ac6bd3d8a1c83eb6" | 5 | LIC_FILES_CHKSUM = "file://LICENSE;md5=38fdd546420fab09ac6bd3d8a1c83eb6" |
| 6 | 6 | ||
| 7 | DISTRO_SRC_URI ?= "file://sitecustomize.py" | 7 | DISTRO_SRC_URI ?= "file://sitecustomize.py" |
| @@ -34,23 +34,26 @@ do_configure_prepend() { | |||
| 34 | autoreconf -Wcross --verbose --install --force --exclude=autopoint Modules/_ctypes/libffi || bbnote "_ctypes failed to autoreconf" | 34 | autoreconf -Wcross --verbose --install --force --exclude=autopoint Modules/_ctypes/libffi || bbnote "_ctypes failed to autoreconf" |
| 35 | } | 35 | } |
| 36 | 36 | ||
| 37 | # | 37 | do_compile() { |
| 38 | # Copy config.h and an appropriate Makefile for distutils.sysconfig, | 38 | # |
| 39 | # which laters uses the information out of these to compile extensions | 39 | # Copy config.h and an appropriate Makefile for distutils.sysconfig, |
| 40 | # | 40 | # which laters uses the information out of these to compile extensions |
| 41 | do_compile_prepend() { | 41 | # |
| 42 | # The following part (until python compilation) should probably moved to an | ||
| 43 | # -initial recipe to handle staging better | ||
| 44 | # | ||
| 42 | install -d ${STAGING_INCDIR}/python${PYTHON_MAJMIN}/ | 45 | install -d ${STAGING_INCDIR}/python${PYTHON_MAJMIN}/ |
| 43 | install -d ${STAGING_LIBDIR}/python${PYTHON_MAJMIN}/config/ | 46 | install -d ${STAGING_LIBDIR}/python${PYTHON_MAJMIN}/config/ |
| 44 | install -m 0644 pyconfig.h ${STAGING_INCDIR}/python${PYTHON_MAJMIN}/ | 47 | install -m 0644 pyconfig.h ${STAGING_INCDIR}/python${PYTHON_MAJMIN}/ |
| 48 | |||
| 49 | # remove hardcoded ccache, see http://bugs.openembedded.net/show_bug.cgi?id=4144 | ||
| 50 | sed -i -e s,ccache,'$(CCACHE)', Makefile | ||
| 51 | |||
| 45 | install -m 0644 Makefile Makefile.orig | 52 | install -m 0644 Makefile Makefile.orig |
| 46 | install -m 0644 Makefile Makefile.backup | 53 | sed -i -e 's,${includedir},${STAGING_INCDIR},' Makefile |
| 47 | sed -e 's,${includedir},${STAGING_INCDIR},' < Makefile.backup > Makefile | 54 | sed -i -e 's,${libdir},${STAGING_LIBDIR},' Makefile |
| 48 | install -m 0644 Makefile Makefile.backup | ||
| 49 | sed -e 's,${libdir},${STAGING_LIBDIR},' < Makefile.backup > Makefile | ||
| 50 | install -m 0644 Makefile ${STAGING_LIBDIR}/python${PYTHON_MAJMIN}/config/ | 55 | install -m 0644 Makefile ${STAGING_LIBDIR}/python${PYTHON_MAJMIN}/config/ |
| 51 | } | ||
| 52 | 56 | ||
| 53 | do_compile() { | ||
| 54 | oe_runmake HOSTPGEN=${STAGING_BINDIR_NATIVE}/pgen \ | 57 | oe_runmake HOSTPGEN=${STAGING_BINDIR_NATIVE}/pgen \ |
| 55 | HOSTPYTHON=${STAGING_BINDIR_NATIVE}/python \ | 58 | HOSTPYTHON=${STAGING_BINDIR_NATIVE}/python \ |
| 56 | STAGING_LIBDIR=${STAGING_LIBDIR} \ | 59 | STAGING_LIBDIR=${STAGING_LIBDIR} \ |
| @@ -69,6 +72,9 @@ do_compile() { | |||
| 69 | } | 72 | } |
| 70 | 73 | ||
| 71 | do_install() { | 74 | do_install() { |
| 75 | # make install needs the original Makefile, or otherwise the inclues would | ||
| 76 | # go to ${D}${STAGING...}/... | ||
| 77 | install -m 0644 Makefile Makefile.sysroot | ||
| 72 | install -m 0644 Makefile.orig Makefile | 78 | install -m 0644 Makefile.orig Makefile |
| 73 | 79 | ||
| 74 | oe_runmake HOSTPGEN=${STAGING_BINDIR_NATIVE}/pgen \ | 80 | oe_runmake HOSTPGEN=${STAGING_BINDIR_NATIVE}/pgen \ |
| @@ -78,12 +84,19 @@ do_install() { | |||
| 78 | BUILD_SYS=${BUILD_SYS} HOST_SYS=${HOST_SYS} \ | 84 | BUILD_SYS=${BUILD_SYS} HOST_SYS=${HOST_SYS} \ |
| 79 | DESTDIR=${D} LIBDIR=${libdir} install | 85 | DESTDIR=${D} LIBDIR=${libdir} install |
| 80 | 86 | ||
| 87 | install -m 0644 Makefile.sysroot ${D}/${libdir}/python${PYTHON_MAJMIN}/config/Makefile | ||
| 88 | rm Makefile.sysroot | ||
| 89 | |||
| 81 | if [ -e ${WORKDIR}/sitecustomize.py ]; then | 90 | if [ -e ${WORKDIR}/sitecustomize.py ]; then |
| 82 | install -m 0644 ${WORKDIR}/sitecustomize.py ${D}/${libdir}/python${PYTHON_MAJMIN} | 91 | install -m 0644 ${WORKDIR}/sitecustomize.py ${D}/${libdir}/python${PYTHON_MAJMIN} |
| 83 | fi | 92 | fi |
| 93 | } | ||
| 84 | 94 | ||
| 85 | # remove hardcoded ccache, see http://bugs.openembedded.net/show_bug.cgi?id=4144 | 95 | PACKAGE_PREPROCESS_FUNCS += "py_package_preprocess" |
| 86 | sed -i -e s,ccache,'$(CCACHE)', ${D}/${libdir}/python${PYTHON_MAJMIN}/config/Makefile | 96 | |
| 97 | py_package_preprocess () { | ||
| 98 | # copy back the old Makefile to fix target package | ||
| 99 | install -m 0644 Makefile.orig ${D}/${libdir}/python${PYTHON_MAJMIN}/config/Makefile | ||
| 87 | } | 100 | } |
| 88 | 101 | ||
| 89 | require python-${PYTHON_MAJMIN}-manifest.inc | 102 | require python-${PYTHON_MAJMIN}-manifest.inc |
