在Linux中,为什么标准库需要存根?
答案 0 :(得分:13)
需要存根来确保在不构建目标文件的情况下在各种Linux版本之间正确链接可执行文件。
例如: 让a成为我们正在构建的可执行文件:
gcc -o a test.o test1.o test2.o -lz
在上面的例子中,可执行文件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
在RHEL5中,我们在libz.so中看到一个未定义的符号。 除非我们在上面的命令中将libc传递给lz之后的链接器,否则无法解析。
存根: 如果我们为libz.so生成存根,将libz.so的所有符号打包到存根库并与存根库而不是真实库链接,我们看不到任何错误:
修改后的链接:
gcc -o a test.o test1.o test2.o -L/home/lib/stubs/ -lz
在/ 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
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