bazel_adb_run.py 5.9 KB
Newer Older
L
Liangliang He 已提交
1
# Copyright 2018 The MACE Authors. All Rights Reserved.
Y
yejianwu 已提交
2 3 4 5 6 7 8 9 10 11 12 13
#
# 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 23 24 25 26 27

# 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
import re
import sys

import sh_commands

L
liuqi 已提交
28
from common import *
L
Liangliang He 已提交
29

L
liuqi 已提交
30
from device import DeviceWrapper, DeviceManager
L
Liangliang He 已提交
31

32

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

40

L
liuqi 已提交
41
def ops_benchmark_stdout_processor(stdout, dev, abi):
L
Liangliang He 已提交
42 43 44
    stdout_lines = stdout.split("\n")
    metrics = {}
    for line in stdout_lines:
L
Liangliang He 已提交
45
        if "Aborted" in line or "Segmentation fault" in line:
L
Liangliang He 已提交
46 47 48 49 50 51
            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]
52
            metrics["%s.gmac_per_sec" % parts[0]] = parts[4]
L
Liangliang He 已提交
53

54 55 56 57 58 59 60
    # platform = dev[YAMLKeyword.target_socs]
    # model = dev[YAMLKeyword.device_name]
    # tags = {
    #     "ro.board.platform": platform,
    #     "ro.product.model": model,
    #     "abi": abi
    # }
L
Liangliang He 已提交
61 62
    # sh_commands.falcon_push_metrics(server,
    #    metrics, tags=tags, endpoint="mace_ops_benchmark")
L
Liangliang He 已提交
63

64

李寅 已提交
65 66 67 68 69 70 71 72 73 74 75
# TODO: after merge mace/python/tools and tools are merged,
# define str2bool as common util
def str2bool(v):
    if v.lower() in ('yes', 'true', 't', 'y', '1'):
        return True
    elif v.lower() in ('no', 'false', 'f', 'n', '0'):
        return False
    else:
        raise argparse.ArgumentTypeError('Boolean value expected.')


76
def parse_args():
L
Liangliang He 已提交
77 78 79 80 81 82 83 84 85 86 87 88
    """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, "
89
        "comma seperated list or all/random")
L
Liangliang He 已提交
90 91 92 93
    parser.add_argument(
        "--target", type=str, default="//...", help="Bazel target to build")
    parser.add_argument(
        "--run_target",
李寅 已提交
94
        type=str2bool,
L
Liangliang He 已提交
95 96 97 98 99 100
        default=False,
        help="Whether to run the target")
    parser.add_argument("--args", type=str, default="", help="Command args")
    parser.add_argument(
        "--stdout_processor",
        type=str,
101
        default="unittest_stdout_processor",
L
Liangliang He 已提交
102
        help="Stdout processing function, default: stdout_processor")
李寅 已提交
103 104 105 106 107
    parser.add_argument(
        "--enable_neon",
        type=str2bool,
        default=True,
        help="Whether to use neon optimization")
108 109 110 111
    parser.add_argument(
        '--address_sanitizer',
        action="store_true",
        help="Whether to enable AddressSanitizer")
李寅 已提交
112 113 114 115 116
    parser.add_argument(
        "--simpleperf",
        type=str2bool,
        default=False,
        help="Whether to use simpleperf stat")
L
liuqi 已提交
117 118 119 120
    parser.add_argument(
        '--device_yml',
        type=str,
        default='',
121 122
        help='embedded linux device config yml file')
    parser.add_argument('--vlog_level', type=int, default=0, help='vlog level')
L
Liangliang He 已提交
123 124
    return parser.parse_known_args()

125 126

def main(unused_args):
L
Liangliang He 已提交
127 128 129 130 131
    target = FLAGS.target
    host_bin_path, bin_name = sh_commands.bazel_target_to_bin(target)
    target_abis = FLAGS.target_abis.split(',')

    for target_abi in target_abis:
L
liuqi 已提交
132
        toolchain = infer_toolchain(target_abi)
133 134 135 136 137 138
        sh_commands.bazel_build(
            target,
            abi=target_abi,
            toolchain=toolchain,
            enable_neon=FLAGS.enable_neon,
            address_sanitizer=FLAGS.address_sanitizer)
L
Liangliang He 已提交
139
        if FLAGS.run_target:
L
liuqi 已提交
140
            target_devices = DeviceManager.list_devices(FLAGS.device_yml)
L
liuqi 已提交
141 142
            if FLAGS.target_socs != TargetSOCTag.all and\
                    FLAGS.target_socs != TargetSOCTag.random:
L
liuqi 已提交
143 144 145 146
                target_socs = set(FLAGS.target_socs.split(','))
                target_devices = \
                    [dev for dev in target_devices
                     if dev[YAMLKeyword.target_socs] in target_socs]
L
liuqi 已提交
147 148 149
            if FLAGS.target_socs == TargetSOCTag.random:
                target_devices = sh_commands.choose_a_random_device(
                    target_devices, target_abi)
L
liuqi 已提交
150

L
liuqi 已提交
151 152
            for dev in target_devices:
                if target_abi not in dev[YAMLKeyword.target_abis]:
L
Liangliang He 已提交
153
                    print("Skip device %s which does not support ABI %s" %
L
liuqi 已提交
154
                          (dev, target_abi))
L
Liangliang He 已提交
155
                    continue
L
liuqi 已提交
156 157
                device_wrapper = DeviceWrapper(dev)
                stdouts = device_wrapper.run(
158 159 160 161
                    target_abi,
                    host_bin_path,
                    bin_name,
                    args=FLAGS.args,
L
liuqi 已提交
162
                    opencl_profiling=True,
163
                    vlog_level=FLAGS.vlog_level,
L
liuqi 已提交
164
                    out_of_range_check=True,
李寅 已提交
165 166
                    address_sanitizer=FLAGS.address_sanitizer,
                    simpleperf=FLAGS.simpleperf)
167
                globals()[FLAGS.stdout_processor](stdouts, dev, target_abi)
L
Liangliang He 已提交
168

169 170

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