blob: 24053b40fb0aa3dd64a0b8db3f25ca8fb75aa425 [file] [log] [blame]
Ben Murdochda12d292016-06-02 14:46:10 +01001#! /bin/sh
2#
3# Copyright 2016 the V8 project authors. All rights reserved.
4# Use of this source code is governed by a BSD-style license that can be
5# found in the LICENSE file.
6#
7
8########## Global variable definitions
9
10# Ensure that <your CPU clock> / $SAMPLE_EVERY_N_CYCLES < $MAXIMUM_SAMPLE_RATE.
11MAXIMUM_SAMPLE_RATE=10000000
12SAMPLE_EVERY_N_CYCLES=10000
13SAMPLE_RATE_CONFIG_FILE="/proc/sys/kernel/perf_event_max_sample_rate"
14KERNEL_MAP_CONFIG_FILE="/proc/sys/kernel/kptr_restrict"
15CALL_GRAPH_METHOD="fp" # dwarf does not play nice with JITted objects.
16
17########## Usage
18
19usage() {
20cat << EOF
21usage: $0 <benchmark_command>
22
23Executes <benchmark_command> under observation by Linux perf.
24Sampling event is cycles in user space, call graphs are recorded.
25EOF
26}
27
28if [ $# -eq 0 ] || [ "$1" = "-h" ] || [ "$1" = "--help" ] ; then
29 usage
30 exit 1
31fi
32
33########## Actual script execution
34
35ACTUAL_SAMPLE_RATE=$(cat $SAMPLE_RATE_CONFIG_FILE)
36if [ "$ACTUAL_SAMPLE_RATE" -lt "$MAXIMUM_SAMPLE_RATE" ] ; then
37 echo "Setting appropriate maximum sample rate..."
38 echo $MAXIMUM_SAMPLE_RATE | sudo tee $SAMPLE_RATE_CONFIG_FILE
39fi
40
41ACTUAL_KERNEL_MAP_RESTRICTION=$(cat $KERNEL_MAP_CONFIG_FILE)
42if [ "$ACTUAL_KERNEL_MAP_RESTRICTION" -ne "0" ] ; then
43 echo "Disabling kernel address map restriction..."
44 echo 0 | sudo tee $KERNEL_MAP_CONFIG_FILE
45fi
46
47echo "Running..."
48perf record -R \
49 -e cycles:u \
50 -c $SAMPLE_EVERY_N_CYCLES \
51 --call-graph $CALL_GRAPH_METHOD \
52 -i $@ --perf_basic_prof