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);
}
|