|  | #! /bin/sh | 
|  | # | 
|  | # Copyright 2016 the V8 project authors. All rights reserved. | 
|  | # Use of this source code is governed by a BSD-style license that can be | 
|  | # found in the LICENSE file. | 
|  | # | 
|  |  | 
|  | ########## Global variable definitions | 
|  |  | 
|  | # Ensure that <your CPU clock> / $SAMPLE_EVERY_N_CYCLES < $MAXIMUM_SAMPLE_RATE. | 
|  | MAXIMUM_SAMPLE_RATE=10000000 | 
|  | SAMPLE_EVERY_N_CYCLES=10000 | 
|  | SAMPLE_RATE_CONFIG_FILE="/proc/sys/kernel/perf_event_max_sample_rate" | 
|  | KERNEL_MAP_CONFIG_FILE="/proc/sys/kernel/kptr_restrict" | 
|  | CALL_GRAPH_METHOD="fp"  # dwarf does not play nice with JITted objects. | 
|  | EVENT_TYPE=${EVENT_TYPE:=cycles:u} | 
|  |  | 
|  | ########## Usage | 
|  |  | 
|  | usage() { | 
|  | cat << EOF | 
|  | usage: $0 <benchmark_command> | 
|  |  | 
|  | Executes <benchmark_command> under observation by Linux perf. | 
|  | Sampling event is cycles in user space, call graphs are recorded. | 
|  | EOF | 
|  | } | 
|  |  | 
|  | if [ $# -eq 0 ] || [ "$1" = "-h" ]  || [ "$1" = "--help" ] ; then | 
|  | usage | 
|  | exit 1 | 
|  | fi | 
|  |  | 
|  | ########## Actual script execution | 
|  |  | 
|  | ACTUAL_SAMPLE_RATE=$(cat $SAMPLE_RATE_CONFIG_FILE) | 
|  | if [ "$ACTUAL_SAMPLE_RATE" -lt "$MAXIMUM_SAMPLE_RATE" ] ; then | 
|  | echo "Setting appropriate maximum sample rate..." | 
|  | echo $MAXIMUM_SAMPLE_RATE | sudo tee $SAMPLE_RATE_CONFIG_FILE | 
|  | fi | 
|  |  | 
|  | ACTUAL_KERNEL_MAP_RESTRICTION=$(cat $KERNEL_MAP_CONFIG_FILE) | 
|  | if [ "$ACTUAL_KERNEL_MAP_RESTRICTION" -ne "0" ] ; then | 
|  | echo "Disabling kernel address map restriction..." | 
|  | echo 0 | sudo tee $KERNEL_MAP_CONFIG_FILE | 
|  | fi | 
|  |  | 
|  | # Extract the command being perfed, so that we can prepend arguments to the | 
|  | # arguments that the user supplied. | 
|  | COMMAND=$1 | 
|  | shift 1 | 
|  |  | 
|  | echo "Running..." | 
|  | perf record -R \ | 
|  | -e $EVENT_TYPE \ | 
|  | -c $SAMPLE_EVERY_N_CYCLES \ | 
|  | --call-graph $CALL_GRAPH_METHOD \ | 
|  | -i "$COMMAND" --perf_basic_prof "$@" |