c – 来自Windows的交叉编译GNU ARM(BeagleBoneBlack). * .elf上的运行时错误:“没有这样的文件或目录”

前端之家收集整理的这篇文章主要介绍了c – 来自Windows的交叉编译GNU ARM(BeagleBoneBlack). * .elf上的运行时错误:“没有这样的文件或目录”前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正处于在BeagleBone Black上开发无人机飞行控制器的(非常)早期阶段.我要提到的是,对于BBB,Linux和嵌入式系统,我是一个新手.我的学术重点一直是控制理论 – 这是我在Matlab仿真之外的第一次实际实现.我目前的系统如下:

宿主 – >运行Eclipse Luna的Windows 8.1 x64(4.4.0)
目标 – > BeagleBone Black rev. B运行Ubuntu 13.10

目标信息

  1. root@arm:~# uname -a
  2. Linux arm 3.8.13-bone32 #1 SMP Fri Dec 13 20:05:25 UTC 2013 armv7l armv7l armv7l GNU/Linux

目标gcc版本

  1. Using built-in specs.
  2. COLLECT_GCC=gcc
  3. COLLECT_LTO_WRAPPER=/usr/lib/gcc/arm-linux-gnueabihf/4.8/lto-wrapper
  4. Target: arm-linux-gnueabihf
  5. Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.8.1-10ubuntu9' --with-bugurl=file:///usr/shar
  6. e/doc/gcc-4.8/README.Bugs --enable-languages=c,c++,java,go,d,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.8
  7. --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --w
  8. ith-gxx-include-dir=/usr/include/c++/4.8 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enabl
  9. e-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --disable-libitm --disable-libquadmath --ena
  10. ble-plugin --with-system-zlib --disable-browser-plugin --enable-java-awt=gtk --enable-gtk-cairo --with-java-home=/usr
  11. /lib/jvm/java-1.5.0-gcj-4.8-armhf/jre --enable-java-home --with-jvm-root-dir=/usr/lib/jvm/java-1.5.0-gcj-4.8-armhf --
  12. with-jvm-jar-dir=/usr/lib/jvm-exports/java-1.5.0-gcj-4.8-armhf --with-arch-directory=arm --with-ecj-jar=/usr/share/ja
  13. va/eclipse-ecj.jar --enable-objc-gc --enable-multiarch --enable-multilib --disable-sjlj-exceptions --with-arch=armv7-
  14. a --with-fpu=vfpv3-d16 --with-float=hard --with-mode=thumb --disable-werror --enable-checking=release --build=arm-lin
  15. ux-gnueabihf --host=arm-linux-gnueabihf --target=arm-linux-gnueabihf
  16. Thread model: posix
  17. gcc version 4.8.1 (Ubuntu/Linaro 4.8.1-10ubuntu9)

我已经安装了Sourcery Codebench Lite工具链并使用了@L_502_2@.我根据Michael Jantz提供的教学视频设置了Eclipse环境(由于限制而删除链接 – 如果感兴趣的搜索“BeagleBone的交叉编译和远程浏览”在YouTube上)进行了一些小调整,以使其在我的系统上运行.这些调整主要包括删除“–specs = rdimon.specs”和“-lrdimon”链接标志,因为我在编译时不断获得“没有这样的文件或目录”.删除这两个标志后,简单的“Hello ARM World”程序编译时没有任何问题.

将已编译的ELF文件传输到BeagleBone后,通过以下方式设置权限和可执行标志:

  1. chmod ugo-x Test6.elf

并通过以下方式运行:

  1. ./Test6.elf

我收到以下消息:

  1. root@arm:/home/ubuntu/RDKTestProgs# ./Test6.elf
  2. bash: ./Test6.elf: No such file or directory

我最初认为我的64位主机系统和32位GNU Make之间的不匹配应该不是问题,但为了消除我的疑问,我发现了一个64位GNU Make文件(由于限制而删除链接)虽然我’我不确定它的完整性.在任何情况下,当尝试在BBB上执行程序时,两个GNU Make文件都会产生相同的结果.

在浏览了几篇帖子之后,我发现了“readelf”,“strace”和“strings”工具,它们产生了以下输出.

