我有一个应用程序,当我尝试运行它时,它会出错:
/lib/libc.so.6: version `GLIBC_2.7' not found
但glibc2.7唯一需要的符号是
__isoc99_sscanf@@GLIBC_2.7
我想写一个小的单一函数“库”,用这个符号作为__sscanf()的别名。
我该如何使用gcc/ld进行此操作?
我的变体不被接受,因为"@@“符号
int __isoc99_sscanf@@GLIBC_2.7(const char *, const char *, ...) __attribute__((alias("__sscanf")));
第二,我的变体是
#include <stdarg.h>
int __isoc99_sscanf1(const char *a, const char *b, va_list args)
{
int i;
va_list ap;
va_copy(ap,args);
i=sscanf(a,b,ap);
va_end(ap);
return i;
}
// __asm__(".symver __isoc99_sscanf,__isoc99_sscanf@@GLIBC_2.7");
__asm__(".symver __isoc99_sscanf1,__isoc99_sscanf@@GLIBC_2.7");
但它以来自链接器的“symbol __isoc99_sscanf@@GLIBC_2.7的版本节点未找到”错误结束。
发布于 2011-03-28 15:34:04
我发现@felipec
的回答很有帮助。此外,我们的应用程序必须使用ocaml执行一些动态链接,我们发现给定的脚本不适用于此场景,因为它使应用程序仅将__isoc99_sscanf符号导出为全局符号。
GLIBC_2.7 {
global: *;
};
上面的脚本解决了这个问题,并允许ocaml的动态链接器正常工作。单独使用-D_GNU_SOURCE
选项不足以避免此问题,因为对GLIBC_2.7的依赖来自我们静态链接的预构建二进制文件。
发布于 2010-09-27 12:10:35
您的第二个版本使用此脚本:
GLIBC_2.7 {
global: __isoc99_sscanf;
local: *;
};
但是,使用-Wl,--version-script=script.txt
时,我不知道如何访问原始的sscanf@GLIBC_2.4
。
无论如何,为了完全避免__isoc99_sscanf
,您可能会希望使用-D_GNU_SOURCE
。
https://stackoverflow.com/questions/3660826
复制相似问题