summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.examples/sigmon.stp
diff options
context:
space:
mode:
authorFrank Ch. Eigler <fche@elastic.org>2008-04-24 13:55:34 -0400
committerFrank Ch. Eigler <fche@elastic.org>2008-04-24 13:55:34 -0400
commitfe44e686c32ccb684bd5ec6df57aed00532fc024 (patch)
tree260953c84c8679572d65bf83a65884050f91d2f7 /testsuite/systemtap.examples/sigmon.stp
parentf72154b33e67069cd7c308d24255574b9fbacb1d (diff)
parent478e10649195945adf7153fe5254932df1e2a902 (diff)
downloadsystemtap-steved-fe44e686c32ccb684bd5ec6df57aed00532fc024.tar.gz
systemtap-steved-fe44e686c32ccb684bd5ec6df57aed00532fc024.tar.xz
systemtap-steved-fe44e686c32ccb684bd5ec6df57aed00532fc024.zip
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap
* 'master' of ssh://sources.redhat.com/git/systemtap: Made kernel 2.6.25 changes in task_finder.c. Move examples to testsuite/systemtap.examples
Diffstat (limited to 'testsuite/systemtap.examples/sigmon.stp')
-rwxr-xr-xtestsuite/systemtap.examples/sigmon.stp35
1 files changed, 35 insertions, 0 deletions
diff --git a/testsuite/systemtap.examples/sigmon.stp b/testsuite/systemtap.examples/sigmon.stp
new file mode 100755
index 00000000..31d7822e
--- /dev/null
+++ b/testsuite/systemtap.examples/sigmon.stp
@@ -0,0 +1,35 @@
+#! /usr/bin/env 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)
+}