1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
|
global indent, indent_str, entry_p
probe begin {
indent = 0
for (i=0; i<20; i++) {
if (i == 0)
indent_str[0] = ""
else
indent_str[i] = indent_str[i-1] . " "
}
}
probe tp_syscall.* ? {
if (pid() == target()) {
if (entry_p) printf("\n")
printf("%s%s: %s (%s) = ", indent_str[indent], execname(), name, argstr)
# printf("%s%s: %s (%s) = ", indent_str[indent], execname(), probefunc(), argstr)
indent++
entry_p = 1
}
}
probe tp_syscall.*.return ? {
if (pid() == target()) {
if (indent) indent--
if (entry_p)
printf("%s\n", retstr)
else
printf("%s%s\n", indent_str[indent],retstr)
entry_p = 0
}
}
probe end {
printf("\n")
}
|