Exemplo n.º 1
0
def bazel_build(target, abi, executor, device_types):
    print("* Build %s for %s with ABI %s" %
          (target, base_pb2.ExecutorType.Name(executor), abi))
    if abi == "host":
        bazel_args = (
            "build",
            target,
        )
    else:
        bazel_args = (
            "build",
            target,
            "--config",
            ABI_TOOLCHAIN_CONFIG[abi],
            "--cpu=%s" % abi,
            "--action_env=ANDROID_NDK_HOME=%s" %
            os.environ["ANDROID_NDK_HOME"],
        )
    bazel_args += ("--define",
                   "%s=true" % base_pb2.ExecutorType.Name(executor).lower())
    if executor == base_pb2.MACE:
        bazel_args += ("--define", "neon=true")
        bazel_args += ("--define", "openmp=true")
        bazel_args += ("--define", "opencl=true")
        bazel_args += ("--define", "quantize=true")
        if base_pb2.DSP in device_types:
            bazel_args += ("--define", "hexagon=true")

    sh.bazel(_fg=True, *bazel_args)
    print("Build done!\n")
Exemplo n.º 2
0
def bazel_build(target,
                abi="armeabi-v7a",
                hexagon_mode=False,
                enable_openmp=True,
                enable_neon=True,
                enable_opencl=True,
                address_sanitizer=False,
                symbol_hidden=True,
                extra_args=""):
    print("* Build %s with ABI %s" % (target, abi))
    if abi == "host":
        bazel_args = (
            "build",
            "--define",
            "openmp=%s" % str(enable_openmp).lower(),
            target,
        )
    else:
        bazel_args = ("build", target, "--config", "android", "--cpu=%s" % abi,
                      "--define", "neon=%s" % str(enable_neon).lower(),
                      "--define", "openmp=%s" % str(enable_openmp).lower(),
                      "--define", "opencl=%s" % str(enable_opencl).lower(),
                      "--define", "hexagon=%s" % str(hexagon_mode).lower())
    if address_sanitizer:
        bazel_args += ("--config", "asan")
    else:
        bazel_args += ("--config", "optimization")
    if symbol_hidden:
        bazel_args += ("--config", "symbol_hidden")
    if extra_args:
        bazel_args += (extra_args, )
        print bazel_args
    sh.bazel(_fg=True, *bazel_args)
    print("Build done!\n")
Exemplo n.º 3
0
def bazel_build(serialno, target, abi, frameworks, runtimes):
    print("* Build %s with ABI %s" % (target, abi))
    if abi == "host":
        bazel_args = (
            "build",
            target,
        )
    else:
        bazel_args = (
            "build",
            target,
            "--config",
            "android",
            "--cpu=%s" % abi,
            "--action_env=ANDROID_NDK_HOME=%s" %
            os.environ["ANDROID_NDK_HOME"],
        )
    for framework in frameworks:
        bazel_args += ("--define", "%s=true" % framework.lower())
    if "DSP" in runtimes and abi == "armeabi-v7a":
        with device_lock(serialno):
            output = sh.adb("-s", serialno, "shell",
                            "ls /system/lib/libcdsprpc.so")
            if "No such file or directory" in output:
                print("/system/lib/libcdsprpc.so does not exists! Skip DSP.")
            else:
                bazel_args += ("--define", "dsp=true")
    sh.bazel(_fg=True, *bazel_args)
    print("Build done!\n")
Exemplo n.º 4
0
def bazel_build(target,
                abi="armeabi-v7a",
                hexagon_mode=False,
                enable_openmp=True,
                enable_neon=True,
                address_sanitizer=False):
    print("* Build %s with ABI %s" % (target, abi))
    if abi == "host":
        bazel_args = (
            "build",
            "--define",
            "openmp=%s" % str(enable_openmp).lower(),
            target,
        )
    else:
        bazel_args = (
            "build",
            target,
            "--config",
            "android",
            "--cpu=%s" % abi,
            "--define",
            "neon=%s" % str(enable_neon).lower(),
            "--define",
            "openmp=%s" % str(enable_openmp).lower(),
            "--define",
            "hexagon=%s" % str(hexagon_mode).lower())
    if address_sanitizer:
        bazel_args += ("--config", "asan")
    else:
        bazel_args += ("--config", "optimization")
    sh.bazel(
        _fg=True,
        *bazel_args)
    print("Build done!\n")
