ARM Linux应用程序not found 问题

今天,移植 openssh-portable 到imx6ul板子上,交叉编译OK。

 

放板子上执行,除错。

 

root@imx6ulevk:/mnt/nfs/ssh# ./ssh-keygen
-sh: ./ssh-keygen: not found

 

root@imx6ulevk:/mnt/nfs/ssh# ./scp
-sh: ./scp: not found

 

问题

  • 在板子上执行应用程序时报错 -/bin/ash: ./xxx not found

解决方法:

  • 在搭建了交叉编译工具的平台上用交叉编译工具自带的readelf查看该应用程序需要的动态链接库和program interpreter
  • 查看动态链接库 arm-..-linux-..-readelf -d test 
    这里写图片描述

Shared library 为所需的库,可以在板子上 cd /lib 查看 /lib 目录下是否有这些需要的库,同时有的依赖库时可能在该应用程序自身文件目录下

  • 查看program interpreter arm-..-linux-..-readelf -l test 
  • è¿éåå¾çæè¿°
  • 该应用程序需要的就是 ld-linux-armhf.so.3这个库。应用程序not found 很多时候是interpreter的原因。 
    在交叉编译时,可以给gcc加上 -muclibc ,就更改了interpreter,但是这种方法我还没试过。 
    另一种方法是用ln指令把 ld-2.13.so (/lib下的一个库,可能版本不一样) 连接到 ld-linux-armhf.so.3 上,即 ln -s /lib/ld-2.13.so /lib/ld-linux-armhf.so.3 之后就发现应用程序就可以运行了。

第一种方法使用于,源码已知的情况,第二种方法适用于应用程序源码未知,并且更方便快速。

 

经过对比,发现板子运行环境没有所需的interpreter。

解决办法:将/lib/ld-xxx.so, 连接到对应的so

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章