64位系统下 编译 32位

 

64位ubuntu下编译32位汇编程序(同时链接C库)

as --32   cmd.s -o cmd.o   # 调试的话加上选项 -gstabs

ld -m elf_i386 -dynamic-linker /lib/ld-linux.so.2 cmd.o -o cmd -lc

        --32声明为32位程序   

       链接时elf_i386也是表明链接32位库

        -dynamic-linker /lib/ld-linux.so.2 使我们能链接到库,这样可执行文件会在执行前生成,而操作系统将加载程序/lib/ld-linux.so.2,以加载外部库并将其链接到程序。这种程序称为动态链接器。

        选项-lc表示:链接库c。该库在GNU/Linux系统上的文件名称为libc.so。给定库名,在本例中为c(通常库不止一个字符),GNU /Linux链接器就爱那个字符串lib加至库名前,就爱那个字符串.so加到库名后,构成库文件名。这个库包含很多函数以自动执行各种任务。我们使用了 printf和exit。

        当我们使用-lc来链接cmd程序时,将该选项告诉链接器使用c库(即libc.so)来寻找未在cmd,o中定义过的符号。但实际上这并未增加任何代码 到我们的程序,只是在程序中说明到哪里寻找。程序cmd开始时,首先加载文件/lib/ld-linux.so.2,这是动态链接器,会查看cmd程序, 并法线改程序需要c库才能运行。因此链接器在标准目录(即/etc/ld.so.conf下以及环境变量LD_LIBRARY_PATH中的所有目录下) 查找名为libc.so的库,然后在库中查找所需符号(即printf和exit),并加载到程序的虚拟内存。最后,链接库以库中printf的实际位置 代替程序中的printf的所有实例。

   运行ldd  ./cmd

        这次会报如下信息

  1. linux-gate.so.1 =>  (0xf7763000)  
  2. libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xf7590000)  
  3. /lib/ld-linux.so.2 (0xf7764000)
 
转载:http://www.cnblogs.com/haoweishow/archive/2012/02/04/2338000.html
 
以下过程是因为本机安装Emacs之前所有的编译工程都是OK的,但是安装了Emacs之后g++就编译不了了。
 
解决/usr/bin/ld: cannot find -lc过程
1. 在本机系统中搜索libc.so
2. 搜索到的结果:/lib/i386-linux-gnu/libc.so.6
3. 进入/usr/lib或者/usr/local/lib目录
4. 建立libc.so的软连接:ln -sv /lib/i386-linux-gnu/libc.so.6 libc.so
 
解决/usr/bin/ld: cannot find -lm过程
1. 在系统中搜索libm.so
2. 搜索到的结果:/usr/lib/i386-linux-gnu/libm.so
3. 进入/usr/lib目录
4. 建立libm.so的软连接:ln -sv /usr/lib/i386-linux-gnu/libm.so libm.so

猜你喜欢

转载自pb-water.iteye.com/blog/2171048