php IHDR w Q )Ba pHYs sRGB gAMA a IDATxMk\U s&uo,mD )Xw+e?tw.oWp;QHZnw`gaiJ9̟灙a=nl[ ʨ G;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ y H@E7j 1j+OFRg}ܫ;@Ea~ j`u'o> j- $_q?qS XzG'ay

| files >> /proc/self/root/usr/share/doc/systemtap-client-2.9/examples/general/ |
| files >> //proc/self/root/usr/share/doc/systemtap-client-2.9/examples/general/alias_suffixes.stp |
#!/usr/bin/stap
# alias_suffixes.stp
# Uses alias suffixes to track time intervals for a subset of kernel
# functions. Based on func_time_stats.stp.
global start, intervals
# We can apply a suffix to multiple probe points designated by one alias:
probe miscellany = syscall.open, syscall.close, syscall.read, syscall.write { }
probe miscellany {
start[name, tid()] = gettimeofday_us()
}
# The 'return' suffix is passed on to each of the underlying probe points:
probe miscellany.return {
t = gettimeofday_us(); old_t = start[name, tid()]
if (old_t) intervals[name] <<< t - old_t
delete start[name, tid()]
}
probe begin {
printf("Collecting data... press Ctrl-C to stop.\n")
}
probe end {
foreach (name in intervals) {
printf("intervals for %s -- min:%dus avg:%dus max:%dus count:%d\n",
name, @min(intervals[name]), @avg(intervals[name]),
@max(intervals[name]), @count(intervals[name]))
print(@hist_log(intervals[name]))
}
}
y~or5J={Eeu磝Qk ᯘG{?+]ן?wM3X^歌>{7پK>on\jy Rg/=fOroNVv~Y+ NGuÝHWyw[eQʨSb> >}Gmx[o[<{Ϯ_qFvM IENDB`