7

我遇到了一个我遇到过的最奇怪的问题。我正在为带有板载 Linux 的 ARM CPU 交叉编译一个应用程序。我正在使用buildroot,一切顺利,直到我尝试在目标上运行应用程序:我得到-sh: ./hw: not found. 例如:

$ cat /tmp/test.cpp 
#include <cstdio>
#include <vector>

int main(int argc, char** argv){
        printf("Hello Kitty!\n");
        return 0;
}
$ ./arm-linux-g++ -march=armv7-a /tmp/test.cpp -o /tftpboot/hw

将可执行文件加载到目标;然后在目标上发出:

# ./hw
-sh: ./hw: Permission denied
# chmod +x ./hw
# ./hw
-sh: ./hw: not found
# ls -l ./hw
-rwxr-xr-x    1 root     root          6103 Jan  1 03:40 ./hw

还有更多:在使用发行版编译器构建时arm-linux-gnueabi-g++ -march=armv7-a /tmp/test.cpp -o /tftpboot/hw,应用程序运行良好!

我通过 比较了可执行文件readelf -a -W /tftpboot/hw,但没有注意到太多差异。我在这里粘贴了两个输出。我注意到的唯一一件事是行Version5 EABI, soft-float ABIVersion5 EABI. 我尝试通过传递-mfloat-abi=softfpand来消除差异-mfloat-abi=soft,但编译器似乎忽略了它。不过我想,这并不重要,因为编译器甚至没有警告。

我还认为,如果可执行文件以某种方式不兼容,也许sh会输出此错误。但是在我的主机 PC 上,我在这种情况下看到另一个错误,例如:

$ sh /tftpboot/hw
/tftpboot/hw: 1: /tftpboot/hw: Syntax error: word unexpected (expecting ")")
4

1 回答 1

11

sh打印出这个奇怪的错误,因为它试图将您的程序作为shell 脚本运行!

您的错误./hw: not found可能是由于找不到动态链接器(AKA ELF 解释器)引起的。-static尝试使用动态加载器将其编译为静态程序或运行它:# /lib/ld-linux.so.2 ./hw或类似的东西。

如果问题是动态加载器在您的工具链和运行时环境中的命名不同,您可以修复它:

  • 在运行时环境中:带有符号链接。
  • 在工具链中:使用-Wl,--dynamic-linker=/lib/ld-linux.so.2
于 2014-07-07T09:19:32.020 回答