This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: Cross compilation using different libc is broken
Type: behavior Stage: resolved
Components: Build Versions: Python 3.9, Python 3.8, Python 3.7, Python 3.6, Python 3.5, Python 2.7
process
Status: closed Resolution: duplicate
Dependencies: Superseder: byte-compile fails for cross-builds
View: 22724
Assigned To: Nosy List: ned.deily, puchenyaka
Priority: normal Keywords:

Created on 2020-01-20 19:46 by puchenyaka, last changed 2022-04-11 14:59 by admin. This issue is now closed.

Messages (3)
msg360330 - (view) Author: Andrew Aladjev (puchenyaka) Date: 2020-01-20 19:46
Hello. I am implementing python cross compilation using "x86_64-pc-linux-musl" toolchain: "x86_64-pc-linux-musl-emerge -v1 python:3.6". Please see the following build log https://gist.github.com/andrew-aladev/e10fa5a8151ffb3c5782edd64ae08b28.

We can see the following part:

Traceback (most recent call last):
  File "/usr/x86_64-pc-linux-musl/tmp/portage/dev-lang/python-3.6.9/image//usr/lib/python3.6/compileall.py", line 17, in <module>
    import struct
  File "/usr/x86_64-pc-linux-musl/tmp/portage/dev-lang/python-3.6.9/image/usr/lib/python3.6/struct.py", line 13, in <module>
    from _struct import *
ImportError: libc.so: cannot open shared object file: No such file or directory

It means that cross compilation of python is not reliable today by design. Python is trying to use PYTHON_FOR_BUILD for loading cross compiled modules. It is not possible in general case. PYTHON_FOR_BUILD should not try to load cross compiled modules.

Please see the following gentoo issue https://bugs.gentoo.org/705970. I've attached a gentoo specific workaround there.
msg360343 - (view) Author: Ned Deily (ned.deily) * (Python committer) Date: 2020-01-20 23:13
Thanks for the report. This appears to be a duplicate of languishing Issue22724.  Suggest you join the discussion there.
msg360363 - (view) Author: Andrew Aladjev (puchenyaka) Date: 2020-01-21 08:23
Hello, it seems like issue 22724 is completely the same. Let's discuss solutions there. Thank you.
History
Date User Action Args
2022-04-11 14:59:25adminsetgithub: 83580
2020-01-21 08:23:07puchenyakasetmessages: + msg360363
2020-01-20 23:13:41ned.deilysetstatus: open -> closed

superseder: byte-compile fails for cross-builds

nosy: + ned.deily
messages: + msg360343
resolution: duplicate
stage: resolved
2020-01-20 19:46:07puchenyakacreate