3

我正在向 LD_PRELOAD 编写一个共享库并拦截来自现有库(在 linux 中)的一些调用。

我有大约 50 多个不同的函数原型和属性声明要编写,我希望代码尽可能短,因为函数原型非常大。

我遇到的问题如下:假设我想拦截对 doStuff(int, void*) 的所有调用

我有以下代码:

头文件:

typedef int (*doStuffPrototype) (int, void*);
extern doStuffPrototype dlSym_doStuff;
extern int doStuff(int, void*);

C 文件

doStuffPrototype dlSym_doStuff;
__attribute__((constructor)) void libSomething() {
    void* lib_ptr;
    dlerror();
    lib_ptr = dlopen(LIB_NAME, RTLD_LAZY);
    ...
    // Loading all references to the real library
    dlSym_doStuff = (doStuffPrototype) dlSym(lib_ptr, "doStuff");
}

好的,现在这工作正常,但我想替换标题中的以下行:

extern int doStuff(int, void*);

有类似的东西:

extern doStuffPrototype doStuff;

但后来我得到

'doStuff' 重新声明为不同类型的符号

因为它是在真正的库中声明的......但是......它与当前的语法没有问题......我必须重新编写参数......如果我取消对 typedef 的引用:

typedef int (doStuffPrototype) (int, void*);

然后extern doStuffPrototype doStuff;工作,但dlSym_doStuff = (doStuffPrototype) dlSym(lib_ptr, "doStuff");不编译...

我尝试了很多事情:这可能吗?

4

1 回答 1

0

很明显

typedef int (*doStuffPrototype) (int, void*);

typedef int (doStuffPrototype) (int, void*);

创建略有不同typedef的 s。

我的建议是创建两个不同typedef的 s 并适当地使用每个。

typedef int (doStuffPrototype) (int, void*);
typedef doStuffPrototype* doStuffPrototypePtr

并像这样使用它们:

extern doStuffPrototypePtr dlSym_doStuff;
extern doStuffPrototype doStuff;

...


dlSym_doStuff = (doStuffPrototypePtr) dlSym(lib_ptr, "doStuff");
于 2014-06-19T19:40:47.740 回答