Readelf:

  1. root@arm:/home/ubuntu/RDKTestProgs# readelf -d Test6.elf
  2. Dynamic section at offset 0x858 contains 27 entries:
  3. Tag Type Name/Value
  4. 0x00000001 (NEEDED) Shared library: [libc.so.6]
  5. 0x00000001 (NEEDED) Shared library: [libstdc++.so.6]
  6. 0x00000001 (NEEDED) Shared library: [libm.so.6]
  7. 0x00000001 (NEEDED) Shared library: [libgcc_s.so.1]
  8. 0x0000000c (INIT) 0x8550
  9. 0x0000000d (FINI) 0x87a0
  10. 0x00000019 (INIT_ARRAY) 0x10848
  11. 0x0000001b (INIT_ARRAYSZ) 8 (bytes)
  12. 0x0000001a (FINI_ARRAY) 0x10850
  13. 0x0000001c (FINI_ARRAYSZ) 4 (bytes)
  14. 0x00000004 (HASH) 0x8168
  15. 0x00000005 (STRTAB) 0x82bc
  16. 0x00000006 (SYMTAB) 0x81bc
  17. 0x0000000a (STRSZ) 444 (bytes)
  18. 0x0000000b (SYMENT) 16 (bytes)
  19. 0x00000015 (DEBUG) 0x0
  20. 0x00000003 (PLTGOT) 0x10958
  21. 0x00000002 (PLTRELSZ) 72 (bytes)
  22. 0x00000014 (PLTREL) REL
  23. 0x00000017 (JMPREL) 0x8508
  24. 0x00000011 (REL) 0x84f8
  25. 0x00000012 (RELSZ) 16 (bytes)
  26. 0x00000013 (RELENT) 8 (bytes)
  27. 0x6ffffffe (VERNEED) 0x8498
  28. 0x6fffffff (VERNEEDNUM) 3
  29. 0x6ffffff0 (VERSYM) 0x8478
  30. 0x00000000 (NULL) 0x0
  31. root@arm:/home/ubuntu/RDKTestProgs# strings Test6.elf
  32. /lib/ld-linux.so.3
  33. libc.so.6
  34. abort
  35. __libc_start_main
  36. __aeabi_atexit
  37. libstdc++.so.6
  38. __gmon_start__
  39. _Jv_RegisterClasses
  40. _ZStlsISt11char_traitsIcEERSt13basic_ostreamIcT_ES5_PKc
  41. _ITM_deregisterTMCloneTable
  42. _ITM_registerTMCloneTable
  43. _ZSt4endlIcSt11char_traitsIcEERSt13basic_ostreamIT_T0_ES6_
  44. _ZNSt8ios_base4InitD1Ev
  45. _ZNSolsEPFRSoS_E
  46. _ZNSt8ios_base4InitC1Ev
  47. _ZSt4cout
  48. libm.so.6
  49. libgcc_s.so.1
  50. __aeabi_unwind_cpp_pr0
  51. __aeabi_unwind_cpp_pr1
  52. GLIBCXX_3.4
  53. GCC_3.5
  54. GLIBC_2.4
  55. ?8FAFJF
  56. x`9`{h
  57. Hello ARM World!

strace的:

  1. root@arm:/home/ubuntu/RDKTestProgs# strace ./Test6
  2. strace: Can't stat './Test6': No such file or directory
  3. root@arm:/home/ubuntu/RDKTestProgs# strace ./Test6.elf
  4. execve("./Test6.elf",["./Test6.elf"],[/* 22 vars */]) = -1 ENOENT (No such file or directory)
  5. write(2,"strace: exec: No such file or di"...,40strace: exec: No such file or directory
  6. ) = 40
  7. exit_group(1) = ?
  8. +++ exited with 1 +++

字符串:

  1. root@arm:/home/ubuntu/RDKTestProgs# strings Test6.elf
  2. /lib/ld-linux.so.3
  3. libc.so.6
  4. abort
  5. __libc_start_main
  6. __aeabi_atexit
  7. libstdc++.so.6
  8. __gmon_start__
  9. _Jv_RegisterClasses
  10. _ZStlsISt11char_traitsIcEERSt13basic_ostreamIcT_ES5_PKc
  11. _ITM_deregisterTMCloneTable
  12. _ITM_registerTMCloneTable
  13. _ZSt4endlIcSt11char_traitsIcEERSt13basic_ostreamIT_T0_ES6_
  14. _ZNSt8ios_base4InitD1Ev
  15. _ZNSolsEPFRSoS_E
  16. _ZNSt8ios_base4InitC1Ev
  17. _ZSt4cout
  18. libm.so.6
  19. libgcc_s.so.1
  20. __aeabi_unwind_cpp_pr0
  21. __aeabi_unwind_cpp_pr1
  22. GLIBCXX_3.4
  23. GCC_3.5
  24. GLIBC_2.4
  25. ?8FAFJF
  26. x`9`{h
  27. Hello ARM World!

我通过我的BeagelBoneBlack搜索了“readelf”函数指示的4个共享库文件,发现它们实际存在.但问题是,其中一些文件位于usr / lib / arm-linux-gnueabihf /目录中,而其他文件位于/ lib / arm-linux-gnueabihf#目录中.为了解决这个问题,我创建了指向/usr/lib / arm-linux-gnueabihf /目录中找不到的文件的符号链接.这仍然没有解决问题.所以我创建了符号链接到/ lib / arm-linux-gnueabihf /目录中找不到的文件.再一次,没有运气.

有没有办法检查执行时使用的目录? Test6.elf文件中可能还缺少什么?我此刻不知所措.任何建议或指导将不胜感激!干杯!

附:我还设法检查GLIBCXX_3.4,GLIBC_2.4和GCC_3.5,如下所示,但同样,其中一些属于/usr/lib / arm-linux-gnueabihf中的文件,其他的可以在/ lib /中找到在arm-linux的-gnueabihf.再次感谢!

  1. root@arm:/lib/arm-linux-gnueabihf# strings libgcc_s.so.1 | grep GCC
  2. GCC_3.0
  3. GCC_3.3
  4. GCC_3.3.1
  5. GCC_3.3.4
  6. GCC_3.4
  7. GCC_3.4.2
  8. GCC_4.0.0
  9. GCC_4.2.0
  10. GCC_4.3.0
  11. GCC_4.7.0
  12. GCC_3.5
  13. root@arm:/usr/lib/arm-linux-gnueabihf# strings libstdc++.so.6.0.18 | grep GLIBC
  14. GLIBCXX_3.4
  15. GLIBCXX_3.4.1
  16. GLIBCXX_3.4.2
  17. GLIBCXX_3.4.3
  18. GLIBCXX_3.4.4
  19. GLIBCXX_3.4.5
  20. GLIBCXX_3.4.6
  21. GLIBCXX_3.4.7
  22. GLIBCXX_3.4.8
  23. GLIBCXX_3.4.9
  24. GLIBCXX_3.4.10
  25. GLIBCXX_3.4.11
  26. GLIBCXX_3.4.12
  27. GLIBCXX_3.4.13
  28. GLIBCXX_3.4.14
  29. GLIBCXX_3.4.15
  30. GLIBCXX_3.4.16
  31. GLIBCXX_3.4.17
  32. GLIBCXX_3.4.18
  33. GLIBCXX_3.4.19
  34. GLIBC_2.4
  35. GLIBC_2.17
  36. GLIBCXX_DEBUG_MESSAGE_LENGTH

最后,这是“Hello ARM World”计划

  1. //============================================================================
  2. // Name : main.cpp
  3. // Author : RDK
  4. // Version :
  5. // Copyright : Your copyright notice
  6. // Description : Hello World in C++
  7. //============================================================================
  8. #include
最佳答案
对吧!所以我已经开始工作了.这是我的步骤,希望它们是合理的,不会在将来引起我的问​​题.

>从this post开始,我试图找出Test6.elf期望找到动态链接库的linux加载器的位置.这产生了:

root @ arm:/ home / ubuntu / RDKTestProgs#readelf -l ./Test6.elf | grep ld-linux
      [请求程序解释器:/lib/ld-linux.so.3]
>我检查了我的/ lib文件夹,确定ld-linux.so.3文件丢失了.相反,我在/ lib / arm-linux-gnueabihf /文件夹中找到了它
>所以我通过以下方式在/ lib文件夹中创建了一个符号链接

ln -s /lib/arm-linux-gnueabihf/ld-linux.so.3 /lib/ld-linux.so.3

繁荣!有用.然而,我仍然觉得奇怪的是ldd ./Test6.elf仍然返回:

  1. root@arm:/home/ubuntu/RDKTestProgs# ldd ./Test6.elf
  2. not a dynamic executable

有没有充分的理由,或者这是否正常? – 这对我来说似乎不对.

我还注意到我将Float ABI的当前编译器设置(以及工具链)设置为soft,但我的BeagleBoneBlack正在运行arm-linux-gnueabihf – hard float.这会不会给我带来问题?我应该寻找不同的工具链吗?

干杯!

猜你在找的Linux相关文章