#!/bin/bash # Copyright (C) 2016 The Android Open Source Project # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # Include some functions from common.sh. SCRIPT_DIR="$(dirname "$(readlink -f "$0")")" source ${SCRIPT_DIR}/common.sh OUT_DATA_DIR="test_out" # Disable REMOTE for test on local REMOTE="--remote" TEST_COUNT=10 DEBUG=false apply_overlay() { local overaly="$1" local base_dts="$2" local overlay_dts="$3" local merged_dts="$4" local summary=0 for i in $(seq 1 $TEST_COUNT); do TIME=$(./apply_overlay.sh "--$overaly" $REMOTE \ "$base_dts" "$overlay_dts" "$merged_dts" \ | sed -E "s/.*took ([0-9]+\\.[0-9]+) secs/\\1/") if $DEBUG; then echo "time=$TIME" fi summary=$(echo "$summary + $TIME" | bc -l) done AVERAY=$(echo "scale=9; $summary/$TEST_COUNT" | bc -l) printf "%10s Average time=%s\n" "($overaly)" "$AVERAY" } run_performance_test() { # see ufdt_gen_test_dts.c for detail local node_depth="$1" local node_unused="$2" local node_count="$3" local append_count="$4" local override_count="$5" mkdir -p "$OUT_DATA_DIR" >& /dev/null # # Prepare dtb and dtbo files # local base_dts="${OUT_DATA_DIR}/base.dts" echo " Base DT: depth=$node_depth unused=$node_unused nodes=$node_count" ufdt_gen_test_dts -n $node_count -d $node_depth -u $node_unused \ -o "$base_dts" if $DEBUG; then cat "$base_dts" fi local overlay_dts="${OUT_DATA_DIR}/overlay.dts" echo " Overlay DT: append=$append_count override=$override_count" ufdt_gen_test_dts -p -a $append_count -w $override_count \ -o "$overlay_dts" if $DEBUG; then cat "$overlay_dts" fi local merged_dts="${OUT_DATA_DIR}/overlay_merged.dts" apply_overlay fdt $base_dts $overlay_dts $merged_dts apply_overlay ufdt $base_dts $overlay_dts $merged_dts rm -rf "$OUT_DATA_DIR" } main() { alert "========== Running Performance Tests ==========" if [ -z "$ANDROID_BUILD_TOP" ]; then die "Run envsetup.sh / lunch yet?" fi if ! command_exists ufdt_gen_test_dts || ! command_exists dtc; then die "Run mmma $(dirname $SCRIPT_DIR) yet?" fi if [ "$REMOTE" == "--remote" ]; then adb get-state > /dev/null if [ "$?" -ne "0" ]; then die "adb can not connect to device." fi fi # cd to ${SCRIPT_DIR} in a subshell because gen_test.sh uses relative # paths for dependent files. cd "${SCRIPT_DIR}" # # run_performance_test # <node_depth> <node_unused> <node_count> <append_count> <override_count> # Test case #1: node=x append=100 override=100 for t in $(seq 200 50 1000); do run_performance_test 2 0 $t 100 100 done # Test case #2: node=x append=100 override=100 for t in $(seq 200 50 1000); do run_performance_test 2 $t $t 100 100 done # Test case #3: node=2000 append=X for t in $(seq 50 50 1000); do run_performance_test 2 0 2000 $t 0 done # Test case #4: node=2000 override=X for t in $(seq 50 50 1000); do run_performance_test 2 0 2000 0 $t done } main "$@"