]> sourceware.org Git - systemtap.git/commitdiff
Script to track when a specific PID receives a specific signal.
authormmason <mmason>
Tue, 5 Jun 2007 17:30:18 +0000 (17:30 +0000)
committermmason <mmason>
Tue, 5 Jun 2007 17:30:18 +0000 (17:30 +0000)
examples/sigmon.stp [new file with mode: 0755]

diff --git a/examples/sigmon.stp b/examples/sigmon.stp
new file mode 100755 (executable)
index 0000000..87ae3ea
--- /dev/null
@@ -0,0 +1,35 @@
+#!/bin/sh stap
+
+# Copyright (C) 2006 IBM Corp.
+#
+# This file is part of systemtap, and is free software.  You can
+# redistribute it and/or modify it under the terms of the GNU General
+# Public License (GPL); either version 2, or (at your option) any
+# later version.
+
+#
+# Track when a specific process ID receives a specific signal.  For example,
+# when process ID 31994 receives a SIGKILL signal.
+#
+# Example command line: 
+#
+#      stap -x 31994 sigmon.stp SIGKILL
+#
+# Example output: 
+#
+#      SPID     SNAME            RPID  RNAME            SIGNUM SIGNAME
+#      5609     bash             31994 find             9      SIGKILL 
+#
+
+probe begin
+{
+       printf("%-8s %-16s %-5s %-16s %6s %-16s\n",
+              "SPID", "SNAME", "RPID", "RNAME", "SIGNUM", "SIGNAME")
+}
+
+probe signal.send 
+{
+       if (sig_name == @1 && sig_pid == target())
+               printf("%-8d %-16s %-5d %-16s %-6d %-16s\n", 
+                       pid(), execname(), sig_pid, pid_name, sig, sig_name)
+}
This page took 0.028555 seconds and 5 git commands to generate.