/usr/lib64/libc.so是如何生成的?

时间:2011-04-07 14:26:31

标签: linux glibc ld

[root@xx test]# cat /usr/lib64/libc.so
/* GNU ld script
   Use the shared library, but some functions are only in
   the static library, so try that secondarily.  */
OUTPUT_FORMAT(elf64-x86-64)
GROUP ( /lib64/libc.so.6 /usr/lib64/libc_nonshared.a  AS_NEEDED ( /lib64/ld-linux-x86-64.so.2 ) )

任何人都知道这种东西是如何生成的?

2 个答案:

答案 0 :(得分:9)

使用Make实用程序编译glibc时生成。

glibc的Makefile中有一条规则(由make install启动),它只需将所需的行回显到一些临时文件$@.new中:

(echo '/* GNU ld script';\
 echo '   Use the shared library, but some functions are only in';\
 echo '   the static library, so try that secondarily.  */';\
 cat $<; \
 echo 'GROUP ( $(slibdir)/libc.so$(libc.so-version)' \
      '$(libdir)/$(patsubst %,$(libtype.oS),$(libprefix)$(libc-name))'\
      ' AS_NEEDED (' $(slibdir)/$(rtld-installed-name) ') )' \
) > $@.new

然后将此文件重命名为libc.so

mv -f $@.new $@

以下是Makefile的评论,其中解释了一下:

# What we install as libc.so for programs to link against is in fact a
# link script.  It contains references for the various libraries we need.
# The libc.so object is not complete since some functions are only defined
# in libc_nonshared.a.
# We need to use absolute paths since otherwise local copies (if they exist)
# of the files are taken by the linker.

我理解为:libc.so.6不完整,需要一些不能存储在共享库中的东西。所以,glibc开发人员将这个东西移到了glibc的静态部分 - libc_nonshared.a。为了强制始终链接libc.so.6libc_nonstared.a,他们创建了一个特殊的链接脚本,指示ld链接器在被要求-lc(libc)时使用它们

非共享部分是什么?我们来看看:

$ objdump -t /usr/lib/libc_nonshared.a |grep " F "|grep -v __
00000000 g     F .text  00000058 .hidden atexit
00000000  w    F .text  00000050 .hidden stat
00000000  w    F .text  00000050 .hidden fstat
00000000  w    F .text  00000050 .hidden lstat
00000000 g     F .text  00000050 .hidden stat64
00000000 g     F .text  00000050 .hidden fstat64
00000000 g     F .text  00000050 .hidden lstat64
00000000 g     F .text  00000050 .hidden fstatat
00000000 g     F .text  00000050 .hidden fstatat64
00000000  w    F .text  00000058 .hidden mknod
00000000 g     F .text  00000050 .hidden mknodat
00000000 l     F .text  00000001 nop

atexit()*stat*()mknod个功能。为什么?真的不知道,但这是glibc的事实。

以下是一些长篇解释http://giraffe-data.com/~bryanh/giraffehome/d/note/proglib,我引用了它:

The stat() family of functions and mknod() are special.  Their
interfaces are tied so tightly to the underlying operating system that
they change occasionally. 

答案 1 :(得分:-1)

在托管系统上,您可能需要安装glibc-devel和/或glibc-devel.i686。