File: measureinterval.stp

package info (click to toggle)
systemtap 4.4-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 38,260 kB
  • sloc: cpp: 77,147; ansic: 61,828; xml: 49,277; exp: 42,244; sh: 11,046; python: 2,772; perl: 2,252; tcl: 1,305; makefile: 1,086; lisp: 105; java: 102; awk: 101; asm: 91; sed: 16
file content (40 lines) | stat: -rwxr-xr-x 835 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#! /usr/bin/env stap

# General interval measurement / monitor.  Gives a report of event interval measurement on a
# per-process or systemwide basis.
# 
# Invoke with a list of probe point patterns as script command-line arguments:
# stap measureinterval.stp 'measurement' 'match' 'accumulation' 'start_event(s)' 'end_event(s)'
#

global interval%, acc%

probe $4
{
  measure = $1
  if ($2 in interval) {
    acc[%($# >= 6 %? $6 %: 0 %)] <<< measure - interval[$2]
  }
  interval[$2] = measure;
}

# optional end of pipeline probe
probe %($# >= 5 %? $5 %: never %)
{
  measure = $1
  if ($2 in interval) {
    acc[%($# >= 6 %? $6 %: 0 %)] <<< measure - interval[$2]
    delete interval[$2]
  }
}

function report()
{
  print("\n");
  foreach(i+ in acc){
     printdln("=", "id", i)
     println($3(acc[i]))
  }
}

probe end {report()}