2011-04-25 51 views
1

我需要在另一个没有安装mudflap库并具有不同glibc版本的linux发行版中运行我的程序。我试图编译我的程序用-static,但它是不可能的:gcc -nostdlib和mudflap

 
warning: Using 'getaddrinfo' in statically linked applications requires at runtime the shared libraries from the glibc version used for linking 

所以,我想-nostdlib并手动安装该库,但得到这些错误:

 
[email protected]:~/Desktop$ gcc -nostdlib -Wl,-dynamic-linker,/home/myuser/Desktop/ld-linux-x86-64.so.2,-rpath,/home/myuser/Desktop /home/myuser/Desktop/libc.so.6 -fmudflap /home/myuser/Desktop/libmudflap.so.0 /home/myuser/Desktop/libdl.so.2 simple.c 
[email protected]:~/Desktop$ ./a.out 
mf: dlsym("mmap") = NULL 
Aborted (core dumped) 
[email protected]:~/Desktop$ ldd a.out 
    linux-vdso.so.1 => (0x00007fff2bad2000) 
    libc.so.6 => /home/myuser/Desktop/libc.so.6 (0x00007fddfd521000) 
    libmudflap.so.0 => /home/myuser/Desktop/libmudflap.so.0 (0x00007fddfd175000) 
    libdl.so.2 => /home/myuser/Desktop/libdl.so.2 (0x00007fddfcf70000) 
    /home/myuser/Desktop/ld-linux-x86-64.so.2 => /lib64/ld-linux-x86-64.so.2 (0x00007fddfd884000) 
[email protected]:~/Desktop$ 
  1. 哪个ld真的被使用?在我的桌面或在/ lib64的?
  2. 必须包含哪些其他标志才能正确编译?
+0

在您正在部署到其他计算机的程序中使用mudflap是否有原因?这是一个调试工具... – 2011-04-25 13:06:13

回答

0

而不是尝试静态链接库,携带它们与您的可执行文件,并具有LD_LIBRARY_PATH或rpath指向包含它们的目录。

但是绝对不要携带libc,如果你在一个较旧的libc版本上链接你的程序,你应该是安全的。这意味着您需要在旧的或与目标系统完全相同的环境中编译应用程序。

只要不使用在编译和目标系统之间获得版本更新的符号,您也许能够脱离更新的系统。

不幸的是,静态链接要比听起来复杂得多。

0

不那么复杂。使用strace来找出你​​的二进制链接到哪些库。

gcc -Xlinker -rpath =/path/to/provided/libs -Xlinker -I/path/to/provided/linker/ld-2.11.2.so -std = c99 -D_POSIX_C_SOURCE = 200112L -fmudflap/path /to/provided/mudflap/libmudflap.so.0 simple.c