Exemplo n.º 5
0
def bazel_build(target,
                abi="armeabi-v7a",
                toolchain='android',
                enable_hexagon=False,
                enable_hta=False,
                enable_apu=False,
                apu_ancient=False,
                enable_neon=True,
                enable_opencl=True,
                enable_quantize=True,
                enable_bfloat16=False,
                enable_fp16=False,
                enable_rpcmem=True,
                address_sanitizer=False,
                symbol_hidden=True,
                debug_mode=False,
                extra_args=""):
    six.print_("* Build %s with ABI %s" % (target, abi))
    if abi == "host":
        toolchain = platform.system().lower()
        bazel_args = (
            "build",
            "--config",
            toolchain,
            "--define",
            "quantize=%s" % str(enable_quantize).lower(),
            "--define",
            "bfloat16=%s" % str(enable_bfloat16).lower(),
            target,
        )
    else:
        bazel_args = ("build", target, "--config", toolchain,
                      "--cpu=%s" % abi_to_internal(abi), "--define",
                      "neon=%s" % str(enable_neon).lower(), "--define",
                      "opencl=%s" % str(enable_opencl).lower(), "--define",
                      "quantize=%s" % str(enable_quantize).lower(), "--define",
                      "bfloat16=%s" % str(enable_bfloat16).lower(), "--define",
                      "fp16=%s" % str(enable_fp16).lower(), "--define",
                      "rpcmem=%s" % str(enable_rpcmem).lower(), "--define",
                      "hexagon=%s" % str(enable_hexagon).lower(), "--define",
                      "hta=%s" % str(enable_hta).lower(), "--define",
                      "apu=%s" % str(enable_apu).lower(), "--define",
                      "apu_ancient=%s" % str(apu_ancient).lower())
    if address_sanitizer:
        bazel_args += ("--config", "asan")
    if debug_mode:
        bazel_args += ("--config", "debug")
    if not address_sanitizer and not debug_mode:
        if toolchain == "darwin" or toolchain == "ios":
            bazel_args += ("--config", "optimization_darwin")
        else:
            bazel_args += ("--config", "optimization")
        if symbol_hidden:
            bazel_args += ("--config", "symbol_hidden")
    if extra_args:
        bazel_args += (extra_args, )
        six.print_(bazel_args)
    sh.bazel(_fg=True, *bazel_args)
    six.print_(bazel_args)
    six.print_("Build done!\n")
Exemplo n.º 6
0
def bazel_build_common(target, build_args=""):
    stdout_buff = []
    process_output = make_output_processor(stdout_buff)
    sh.bazel("build",
             target + build_args,
             _tty_in=True,
             _out=process_output,
             _err_to_out=True)
    return "".join(stdout_buff)
Exemplo n.º 7
0
def bazel_build_common(target, build_args=""):
    stdout_buff = []
    process_output = make_output_processor(stdout_buff)
    sh.bazel(
        "build",
        target + build_args,
        _tty_in=True,
        _out=process_output,
        _err_to_out=True)
    return "".join(stdout_buff)
Exemplo n.º 8
0
def bazel_build(target,
                abi="armeabi-v7a",
                toolchain='android',
                hexagon_mode=False,
                enable_openmp=True,
                enable_neon=True,
                enable_opencl=True,
                enable_quantize=True,
                address_sanitizer=False,
                symbol_hidden=True,
                extra_args=""):
    six.print_("* Build %s with ABI %s" % (target, abi))
    if abi == "host":
        bazel_args = (
            "build",
            "--config",
            platform.system().lower(),
            "--define",
            "openmp=%s" % str(enable_openmp).lower(),
            "--define",
            "quantize=%s" % str(enable_quantize).lower(),
            target,
        )
    else:
        bazel_args = (
            "build",
            target,
            "--config",
            toolchain,
            "--cpu=%s" % abi_to_internal(abi),
            "--define",
            "neon=%s" % str(enable_neon).lower(),
            "--define",
            "openmp=%s" % str(enable_openmp).lower(),
            "--define",
            "opencl=%s" % str(enable_opencl).lower(),
            "--define",
            "quantize=%s" % str(enable_quantize).lower(),
            "--define",
            "hexagon=%s" % str(hexagon_mode).lower())
    if address_sanitizer:
        bazel_args += ("--config", "asan")
    else:
        bazel_args += ("--config", "optimization")
    if symbol_hidden:
        bazel_args += ("--config", "symbol_hidden")
    if extra_args:
        bazel_args += (extra_args,)
        six.print_(bazel_args)
    sh.bazel(
        _fg=True,
        *bazel_args)
    six.print_("Build done!\n")
