File: countcalls.d

package info (click to toggle)
dtrace 2.0.5-1
  • links: PTS
  • area: main
  • in suites: sid
  • size: 24,408 kB
  • sloc: ansic: 61,247; sh: 17,997; asm: 1,717; lex: 947; awk: 754; yacc: 695; perl: 37; sed: 17; makefile: 15
file content (45 lines) | stat: -rwxr-xr-x 1,398 bytes parent folder | download
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
43
44
45
/*
 * Oracle Linux DTrace.
 * Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
 * Licensed under the Universal Permissive License v 1.0 as shown at
 * http://oss.oracle.com/licenses/upl.
 */

/*
 *  NAME
 *    countcalls.d - count the open(), read(), and write() calls for 5 seconds
 *
 *  SYNOPSIS
 *    sudo dtrace -s countcalls.d
 *
 *  DESCRIPTION
 *    List and count the calls to write(), read(), and open() executed, while
 *    the script is running.  The script automatically stops after 5 seconds.
 *
 *  NOTES
 *    - This script uses the profile provider to stop the tracing after a
 *    certain amount of time.  This time can easily be adjusted by changing.
 *    the number and unit.
 *
 *    - An anonymous aggregation is used to store the results.  Like a named
 *    aggregation, it is automatically printed when the tracing terminates.
 */

/*
 *  Fires every 5 seconds.  Since exit() is called, the tracing terminates
 *  the first time this probe fires and the clause is executed.
 */
profile:::tick-5sec
{
  exit(0);
}

/*
 *  Create the key by concatenating the function name and a string.  An
 *  alternative is to only use probefunc as a key and print the string as
 *  part of a printa() in the END probe: printa("%s () calls\n",@);
 */
syscall::write:entry, syscall::read:entry, syscall::open:entry
{
  @[strjoin(probefunc,"() calls")] = count();
}