6

我有一个应用程序,当我尝试运行它时会出错:

/lib/libc.so.6: version `GLIBC_2.7' not found

但它需要的 glibc 2.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");

但它以来自链接器的“未找到符号 __isoc99_sscanf@@GLIBC_2.7 的版本节点”错误结尾。

4

2 回答 2

4

您的第二个版本适用于此脚本:

GLIBC_2.7 {
 global: __isoc99_sscanf;
 local: *;
};

-Wl,--version-script=script.txt但是,使用sscanf@GLIBC_2.4.

无论如何,也许您想-D_GNU_SOURCE改用;完全避免__isoc99_sscanf

于 2010-09-27T04:10:34.600 回答
2

我发现@felipec答案很有帮助。此外,我们的应用程序必须使用 ocaml 进行一些动态链接,我们发现给定的脚本不适用于这种情况,因为它使应用程序仅将 __isoc99_sscanf 符号导出为全局符号。

GLIBC_2.7 {
 global: *;
};

上面的脚本解决了这个问题并允许 ocaml 的动态链接器正常工作。仅使用该-D_GNU_SOURCE选项不足以避免此问题,因为对 GLIBC_2.7 的依赖来自我们静态链接的预构建二进制文件。

于 2011-03-28T07:34:04.360 回答