summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.examples/general/varwatch.stp
blob: 845ca166f92f070b68b4f37333bcb51eb77c741a (plain)
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
#! /usr/bin/env stap

global var, varerr

probe $1 {
  t=tid() # or t=0 for thread-agnostic checking
  if (@defined($2)) {
     try {
         newvar = $2;
         if (var[t] != newvar) {
            printf("%s %s changed in thread %d from %s to %s\n", pp(), @2, t, sprint(var[t]), sprint(newvar));
            var[t] = newvar;
         }
     } catch { varerr ++ }  # error during $2 resolution or perhaps var[] assignment
  }
}

probe kprocess.release { # if using per-thread checking
  delete var[$p->pid] # thread
}

probe never {
  var[0]=""  # assigns a type to var in case no probes match $1 above
}

probe error,end {
  if (varerr) printf("%s %s access errors: %d", @1, @2, varerr);
}