summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.examples/io/iotop.stp
diff options
context:
space:
mode:
authorDavid Smith <dsmith@redhat.com>2008-08-08 12:26:02 -0500
committerDavid Smith <dsmith@redhat.com>2008-08-08 12:26:02 -0500
commita9a23c6ec198c08057989d6c3fc08b8865681bc4 (patch)
tree2d28417ab9a45f3200dcda7acdf84998c9c2b383 /testsuite/systemtap.examples/io/iotop.stp
parent9963b5fc7945ce939aaa8027ca71927cb77a55ff (diff)
parent751f828801e9bd4739d03a31a77e84c91e075b4e (diff)
downloadsystemtap-steved-a9a23c6ec198c08057989d6c3fc08b8865681bc4.tar.gz
systemtap-steved-a9a23c6ec198c08057989d6c3fc08b8865681bc4.tar.xz
systemtap-steved-a9a23c6ec198c08057989d6c3fc08b8865681bc4.zip
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap into work
Diffstat (limited to 'testsuite/systemtap.examples/io/iotop.stp')
-rw-r--r--testsuite/systemtap.examples/io/iotop.stp25
1 files changed, 25 insertions, 0 deletions
diff --git a/testsuite/systemtap.examples/io/iotop.stp b/testsuite/systemtap.examples/io/iotop.stp
new file mode 100644
index 00000000..6050343c
--- /dev/null
+++ b/testsuite/systemtap.examples/io/iotop.stp
@@ -0,0 +1,25 @@
+global reads, writes, total_io
+
+probe kernel.function("vfs_read") {
+ reads[execname()] += $count
+}
+
+probe kernel.function("vfs_write") {
+ writes[execname()] += $count
+}
+
+# print top 10 IO processes every 5 seconds
+probe timer.s(5) {
+ foreach (name in writes)
+ total_io[name] += writes[name]
+ foreach (name in reads)
+ total_io[name] += reads[name]
+ printf ("%16s\t%10s\t%10s\n", "Process", "KB Read", "KB Written")
+ foreach (name in total_io- limit 10)
+ printf("%16s\t%10d\t%10d\n", name,
+ reads[name]/1024, writes[name]/1024)
+ delete reads
+ delete writes
+ delete total_io
+ print("\n")
+}