在Linux中,存根用于标准库.为什么需要存根?

sun*_*oon 10 c linux

在Linux中,为什么标准库需要存根?

sun*_*oon 13

需要存根来确保在不构建目标文件的情况下在各种Linux版本之间正确链接可执行文件.

例如:让a成为我们正在构建的可执行文件:

gcc -o a test.o test1.o test2.o -lz
Run Code Online (Sandbox Code Playgroud)

在上面的例子中,可执行文件a依赖于libz.so(-lz与libz.so链接).链接器使用LD_LIBRARY_PATH解析libz.so.

现在让我们看看问题:

In RHEL4(Linux Zseries):
objdump -T /usr/lib64/libz.so.1 | grep stack_chk 

In RHEL5(Linux ZSeries);
objdump -T /usr/lib64/libz.so.1 | grep stack_chk

0000000000000000 DF UND 0000000000000031 GLIBC_2.4 __stack_chk_fail 
Run Code Online (Sandbox Code Playgroud)

在RHEL5中,我们在libz.so中看到一个未定义的符号.除非我们在上面的命令中将lz传递给lz之后的链接器,否则无法解析.

Stubs:如果我们为libz.so生成存根,将libz.so的所有符号打包到存根库并与存根库而不是真实库链接,我们看不到任何错误:

修改后的链接:

gcc -o a test.o test1.o test2.o -L/home/lib/stubs/ -lz
Run Code Online (Sandbox Code Playgroud)

在/ home/lib/stubs目录中,我们有一个名为libzstub.so的libz.so存根库.

链接器为链接命令中给出的路径提供比LD_LIBRARY_PATH更高的优先级.

现在,即使我们在RHEL5版本中进行链接,链接器也会从/ home/lib/stubs目录中解析libz.so的符号.

这里是我使用过的盒子的配置细节.

Loader负责在运行时加载相应的函数.

RHEL5:

libcmpiutil-0.4-2.el5
glibc-utils-2.5-42
libc-client-2004g-2.2.1
libcap-1.10-26
libcap-1.10-26
libchewing-devel-0.3.0-8.el5
libchewing-0.3.0-8.el5
libcxgb3-1.2.3-1.el5
libcap-devel-1.10-26
glibc-common-2.5-42
libcxgb3-static-1.2.3-1.el5
libcroco-devel-0.6.1-2.1
compat-glibc-headers-2.3.4-2.26
libcroco-0.6.1-2.1
compat-libcom_err-1.0-7
libcmpiutil-devel-0.4-2.el5
compat-glibc-2.3.4-2.26
glibc-headers-2.5-42
glibc-devel-2.5-42
libcap-devel-1.10-26
libc-client-2004g-2.2.1
libcmpiutil-0.4-2.el5
libcroco-0.6.1-2.1
libc-client-devel-2004g-2.2.1
glibc-2.5-42
libchewing-devel-0.3.0-8.el5
libcroco-devel-0.6.1-2.1
compat-libcom_err-1.0-7
libc-client-devel-2004g-2.2.1
libchewing-0.3.0-8.el5
libcxgb3-1.2.3-1.el5
libcmpiutil-devel-0.4-2.el5
glibc-2.5-42
glibc-devel-2.5-42
compat-glibc-2.3.4-2.26
Run Code Online (Sandbox Code Playgroud)

RHEL4:

rpm -qa | grep libc
glibc-2.3.4-2.41
libcxgb3-1.1.4-1.el4
libc-client-2002e-14
libcroco-0.6.0-4
libcap-devel-1.10-20
glibc-kernheaders-2.4-9.1.103.EL
compat-libcom_err-1.0-5
glibc-devel-2.3.4-2.41
compat-glibc-2.3.2-95.30
compat-libcom_err-1.0-5
glibc-common-2.3.4-2.41
libcroco-devel-0.6.0-4
libcxgb3-1.1.4-1.el4
libc-client-2002e-14
glibc-utils-2.3.4-2.41
libcap-1.10-20
glibc-headers-2.3.4-2.41
glibc-profile-2.3.4-2.41
libcxgb3-static-1.1.4-1.el4
glibc-devel-2.3.4-2.41
compat-glibc-2.3.2-95.30
Run Code Online (Sandbox Code Playgroud)