我是在debian系统(32位)上编译了一个程序文件 (并没有采用交叉编译工具链)
uname -a
Linux Debian 3.10.90-2-686 #7 SMP Fri Oct 9 20:26:23 CST 2015 i686 GNU/Linux
root@# ldd --version
ldd (Debian EGLIBC 2.11.2-10) 2.11.2
root# gcc --version
gcc (Debian 4.3.2-1.1) 4.3.2
然后想放到虚拟机ubuntu上运行(当前肯定是不能运行的,但是会出现什么错误呢)
uname -a
Linux ls-virtual-machine 4.2.0-42-generic #49~14.04.1-Ubuntu SMP Wed Jun 29 20:22:11 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux
ldd --version
ldd (Ubuntu EGLIBC 2.19-0ubuntu6.14) 2.19
gcc --version
gcc (Ubuntu 4.8.4-2ubuntu1~14.04.4) 4.8.4
问题来了:
当我执行时出现如下错误:bash: ./xxx : No such file or directory(xxx为我程序名)
奇怪了,怎么会提示找不到程序文件呢,这给了我们一个学习的机会。
这就需要了解程序执行的过程,程序执行前首先需要加载所需要的动态库,,当一个 需要动态链接 的应用被操作系统加载时,系统必须要 定位 然后 加载它所需要的所有动态库文件。 在Linux环境下,这项工作是由ld-linux.so.2来负责完成的,我们可以通过 ldd 命令来查看一个 应用需要哪些依赖的动态库:
linux-gate.so.1 => (0xb776b000)
libpthread.so.0 => /lib/i686/cmov/libpthread.so.0 (0xb774c000)
libc.so.6 => /lib/i686/cmov/libc.so.6 (0xb7606000)
/lib/ld-linux.so.2 (0xb776c000)
readelf -l xxx:
Elf file type is EXEC (Executable file)
Entry point 0x8049580
There are 7 program headers, starting at offset 52
Program Headers:
Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align
PHDR 0x000034 0x08048034 0x08048034 0x000e0 0x000e0 R E 0x4
INTERP 0x000114 0x08048114 0x08048114 0x00013 0x00013 R 0x1
[Requesting program interpreter: /lib/ld-linux.so.2]
LOAD 0x000000 0x08048000 0x08048000 0x0b684 0x0b684 R E 0x1000
LOAD 0x00b684 0x08054684 0x08054684 0x006ac 0x02288 RW 0x1000
DYNAMIC 0x00b698 0x08054698 0x08054698 0x000d8 0x000d8 RW 0x4
NOTE 0x000128 0x08048128 0x08048128 0x00020 0x00020 R 0x4
GNU_STACK 0x000000 0x00000000 0x00000000 0x00000 0x00000 RW 0x4
程序启动时,就需要把ld-linux.so.2加载器将所有的动态库加载后然后再将控制权交给程序的入口。
关于动态库的工作原理,参考:https://blog.csdn.net/hudaliquan/article/details/50055493
在Ubuntu下是找不到/lib/ld-linux.so.2,于是我就从debian的lib中把ld-linux.so.2拷贝到ubuntu中(由于ld-linux.so.2是一个软连接,实际
拷贝的文件是ld-2.11.2.so,然后再ubuntu中手动建立ld-2.11.2.so软连接)
然后再执行程序,好的,没有再报bash: ./xxx : No such file or directory错误了,看似有点效果,然而也只是有一点效果而已,
程序还是无法执行的。
程序执行会报错 bash:.xxx Permission deny. 详细原因由于时间关系留以后研究。