summaryrefslogtreecommitdiffstats
path: root/examples/sig_by_pid.stp
blob: a8e8be84fb3326ba4e2c92602fa654229a951b07 (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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#! 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.

#
# Print signal counts by process IDs in descending order.
#

global sigcnt, pid2name, sig2name

probe begin {
	print("Collecting data... Type Ctrl-C to exit and display results\n")
}

probe signal.send 
{
	snd_pid = pid()
	rcv_pid = sig_pid

	sigcnt[snd_pid, rcv_pid, sig]++

	if (!(snd_pid in pid2name)) pid2name[snd_pid] = execname()
	if (!(rcv_pid in pid2name)) pid2name[rcv_pid] = pid_name
	if (!(sig in sig2name)) sig2name[sig] = sig_name 
}

probe end
{
	printf("%-8s %-16s %-5s %-16s %-16s %s\n",
	       "SPID", "SENDER", "RPID", "RECEIVER", "SIGNAME", "COUNT")

	foreach ([snd_pid, rcv_pid, sig_num] in sigcnt-) {
		printf("%-8d %-16s %-5d %-16s %-16s %d\n", 
		       snd_pid, pid2name[snd_pid], rcv_pid, pid2name[rcv_pid],
		       sig2name[sig_num], sigcnt[snd_pid, rcv_pid, sig_num])
	}
}