summaryrefslogtreecommitdiffstats
path: root/examples/prof.stp
diff options
context:
space:
mode:
authorhunt <hunt>2006-03-09 20:01:16 +0000
committerhunt <hunt>2006-03-09 20:01:16 +0000
commite4aab7c771fe2b08454c6c61a7887b0146f28f70 (patch)
treec96be27daf66922b54486abb5ebce892d93a058d /examples/prof.stp
parent438cd7ed199ae31e60c973d78c48d2923e344687 (diff)
downloadsystemtap-steved-e4aab7c771fe2b08454c6c61a7887b0146f28f70.tar.gz
systemtap-steved-e4aab7c771fe2b08454c6c61a7887b0146f28f70.tar.xz
systemtap-steved-e4aab7c771fe2b08454c6c61a7887b0146f28f70.zip
2006-03-09 Martin Hunt <hunt@redhat.com>
* key.stp: Toy example. * prof.stp: Example profiler. * top.stp: Print the top 20 syscalls.
Diffstat (limited to 'examples/prof.stp')
-rwxr-xr-xexamples/prof.stp35
1 files changed, 35 insertions, 0 deletions
diff --git a/examples/prof.stp b/examples/prof.stp
new file mode 100755
index 00000000..db5bdf9b
--- /dev/null
+++ b/examples/prof.stp
@@ -0,0 +1,35 @@
+#!/usr/bin/env stap
+
+# This is an example of profiling a specific command or pid.
+# It works by recordind the time when a system call is entered
+# exited.
+
+# Usage: prof.stp -c "top -n5"
+# Will start up "top" and after 5 iterations, will exit.
+#
+# Usage: prof.stp -x 3323
+# Will profile pid 3323 until it ^c is hit.
+#
+
+probe kernel.function("sys_*") {
+ if (target() == tid())
+ calltime[tid()] = gettimeofday_us()
+}
+
+probe kernel.function("sys_*").return {
+ if (target() != tid()) next
+ now = gettimeofday_us()
+ c = calltime[tid()]
+ if (!c) next
+ ttime[probefunc()] <<< now - c
+ delete calltime[tid()]
+}
+
+probe end {
+ printf("\n")
+ foreach (x in ttime)
+ printf("%-20s\tcalls:%6d\tavg time (ms):%5d\ttotal(ms):%7d\n",
+ x, @count(ttime[x]), @avg(ttime[x]), @sum(ttime[x]))
+}
+
+global calltime, ttime