尝试运行此可执行文件时为什么会出错?

时间:2015-08-24 16:59:26

标签: linux cx-freeze nuitka

我正在尝试将python 3应用程序部署到带有armv7架构的嵌入式Linux(Yocto)机器上。由于包装有限,我正在我的覆盆子pi(具有相同的armv7架构)上创建一个带有cx-freeze的独立文件。现在,如果我尝试在目标机器上运行创建的二进制文件,我会收到一个错误,表明源代码是为另一个平台编译的:

root@target:/media/sda/dist# ./helloworld
-sh: ./helloworld: No such file or directory

此可执行文件适用于构建计算机。

我已经将file-command的输出与在目标机器上运行的另一个应用程序进行了比较:

这是的文件:

root@target:/media/sda/dist# file helloworld
helloworld: ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.26, BuildID[sha1]=99b2ae19f1e65dc26b6fd7d8b1dbc83f974830bd, stripped

这是另一个 在目标机器上工作的二进制文件:

root@target:/usr/bin# file demo-application
demo-application: ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.16, BuildID[sha1]=bd6660c43d9e98c59dfa8b16eb26277aa4f19949, stripped

唯一的区别似乎是所需的最低内核版本,但是uname显示实际版本是3.0.35:

root@target:/media/sda/dist# uname -a
Linux Target-Machine 3.0.35-Yocto-21.0-r5061-0-svn2437 #1 PREEMPT Fri Jun 19 21:40:10 CEST 2015 armv7l GNU/Linux

覆盆子pi构建机器的uname输出:

pi@raspberrypi ~/py/helloworld $ uname -a
Linux raspberrypi 3.18.11-v7+ #781 SMP PREEMPT Tue Apr 21 18:07:59 BST 2015 armv7l GNU/Linux

我在这里做错了什么?它应该不是实际的python代码或依赖项的问题,我尝试使用一个非常简单的helloworld应用程序和一行代码。

修改

在构建机器上输出ldd命令(使用nuitka创建的exe):

pi@raspberrypi ~/py/helloworld/helloworld.dist $ ldd helloworld.exe
    /usr/lib/arm-linux-gnueabihf/libcofi_rpi.so (0x76faf000)
    libdl.so.2 => /home/pi/py/helloworld/helloworld.dist/./libdl.so.2 (0x76fa4000)
    libpython3.2mu.so.1.0 => /home/pi/py/helloworld/helloworld.dist/./libpython3.2mu.so.1.0 (0x76ccf000)
    libstdc++.so.6 => /home/pi/py/helloworld/helloworld.dist/./libstdc++.so.6 (0x76bfd000)
    libm.so.6 => /home/pi/py/helloworld/helloworld.dist/./libm.so.6 (0x76b8c000)
    libgcc_s.so.1 => /home/pi/py/helloworld/helloworld.dist/./libgcc_s.so.1 (0x76b64000)
    libc.so.6 => /home/pi/py/helloworld/helloworld.dist/./libc.so.6 (0x76a33000)
    /lib/ld-linux-armhf.so.3 (0x76fbc000)
    libz.so.1 => /home/pi/py/helloworld/helloworld.dist/./libz.so.1 (0x76a15000)
    libexpat.so.1 => /home/pi/py/helloworld/helloworld.dist/./libexpat.so.1 (0x769ec000)
    libpthread.so.0 => /home/pi/py/helloworld/helloworld.dist/./libpthread.so.0 (0x769cd000)
    libutil.so.1 => /home/pi/py/helloworld/helloworld.dist/./libutil.so.1 (0x769c2000)

编辑2

我尝试nuitka编译python代码并使用以下命令创建一个独立的应用程序:

nuitka --standalone --recurse-all helloworld.py

生成可执行文件helloworld.exe文件以及所有已编译的库文件(.so)。 但是,在目标机器上,当我尝试运行时,我仍然得到:

root@target:~/helloworld/helloworld.dist# ./helloworld.exe -sh: ./helloworld.exe: No such file or directory

不幸的是,我无法在目标计算机上运行lddreadelf命令,因为它们的软件包丢失了。

编辑3

它似乎真的缺少一些库。出于实验目的,我将ld-linux-armhf.so.3从raspi复制到嵌入式系统,它显示了一个不同的错误(缺少另一个库)。我认为另一个问题是raspberry pi使用hardfloat(armhf)而嵌入式系统使用softfloat ..我不认为我可以这样工作。

编辑4 我现在正在使用另一个平台和操作系统,一切正常,所以这个问题不再适用于我。

1 个答案:

答案 0 :(得分:0)

在目标计算机上运行此命令:

chmod +x helloworld

它使您的文件可执行。