Exemplo n.º 9
0
def bazel_build(serialno, target, abi, executor, device_types):
    print("* Build %s for %s with ABI %s" %
          (target, base_pb2.ExecutorType.Name(executor), abi))
    if abi == "host":
        bazel_args = (
            "build",
            target,
        )
    else:
        bazel_args = (
            "build",
            target,
            "--config",
            "android",
            "--cpu=%s" % abi,
            "--action_env=ANDROID_NDK_HOME=%s" %
            os.environ["ANDROID_NDK_HOME"],
        )
    bazel_args += ("--define",
                   "%s=true" % base_pb2.ExecutorType.Name(executor).lower())
    if executor == base_pb2.MACE:
        bazel_args += ("--define", "neon=true")
        bazel_args += ("--define", "openmp=true")
        bazel_args += ("--define", "opencl=true")
        bazel_args += ("--define", "quantize=true")

    avail_device_types = copy.copy(device_types)
    if base_pb2.DSP in avail_device_types:
        avail_device_types.remove(base_pb2.DSP)
        if abi == "armeabi-v7a":
            with device_lock(serialno):
                try:
                    output = sh.adb(
                        "-s", serialno, "shell",
                        "ls /system/vendor/lib/rfsa/adsp/libhexagon_nn_skel.so"
                    )  # noqa
                except sh.ErrorReturnCode_1:
                    print(
                        "/system/vendor/lib/rfsa/adsp/libhexagon_nn_skel.so does not exists! Skip DSP."
                    )  # noqa
                else:
                    if "No such file or directory" in output:
                        print(
                            "/system/vendor/lib/rfsa/adsp/libhexagon_nn_skel.so does not exists! Skip DSP."
                        )  # noqa
                    else:
                        avail_device_types.append(base_pb2.DSP)
                        bazel_args += ("--define", "hexagon=true")
    sh.bazel(_fg=True, *bazel_args)
    print("Build done!\n")

    return avail_device_types
Exemplo n.º 10
0
def bazel_build(serialno, target, abi, executors, device_types):
    print("* Build %s with ABI %s" % (target, abi))
    if abi == "host":
        bazel_args = (
            "build",
            target,
        )
    else:
        bazel_args = (
            "build",
            target,
            "--config",
            "android",
            "--cpu=%s" % abi,
            "--action_env=ANDROID_NDK_HOME=%s"
            % os.environ["ANDROID_NDK_HOME"],
        )
    for executor in executors:
        bazel_args += ("--define", "%s=true"
                       % base_pb2.ExecutorType.Name(executor).lower())
    bazel_args += ("--define", "neon=true")
    bazel_args += ("--define", "openmp=true")
    bazel_args += ("--define", "opencl=true")
    bazel_args += ("--define", "quantize=true")

    if base_pb2.DSP in device_types and abi == "armeabi-v7a":
        with device_lock(serialno):
            try:
                output = sh.adb("-s", serialno, "shell",
                                "ls /system/lib/libcdsprpc.so")
            except sh.ErrorReturnCode_1:
                print("/system/lib/libcdsprpc.so does not exists! Skip DSP.")
            else:
                if "No such file or directory" in output:
                    print("/system/lib/libcdsprpc.so does not exists! Skip DSP.")  # noqa
                else:
                    bazel_args += ("--define", "dsp=true")
                    bazel_args += ("--define", "hexagon=true")
    sh.bazel(
        _fg=True,
        *bazel_args)
    print("Build done!\n")
