系统相关
首页 > 系统相关> > 使用g在Linux上使用Valgrind拦截全局函数

使用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