This is the mail archive of the
systemtap@sourceware.org
mailing list for the systemtap project.
traceio.stp diff #2
- From: Kai Meyer <kai at fiber dot net>
- To: systemtap at sources dot redhat dot com
- Date: Mon, 27 Apr 2009 16:12:29 -0600
- Subject: traceio.stp diff #2
fche in the IRC channel suggested we index on both the pid and execname.
If we do, we get the following:
--- traceio.stp.orig 2009-04-27 15:17:38.000000000 -0600
+++ traceio.stp 2009-04-27 16:12:15.000000000 -0600
@@ -10,22 +10,20 @@
global reads, writes, total_io
probe vfs.read.return {
- reads[execname()] += $return
+ reads[pid(),execname()] += $return
+ total_io[pid(),execname()] += $return
}
probe vfs.write.return {
- writes[execname()] += $return
+ writes[pid(),execname()] += $return
+ total_io[pid(),execname()] += $return
}
probe timer.s(1) {
- foreach (p in reads)
- total_io[p] += reads[p]
- foreach (p in writes)
- total_io[p] += writes[p]
- foreach(p in total_io- limit 10)
- printf("%15s r: %8d KiB w: %8d KiB\n",
- p, reads[p]/1024,
- writes[p]/1024)
+ foreach([p,e] in total_io- limit 10)
+ printf("%8d %15s r: %8d MiB w: %8d MiB\n",
+ p, e, reads[p,e]/1024/1024,
+ writes[p,e]/1024/1024)
printf("\n")
# Note we don't zero out reads, writes and total_io,
# so the values are cumulative since the script started.