3 # android_perf: utility for running perf on an android device
5 # The basic usage sequence is to run...
6 # 1) perf record [gm/tests/bench] # runs profiler on specified app
7 # 2) perf report # prints profiler results
8 # 3) perf clean # cleans the temporary directory used to store results
11 SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
12 source $SCRIPT_DIR/utils/android_setup.sh
13 source $SCRIPT_DIR/utils/setup_adb.sh
15 # grab and remove the perf command from the input args
16 PERF_CMD=${APP_ARGS[0]}
18 runVars=("${APP_ARGS[@]}") # shift array indices
20 # We need the debug symbols from these files
21 PERF_TMP_DIR=$(pwd)/android_perf_tmp
23 TMP_SYS_BIN=$PERF_TMP_DIR/system/bin
24 TMP_SYS_LIB=$PERF_TMP_DIR/system/lib
25 TMP_APP_LOC=$PERF_TMP_DIR/data/local/tmp
33 echo "Copying symbol files"
34 adb_pull_if_needed /system/lib/libc.so $TMP_SYS_LIB
35 adb_pull_if_needed /system/lib/libstdc++.so $TMP_SYS_LIB
36 adb_pull_if_needed /system/lib/libGLESv2.so $TMP_SYS_LIB
37 adb_pull_if_needed /system/lib/libandroid.so $TMP_SYS_LIB
38 adb_pull_if_needed /system/lib/libm.so $TMP_SYS_LIB
39 adb_pull_if_needed /system/lib/libz.so $TMP_SYS_LIB
41 # SKIA_OUT variable is set by android_setup.sh
42 if [ ! -f "${SKIA_OUT}/${runVars[0]}" ];
44 echo "Unable to find the ${runVars[0]} executable"
48 echo "Pushing simpleperf..."
49 adb_push_if_needed $SKIA_OUT/simpleperf /data/local/tmp
52 adb_push_if_needed "${SKIA_OUT}/${runVars[0]}" /data/local/tmp
53 cp "${SKIA_OUT}/${runVars[0]}" $TMP_APP_LOC
58 echo "Killing any running Skia processes."
59 $ADB shell ps | grep ${runVars[0]} | awk '{print $2}' | xargs $ADB shell kill
61 echo "Starting application"
62 $ADB shell /data/local/tmp/${runVars[@]} &
64 # WE REALLY REALLY WANT TO BE ABLE TO PASS THE SKIA_LAUNCHER APP DIRECTLY TO
65 # PERF, BUT AT THIS POINT THE DATA FILE WE GET WHEN GOING THAT ROUTE IS UNABLE
66 # TO BE READ BY THE REPORTING TOOL
67 echo "Starting profiler"
68 APP_PID=$($ADB shell ps | grep ${runVars[0]} | awk '{print $2}')
69 $ADB shell /data/local/tmp/simpleperf record -p ${APP_PID} -o /data/local/tmp/perf.data sleep 70
71 $ADB pull /data/local/tmp/perf.data $PERF_TMP_DIR/perf.data
77 adb_pull_if_needed /data/local/tmp/perf.data $PERF_TMP_DIR/perf.data
78 $SKIA_OUT/perfhost_report.py -i $PERF_TMP_DIR/perf.data --symfs=$PERF_TMP_DIR ${runVars[@]}
88 perf_setup ${runVars[@]}
91 perf_setup ${runVars[@]}
92 perf_record ${runVars[@]}
101 echo -n "ERROR: unknown perf command ($PERF_CMD), valid values: "
102 echo "setup, record, report, clean"