使用g在Linux上使用Valgrind拦截全局函数
发布时间:2020-12-13 23:21:44 所属栏目:Linux 来源:网络整理
导读:根据 their example,我试图用Valgrind拦截一个函数. 在使用gcc构建时,我能够拦截全局函数,但是当我用g编译相同的代码时,拦截不起作用. 我应该指定的编译器标志有什么特别之处吗? 这是我的示例应用: #include stdio.h#include "valgrind.h"__attribute__ ((
根据
their example,我试图用Valgrind拦截一个函数.
在使用gcc构建时,我能够拦截全局函数,但是当我用g编译相同的代码时,拦截不起作用. 我应该指定的编译器标志有什么特别之处吗? 这是我的示例应用: #include <stdio.h> #include "valgrind.h" __attribute__ ((noinline)) void foo() { printf("inside foon"); } 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编译时,输出为:
但是当用g编译时,输出就是简单的
解决方法
G为没有extern“C”的函数做了名称修改.所以你应该找到一个受损的名称(例如使用nm对象)并在你的valgrind代码中使用它.或者您可以重写目标程序以使用extern“C”函数.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |