|
|
e227b8 |
/* Example tapset file.
|
|
|
e227b8 |
*
|
|
|
e227b8 |
* You can execute the tapset using following command (please adjust the path
|
|
|
e227b8 |
* prior running the command, if needed):
|
|
|
e227b8 |
*
|
|
|
e227b8 |
* stap /usr/share/doc/ruby-2.0.0.0/ruby-exercise.stp -c "ruby -e \"puts 'test'\""
|
|
|
e227b8 |
*/
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.cmethod.entry {
|
|
|
e227b8 |
printf("%d -> %s::%s %s:%d\n", tid(), classname, methodname, file, line);
|
|
|
e227b8 |
}
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.cmethod.return {
|
|
|
e227b8 |
printf("%d <- %s::%s %s:%d\n", tid(), classname, methodname, file, line);
|
|
|
e227b8 |
}
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.method.entry {
|
|
|
e227b8 |
printf("%d -> %s::%s %s:%d\n", tid(), classname, methodname, file, line);
|
|
|
e227b8 |
}
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.method.return {
|
|
|
e227b8 |
printf("%d <- %s::%s %s:%d\n", tid(), classname, methodname, file, line);
|
|
|
e227b8 |
}
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.gc.mark.begin { printf("%d gc.mark.begin\n", tid()); }
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.gc.mark.end { printf("%d gc.mark.end\n", tid()); }
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.gc.sweep.begin { printf("%d gc.sweep.begin\n", tid()); }
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.gc.sweep.end { printf("%d gc.sweep.end\n", tid()); }
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.object.create{
|
|
|
e227b8 |
printf("%d obj.create %s %s:%d\n", tid(), classname, file, line);
|
|
|
e227b8 |
}
|
|
|
e227b8 |
|
|
|
e227b8 |
probe ruby.raise {
|
|
|
e227b8 |
printf("%d raise %s %s:%d\n", tid(), classname, file, line);
|
|
|
e227b8 |
}
|