ac8c78e01d
Reading --verify_predictable makes me sad, whereas --verify-predictable makes me happy. This CL introduces more happiness. R=machenbach@chromium.org Bug: v8:8834 Change-Id: Id51a75f32e6d5a2f87aed81e058a8b6dff189758 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1550399 Reviewed-by: Michael Achenbach <machenbach@chromium.org> Commit-Queue: Clemens Hammacher <clemensh@chromium.org> Cr-Commit-Position: refs/heads/master@{#60599}
59 lines
1.6 KiB
Bash
Executable File
59 lines
1.6 KiB
Bash
Executable File
#! /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 "$@"
|