使用g在Linux上使用Valgrind拦截全局函数
作者:互联网
根据their example,我试图用Valgrind拦截一个函数.
在使用gcc构建时,我能够拦截全局函数,但是当我用g编译相同的代码时,拦截不起作用.
我应该指定的编译器标志有什么特别之处吗?
这是我的示例应用:
#include <stdio.h>
#include "valgrind.h"
__attribute__ ((noinline))
void foo()
{
printf("inside foo\n");
}
void I_WRAP_SONAME_FNNAME_ZU(NONE,foo)()
{
OrigFn fn;
VALGRIND_GET_ORIG_FN(fn);
printf("*** Before foo()\n");
CALL_FN_v_v(fn);
printf("*** After foo()\n");
}
int main()
{
foo();
return 0;
}
使用GCC编译时,输出为:
*** Before foo()
inside foo
*** After foo()
但是当用g编译时,输出就是简单的
inside foo
解决方法:
G为没有extern“C”的函数做了名称修改.所以你应该找到一个受损的名称(例如使用nm对象)并在你的valgrind代码中使用它.或者您可以重写目标程序以使用extern“C”函数.
标签:linux,gcc,g,valgrind,interception 来源: https://codeday.me/bug/20190710/1420545.html