File: sig_by_pid.stp

package info (click to toggle)
systemtap 4.4-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 38,260 kB
  • sloc: cpp: 77,147; ansic: 61,828; xml: 49,277; exp: 42,244; sh: 11,046; python: 2,772; perl: 2,252; tcl: 1,305; makefile: 1,086; lisp: 105; java: 102; awk: 101; asm: 91; sed: 16
file content (41 lines) | stat: -rwxr-xr-x 1,083 bytes parent folder | download | duplicates (4)
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
#! /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.

#
# 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 
{
  rcv_pid = sig_pid

  sigcnt[pid(), rcv_pid, sig] <<< 1

  if (!(pid() in pid2name)) pid2name[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], @count(sigcnt[snd_pid, rcv_pid, sig_num]))
  }
}