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`