bazel_adb_run.py 6.2 KB
Newer Older
Y
yejianwu 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
# Copyright 2018 Xiaomi, Inc.  All rights reserved.
#
# 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.
14 15 16 17 18 19 20 21 22

# Must run at root dir of libmace project.
# python tools/bazel_adb_run.py \
#     --target_abis=armeabi-v7a \
#     --target_socs=sdm845
#     --target=//mace/ops:ops_test
#     --stdout_processor=stdout_processor

import argparse
L
Liangliang He 已提交
23
import random
24 25 26 27 28
import re
import sys

import sh_commands

L
Liangliang He 已提交
29

30
def stdout_processor(stdout, device_properties, abi):
L
Liangliang He 已提交
31 32
    pass

33

L
Liangliang He 已提交
34
def unittest_stdout_processor(stdout, device_properties, abi):
L
Liangliang He 已提交
35 36
    stdout_lines = stdout.split("\n")
    for line in stdout_lines:
L
Liangliang He 已提交
37 38
        if "Aborted" in line or "FAILED" in line or \
                "Segmentation fault" in line:
L
Liangliang He 已提交
39 40
            raise Exception("Command failed")

41 42

def ops_benchmark_stdout_processor(stdout, device_properties, abi):
L
Liangliang He 已提交
43 44 45
    stdout_lines = stdout.split("\n")
    metrics = {}
    for line in stdout_lines:
L
Liangliang He 已提交
46
        if "Aborted" in line or "Segmentation fault" in line:
L
Liangliang He 已提交
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
            raise Exception("Command failed")
        line = line.strip()
        parts = line.split()
        if len(parts) == 5 and parts[0].startswith("BM_"):
            metrics["%s.time_ms" % parts[0]] = str(float(parts[1]) / 1e6)
            metrics["%s.input_mb_per_sec" % parts[0]] = parts[3]
            metrics["%s.gmacc_per_sec" % parts[0]] = parts[4]

    platform = device_properties["ro.board.platform"].replace(" ", "-")
    model = device_properties["ro.product.model"].replace(" ", "-")
    tags = {
        "ro.board.platform": platform,
        "ro.product.model": model,
        "abi": abi
    }
    sh_commands.falcon_push_metrics(
        metrics, tags=tags, endpoint="mace_ops_benchmark")

65 66

def parse_args():
L
Liangliang He 已提交
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
    """Parses command line arguments."""
    parser = argparse.ArgumentParser()
    parser.add_argument(
        "--target_abis",
        type=str,
        default="armeabi-v7a",
        help="Target ABIs, comma seperated list")
    parser.add_argument(
        "--target_socs",
        type=str,
        default="all",
        help="SoCs (ro.board.platform from getprop) to build, "
        "comma seperated list or all/random")
    parser.add_argument(
        "--target", type=str, default="//...", help="Bazel target to build")
    parser.add_argument(
        "--run_target",
        type=bool,
        default=False,
        help="Whether to run the target")
87 88 89 90 91 92 93 94
    parser.add_argument(
        "--valgrind",
        type=bool,
        default=False,
        help="Whether to use valgrind to check memory error.")
    parser.add_argument(
        "--valgrind_path",
        type=str,
95
        default="/data/local/tmp/valgrind",
96 97 98 99 100 101
        help="Valgrind install path.")
    parser.add_argument(
        "--valgrind_args",
        type=str,
        default="",
        help="Valgrind command args.")
L
Liangliang He 已提交
102 103 104 105 106 107 108 109
    parser.add_argument("--args", type=str, default="", help="Command args")
    parser.add_argument(
        "--stdout_processor",
        type=str,
        default="stdout_processor",
        help="Stdout processing function, default: stdout_processor")
    return parser.parse_known_args()

110 111

def main(unused_args):
L
Liangliang He 已提交
112 113 114
    target_socs = None
    if FLAGS.target_socs != "all" and FLAGS.target_socs != "random":
        target_socs = set(FLAGS.target_socs.split(','))
W
wuchenghui 已提交
115
    target_devices = sh_commands.get_target_socs_serialnos(target_socs)
L
Liangliang He 已提交
116
    if FLAGS.target_socs == "random":
117 118 119 120 121 122
        unlocked_devices = \
            [d for d in target_devices if not sh_commands.is_device_locked(d)]
        if len(unlocked_devices) > 0:
            target_devices = [random.choice(unlocked_devices)]
        else:
            target_devices = [random.choice(target_devices)]
L
Liangliang He 已提交
123 124 125 126 127 128 129 130 131 132

    target = FLAGS.target
    host_bin_path, bin_name = sh_commands.bazel_target_to_bin(target)
    target_abis = FLAGS.target_abis.split(',')

    # generate sources
    sh_commands.gen_encrypted_opencl_source()
    sh_commands.gen_compiled_opencl_source()
    sh_commands.gen_mace_version()

133 134 135 136 137
    strip = "always"
    debug = False
    if FLAGS.valgrind:
        strip = "never"
        debug = True
L
Liangliang He 已提交
138
    for target_abi in target_abis:
139 140
        sh_commands.bazel_build(target, strip=strip, abi=target_abi,
                                disable_no_tuning_warning=True, debug=debug)
L
Liangliang He 已提交
141 142 143 144 145 146 147
        if FLAGS.run_target:
            for serialno in target_devices:
                if target_abi not in set(
                        sh_commands.adb_supported_abis(serialno)):
                    print("Skip device %s which does not support ABI %s" %
                          (serialno, target_abi))
                    continue
148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
                if FLAGS.valgrind:
                    stdouts = sh_commands.adb_run_valgrind(
                        serialno,
                        host_bin_path,
                        bin_name,
                        valgrind_path=FLAGS.valgrind_path,
                        valgrind_args=FLAGS.valgrind_args,
                        args=FLAGS.args,
                        opencl_profiling=1,
                        vlog_level=0,
                        device_bin_path="/data/local/tmp/mace",
                        out_of_range_check=1)
                else:
                    stdouts = sh_commands.adb_run(
                        serialno,
                        host_bin_path,
                        bin_name,
                        args=FLAGS.args,
                        opencl_profiling=1,
                        vlog_level=0,
                        device_bin_path="/data/local/tmp/mace",
                        out_of_range_check=1)
L
Liangliang He 已提交
170 171 172 173 174
                device_properties = sh_commands.adb_getprop_by_serialno(
                    serialno)
                globals()[FLAGS.stdout_processor](stdouts, device_properties,
                                                  target_abi)

175 176

if __name__ == "__main__":
L
Liangliang He 已提交
177 178
    FLAGS, unparsed = parse_args()
    main(unused_args=[sys.argv[0]] + unparsed)