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)