Sophie

Sophie

distrib > Fedora > 18 > i386 > by-pkgid > 21b744155c03a240ef0ea458aef35c9d > files > 818

systemtap-client-2.2.1-1.fc18.i686.rpm

#!/usr/bin/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[%d] %s %s:\n", execname(), t, pp(), @2);
            println(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);
}