diff options
author | Andreas Gampe <agampe@google.com> | 2017-08-23 08:57:51 -0700 |
---|---|---|
committer | Andreas Gampe <agampe@google.com> | 2017-10-06 13:22:08 -0700 |
commit | 097f34cc09caf46945ec17e198f57ac9c156e904 (patch) | |
tree | 2f478bcc58ac21017431505ca87e83f4606355b4 /compiler/driver/compiler_options_map-inl.h | |
parent | 42e482f0615bd935d1426a749a413be2c3f79114 (diff) |
ART: Use CmdlineParser in dex2oat
Refactor dex2oat and the compiler to use the cmdline parser. In
an effort to standardize command-line parsing and make it easier
to add new properties in a principled manner.
Test: m test-art-host
Change-Id: Ia077a56234dbf579d7ca3430fef325b57aa06333
Diffstat (limited to 'compiler/driver/compiler_options_map-inl.h')
-rw-r--r-- | compiler/driver/compiler_options_map-inl.h | 159 |
1 files changed, 159 insertions, 0 deletions
diff --git a/compiler/driver/compiler_options_map-inl.h b/compiler/driver/compiler_options_map-inl.h new file mode 100644 index 0000000000..9cb818a270 --- /dev/null +++ b/compiler/driver/compiler_options_map-inl.h @@ -0,0 +1,159 @@ +/* + * 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 <memory> + +#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 <class Base> +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); + } + if (map.Exists(Base::PIC)) { + options->compile_pic_ = true; + } + 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; + } + map.AssignIfExists(Base::TopKProfileThreshold, &options->top_k_profile_threshold_); + map.AssignIfExists(Base::AbortOnHardVerifierFailure, &options->abort_on_hard_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_); + + return true; +} + +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wframe-larger-than=" + +template <typename Map, typename Builder> +inline void AddCompilerOptionsArgumentParserOptions(Builder& b) { + b. + Define("--compiler-filter=_") + .template WithType<std::string>() + .IntoKey(Map::CompilerFilter) + + .Define("--compile-pic") + .IntoKey(Map::PIC) + + .Define("--huge-method-max=_") + .template WithType<unsigned int>() + .IntoKey(Map::HugeMethodMaxThreshold) + .Define("--large-method-max=_") + .template WithType<unsigned int>() + .IntoKey(Map::LargeMethodMaxThreshold) + .Define("--small-method-max=_") + .template WithType<unsigned int>() + .IntoKey(Map::SmallMethodMaxThreshold) + .Define("--tiny-method-max=_") + .template WithType<unsigned int>() + .IntoKey(Map::TinyMethodMaxThreshold) + .Define("--num-dex-methods=_") + .template WithType<unsigned int>() + .IntoKey(Map::NumDexMethodsThreshold) + .Define("--inline-max-code-units=_") + .template WithType<unsigned int>() + .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("--debuggable") + .IntoKey(Map::Debuggable) + + .Define("--top-k-profile-threshold=_") + .template WithType<double>().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("--dump-init-failures=_") + .template WithType<std::string>() + .IntoKey(Map::DumpInitFailures) + + .Define("--dump-cfg=_") + .template WithType<std::string>() + .IntoKey(Map::DumpCFG) + .Define("--dump-cfg-append") + .IntoKey(Map::DumpCFGAppend) + + .Define("--register-allocation-strategy=_") + .template WithType<std::string>() + .IntoKey(Map::RegisterAllocationStrategy) + + .Define("--verbose-methods=_") + .template WithType<ParseStringList<','>>() + .IntoKey(Map::VerboseMethods); +} + +#pragma GCC diagnostic pop + +} // namespace art + +#endif // ART_COMPILER_DRIVER_COMPILER_OPTIONS_MAP_INL_H_ |