#include <stdio.h> int main( void) { int a=0; a=fun(1115,20); printf("%d ",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
",$a,$b )}'
3.session 2 中执行 [root@localhost ~]# ./a.out
4.观察会话2控制台中 会显示结果 0x45b 0x14