systemtap 用户态调试

#include <stdio.h>
int main( void)
{

int a=0;
a=fun(1115,20);
printf("%d\n",a);

}
int fun(int a,int b)
{
  return a+b;
}

test.c
gcc -g test.c

生成 a.out

----------------------------------

用SecureCRT 创建两个会话到 redhat 5.3,我已经升极内核到3.5,支持用户态调试

session 1

1.执行 stap -L 'process("./a.out").function("*")'

process("/root/a.out").function("fun@/root/test.c:11") $a:int $b:int
process("/root/a.out").function("main@/root/test.c:3") $a:int

得到以上两行结果,现在我要跟踪fun函数的值,有两个符号变量,$a,$b ,并且为整型

2.执行 stap -e 'probe process("a.out").function("fun"){printf("0x%x 0x%x\n",$a,$b )}'
         

3.session 2 中执行  [root@localhost ~]# ./a.out

 

4.观察会话2控制台中 会显示结果 0x45b 0x14

    

 

posted @ 2015-09-16 20:03  zengkefu  阅读(1345)  评论(0编辑  收藏  举报