File: perf_count_event.sh

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 (28 lines) | stat: -rwxr-xr-x 806 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
#!/bin/bash
#
# Oracle Linux DTrace.
# Copyright (c) 2023, 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.

# count some event for some executable

# get the test/utils directory name
utils=`dirname $0`

# get the event to count
event=$1

# the rest of the command line is the executable and its arguments
shift

# Use "perf stat" to count "event" for this executable and its children.
#   If the output is no good, report -1.
#   If the output is time in msec, convert to nsec.
#   Otherwise, just report the count.
/usr/bin/perf stat -e $event --no-big-num -x\  $utils/$* |& gawk '
/^[^0-9]/ { print -1; exit 1 }
/ msec / { print int(1000000. * $1); exit 0 }
{ print $1; exit 0 }'

exit 0