/* * Copyright (C) 2017 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. */ #ifndef ART_COMPILER_DRIVER_COMPILER_OPTIONS_MAP_INL_H_ #define ART_COMPILER_DRIVER_COMPILER_OPTIONS_MAP_INL_H_ #include "compiler_options_map.h" #include #include "android-base/logging.h" #include "android-base/macros.h" #include "android-base/stringprintf.h" #include "base/macros.h" #include "cmdline_parser.h" #include "compiler_options.h" namespace art { template inline bool ReadCompilerOptions(Base& map, CompilerOptions* options, std::string* error_msg) { if (map.Exists(Base::CompilerFilter)) { CompilerFilter::Filter compiler_filter; if (!CompilerFilter::ParseCompilerFilter(map.Get(Base::CompilerFilter)->c_str(), &compiler_filter)) { *error_msg = android::base::StringPrintf("Unknown --compiler-filter value %s", map.Get(Base::CompilerFilter)->c_str()); return false; } options->SetCompilerFilter(compiler_filter); } map.AssignIfExists(Base::HugeMethodMaxThreshold, &options->huge_method_threshold_); map.AssignIfExists(Base::LargeMethodMaxThreshold, &options->large_method_threshold_); map.AssignIfExists(Base::SmallMethodMaxThreshold, &options->small_method_threshold_); map.AssignIfExists(Base::TinyMethodMaxThreshold, &options->tiny_method_threshold_); map.AssignIfExists(Base::NumDexMethodsThreshold, &options->num_dex_methods_threshold_); map.AssignIfExists(Base::InlineMaxCodeUnitsThreshold, &options->inline_max_code_units_); map.AssignIfExists(Base::GenerateDebugInfo, &options->generate_debug_info_); map.AssignIfExists(Base::GenerateMiniDebugInfo, &options->generate_mini_debug_info_); map.AssignIfExists(Base::GenerateBuildID, &options->generate_build_id_); if (map.Exists(Base::Debuggable)) { options->debuggable_ = true; } if (map.Exists(Base::Baseline)) { options->baseline_ = true; } map.AssignIfExists(Base::TopKProfileThreshold, &options->top_k_profile_threshold_); map.AssignIfExists(Base::AbortOnHardVerifierFailure, &options->abort_on_hard_verifier_failure_); map.AssignIfExists(Base::AbortOnSoftVerifierFailure, &options->abort_on_soft_verifier_failure_); if (map.Exists(Base::DumpInitFailures)) { if (!options->ParseDumpInitFailures(*map.Get(Base::DumpInitFailures), error_msg)) { return false; } } map.AssignIfExists(Base::DumpCFG, &options->dump_cfg_file_name_); if (map.Exists(Base::DumpCFGAppend)) { options->dump_cfg_append_ = true; } if (map.Exists(Base::RegisterAllocationStrategy)) { if (!options->ParseRegisterAllocationStrategy(*map.Get(Base::DumpInitFailures), error_msg)) { return false; } } map.AssignIfExists(Base::VerboseMethods, &options->verbose_methods_); options->deduplicate_code_ = map.GetOrDefault(Base::DeduplicateCode); if (map.Exists(Base::CountHotnessInCompiledCode)) { options->count_hotness_in_compiled_code_ = true; } map.AssignIfExists(Base::ResolveStartupConstStrings, &options->resolve_startup_const_strings_); if (map.Exists(Base::CheckProfiledMethods)) { options->check_profiled_methods_ = *map.Get(Base::CheckProfiledMethods); } map.AssignIfExists(Base::MaxImageBlockSize, &options->max_image_block_size_); if (map.Exists(Base::DumpTimings)) { options->dump_timings_ = true; } if (map.Exists(Base::DumpPassTimings)) { options->dump_pass_timings_ = true; } if (map.Exists(Base::DumpStats)) { options->dump_stats_ = true; } return true; } #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wframe-larger-than=" template inline void AddCompilerOptionsArgumentParserOptions(Builder& b) { b. Define("--compiler-filter=_") .template WithType() .IntoKey(Map::CompilerFilter) .Define("--huge-method-max=_") .template WithType() .IntoKey(Map::HugeMethodMaxThreshold) .Define("--large-method-max=_") .template WithType() .IntoKey(Map::LargeMethodMaxThreshold) .Define("--small-method-max=_") .template WithType() .IntoKey(Map::SmallMethodMaxThreshold) .Define("--tiny-method-max=_") .template WithType() .IntoKey(Map::TinyMethodMaxThreshold) .Define("--num-dex-methods=_") .template WithType() .IntoKey(Map::NumDexMethodsThreshold) .Define("--inline-max-code-units=_") .template WithType() .IntoKey(Map::InlineMaxCodeUnitsThreshold) .Define({"--generate-debug-info", "-g", "--no-generate-debug-info"}) .WithValues({true, true, false}) .IntoKey(Map::GenerateDebugInfo) .Define({"--generate-mini-debug-info", "--no-generate-mini-debug-info"}) .WithValues({true, false}) .IntoKey(Map::GenerateMiniDebugInfo) .Define({"--generate-build-id", "--no-generate-build-id"}) .WithValues({true, false}) .IntoKey(Map::GenerateBuildID) .Define({"--deduplicate-code=_"}) .template WithType() .WithValueMap({{"false", false}, {"true", true}}) .IntoKey(Map::DeduplicateCode) .Define({"--count-hotness-in-compiled-code"}) .IntoKey(Map::CountHotnessInCompiledCode) .Define({"--check-profiled-methods=_"}) .template WithType() .WithValueMap({{"log", ProfileMethodsCheck::kLog}, {"abort", ProfileMethodsCheck::kAbort}}) .IntoKey(Map::CheckProfiledMethods) .Define({"--dump-timings"}) .IntoKey(Map::DumpTimings) .Define({"--dump-pass-timings"}) .IntoKey(Map::DumpPassTimings) .Define({"--dump-stats"}) .IntoKey(Map::DumpStats) .Define("--debuggable") .IntoKey(Map::Debuggable) .Define("--baseline") .IntoKey(Map::Baseline) .Define("--top-k-profile-threshold=_") .template WithType().WithRange(0.0, 100.0) .IntoKey(Map::TopKProfileThreshold) .Define({"--abort-on-hard-verifier-error", "--no-abort-on-hard-verifier-error"}) .WithValues({true, false}) .IntoKey(Map::AbortOnHardVerifierFailure) .Define({"--abort-on-soft-verifier-error", "--no-abort-on-soft-verifier-error"}) .WithValues({true, false}) .IntoKey(Map::AbortOnSoftVerifierFailure) .Define("--dump-init-failures=_") .template WithType() .IntoKey(Map::DumpInitFailures) .Define("--dump-cfg=_") .template WithType() .IntoKey(Map::DumpCFG) .Define("--dump-cfg-append") .IntoKey(Map::DumpCFGAppend) .Define("--register-allocation-strategy=_") .template WithType() .IntoKey(Map::RegisterAllocationStrategy) .Define("--resolve-startup-const-strings=_") .template WithType() .WithValueMap({{"false", false}, {"true", true}}) .IntoKey(Map::ResolveStartupConstStrings) .Define("--verbose-methods=_") .template WithType>() .IntoKey(Map::VerboseMethods) .Define("--max-image-block-size=_") .template WithType() .IntoKey(Map::MaxImageBlockSize); } #pragma GCC diagnostic pop } // namespace art #endif // ART_COMPILER_DRIVER_COMPILER_OPTIONS_MAP_INL_H_