Exemplo n.º 11
0
def bazel_build(target, abi="armeabi-v7a", frameworks=None):
    print("* Build %s with ABI %s" % (target, abi))
    if abi == "host":
        bazel_args = (
            "build",
            target,
        )
    else:
        bazel_args = (
            "build",
            target,
            "--config",
            "android",
            "--cpu=%s" % abi,
            "--action_env=ANDROID_NDK_HOME=%s" %
            os.environ["ANDROID_NDK_HOME"],
        )
    for framework in frameworks:
        bazel_args += ("--define", "%s=true" % framework.lower())
    sh.bazel(_fg=True, *bazel_args)
    print("Build done!\n")
Exemplo n.º 12
0
def build_run_throughput_test(abi,
                              serialno,
                              vlog_level,
                              run_seconds,
                              merged_lib_file,
                              model_input_dir,
                              embed_model_data,
                              input_nodes,
                              output_nodes,
                              input_shapes,
                              output_shapes,
                              cpu_model_tag,
                              gpu_model_tag,
                              dsp_model_tag,
                              phone_data_dir,
                              strip="always",
                              input_file_name="model_input"):
    print("* Build and run throughput_test")

    model_tag_build_flag = ""
    if cpu_model_tag:
        model_tag_build_flag += "--copt=-DMACE_CPU_MODEL_TAG=%s " % \
                                cpu_model_tag
    if gpu_model_tag:
        model_tag_build_flag += "--copt=-DMACE_GPU_MODEL_TAG=%s " % \
                                gpu_model_tag
    if dsp_model_tag:
        model_tag_build_flag += "--copt=-DMACE_DSP_MODEL_TAG=%s " % \
                                dsp_model_tag

    sh.cp("-f", merged_lib_file, "mace/benchmark/libmace_merged.a")
    sh.bazel(
        "build",
        "-c",
        "opt",
        "--strip",
        strip,
        "--verbose_failures",
        "//mace/benchmark:model_throughput_test",
        "--crosstool_top=//external:android/crosstool",
        "--host_crosstool_top=@bazel_tools//tools/cpp:toolchain",
        "--cpu=%s" % abi,
        "--copt=-std=c++11",
        "--copt=-D_GLIBCXX_USE_C99_MATH_TR1",
        "--copt=-Werror=return-type",
        "--copt=-O3",
        "--define",
        "neon=true",
        "--define",
        "openmp=true",
        model_tag_build_flag,
        _fg=True)

    sh.rm("mace/benchmark/libmace_merged.a")
    sh.adb("-s",
           serialno,
           "shell",
           "mkdir",
           "-p",
           phone_data_dir)
    adb_push("%s/%s_%s" % (model_input_dir, input_file_name,
                           ",".join(input_nodes)),
             phone_data_dir,
             serialno)
    adb_push("bazel-bin/mace/benchmark/model_throughput_test",
             phone_data_dir,
             serialno)
    if not embed_model_data:
        adb_push("codegen/models/%s/%s.data" % cpu_model_tag,
                 phone_data_dir,
                 serialno)
        adb_push("codegen/models/%s/%s.data" % gpu_model_tag,
                 phone_data_dir,
                 serialno)
        adb_push("codegen/models/%s/%s.data" % dsp_model_tag,
                 phone_data_dir,
                 serialno)
    adb_push("third_party/nnlib/libhexagon_controller.so",
             phone_data_dir,
             serialno)

    sh.adb(
        "-s",
        serialno,
        "shell",
        "LD_LIBRARY_PATH=%s" % phone_data_dir,
        "MACE_CPP_MIN_VLOG_LEVEL=%s" % vlog_level,
        "MACE_RUN_PARAMETER_PATH=%s/mace_run.config" %
        phone_data_dir,
        "%s/model_throughput_test" % phone_data_dir,
        "--input_node=%s" % ",".join(input_nodes),
        "--output_node=%s" % ",".join(output_nodes),
        "--input_shape=%s" % ":".join(input_shapes),
        "--output_shape=%s" % ":".join(output_shapes),
        "--input_file=%s/%s" % (phone_data_dir, input_file_name),
        "--cpu_model_data_file=%s/%s.data" % (phone_data_dir,
                                              cpu_model_tag),
        "--gpu_model_data_file=%s/%s.data" % (phone_data_dir,
                                              gpu_model_tag),
        "--dsp_model_data_file=%s/%s.data" % (phone_data_dir,
                                              dsp_model_tag),
        "--run_seconds=%s" % run_seconds,
        _fg=True)

    print("throughput_test done!\n")
Exemplo n.º 13
0
def build_run_throughput_test(abi,
                              serialno,
                              vlog_level,
                              run_seconds,
                              merged_lib_file,
                              model_input_dir,
                              embed_model_data,
                              input_nodes,
                              output_nodes,
                              input_shapes,
                              output_shapes,
                              cpu_model_tag,
                              gpu_model_tag,
                              dsp_model_tag,
                              phone_data_dir,
                              strip="always",
                              input_file_name="model_input"):
    print("* Build and run throughput_test")

    model_tag_build_flag = ""
    if cpu_model_tag:
        model_tag_build_flag += "--copt=-DMACE_CPU_MODEL_TAG=%s " % \
                                cpu_model_tag
    if gpu_model_tag:
        model_tag_build_flag += "--copt=-DMACE_GPU_MODEL_TAG=%s " % \
                                gpu_model_tag
    if dsp_model_tag:
        model_tag_build_flag += "--copt=-DMACE_DSP_MODEL_TAG=%s " % \
                                dsp_model_tag

    sh.cp("-f", merged_lib_file, "mace/benchmark/libmace_merged.a")
    sh.bazel(
        "build",
        "-c",
        "opt",
        "--strip",
        strip,
        "--verbose_failures",
        "//mace/benchmark:model_throughput_test",
        "--crosstool_top=//external:android/crosstool",
        "--host_crosstool_top=@bazel_tools//tools/cpp:toolchain",
        "--cpu=%s" % abi,
        "--copt=-std=c++11",
        "--copt=-D_GLIBCXX_USE_C99_MATH_TR1",
        "--copt=-Werror=return-type",
        "--copt=-O3",
        "--define",
        "neon=true",
        "--define",
        "openmp=true",
        model_tag_build_flag,
        _fg=True)

    sh.rm("mace/benchmark/libmace_merged.a")
    sh.adb("-s",
           serialno,
           "shell",
           "mkdir",
           "-p",
           phone_data_dir)
    adb_push("%s/%s_%s" % (model_input_dir, input_file_name,
                           ",".join(input_nodes)),
             phone_data_dir,
             serialno)
    adb_push("bazel-bin/mace/benchmark/model_throughput_test",
             phone_data_dir,
             serialno)
    if not embed_model_data:
        adb_push("codegen/models/%s/%s.data" % cpu_model_tag,
                 phone_data_dir,
                 serialno)
        adb_push("codegen/models/%s/%s.data" % gpu_model_tag,
                 phone_data_dir,
                 serialno)
        adb_push("codegen/models/%s/%s.data" % dsp_model_tag,
                 phone_data_dir,
                 serialno)
    adb_push("third_party/nnlib/libhexagon_controller.so",
             phone_data_dir,
             serialno)

    sh.adb(
        "-s",
        serialno,
        "shell",
        "LD_LIBRARY_PATH=%s" % phone_data_dir,
        "MACE_CPP_MIN_VLOG_LEVEL=%s" % vlog_level,
        "MACE_RUN_PARAMETER_PATH=%s/mace_run.config" %
        phone_data_dir,
        "%s/model_throughput_test" % phone_data_dir,
        "--input_node=%s" % ",".join(input_nodes),
        "--output_node=%s" % ",".join(output_nodes),
        "--input_shape=%s" % ":".join(input_shapes),
        "--output_shape=%s" % ":".join(output_shapes),
        "--input_file=%s/%s" % (phone_data_dir, input_file_name),
        "--cpu_model_data_file=%s/%s.data" % (phone_data_dir,
                                              cpu_model_tag),
        "--gpu_model_data_file=%s/%s.data" % (phone_data_dir,
                                              gpu_model_tag),
        "--dsp_model_data_file=%s/%s.data" % (phone_data_dir,
                                              dsp_model_tag),
        "--run_seconds=%s" % run_seconds,
        _fg=True)

    print("throughput_test done!\n")