blob: 8e4a7755584dfe458d34a267cda9ca71f2fe3d40 [file] [log] [blame]
Brian Carlstrom6449c622014-02-10 23:48:36 -08001/*
2 * Copyright (C) 2014 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ART_COMPILER_DRIVER_COMPILER_OPTIONS_H_
18#define ART_COMPILER_DRIVER_COMPILER_OPTIONS_H_
19
Andreas Gampedbfe2542014-11-25 22:21:42 -080020#include <ostream>
Ian Rogersc7dd2952014-10-21 23:31:19 -070021#include <string>
22#include <vector>
23
24#include "base/macros.h"
Andreas Gampe29d38e72016-03-23 15:31:51 +000025#include "compiler_filter.h"
Ian Rogers6a3c1fc2014-10-31 00:33:20 -070026#include "globals.h"
Matthew Gharrity2cd05b72016-08-03 16:57:37 -070027#include "optimizing/register_allocator.h"
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +000028#include "utils.h"
Ian Rogersc7dd2952014-10-21 23:31:19 -070029
Brian Carlstrom6449c622014-02-10 23:48:36 -080030namespace art {
31
Ian Rogersc7dd2952014-10-21 23:31:19 -070032class CompilerOptions FINAL {
Brian Carlstrom6449c622014-02-10 23:48:36 -080033 public:
Brian Carlstrom6449c622014-02-10 23:48:36 -080034 // Guide heuristics to determine whether to compile method if profile data not available.
Brian Carlstrom6449c622014-02-10 23:48:36 -080035 static const size_t kDefaultHugeMethodThreshold = 10000;
36 static const size_t kDefaultLargeMethodThreshold = 600;
37 static const size_t kDefaultSmallMethodThreshold = 60;
38 static const size_t kDefaultTinyMethodThreshold = 20;
39 static const size_t kDefaultNumDexMethodsThreshold = 900;
Calin Juravlec1b643c2014-05-30 23:44:11 +010040 static constexpr double kDefaultTopKProfileThreshold = 90.0;
David Srbecky3e09eeb2016-01-12 14:54:03 +000041 static const bool kDefaultGenerateDebugInfo = false;
David Srbecky5b1c2ca2016-01-25 17:32:41 +000042 static const bool kDefaultGenerateMiniDebugInfo = false;
Alex Light53cb16b2014-06-12 11:26:29 -070043 static const bool kDefaultIncludePatchInformation = false;
Calin Juravleec748352015-07-29 13:52:12 +010044 static const size_t kDefaultInlineDepthLimit = 3;
Nicolas Geoffray5949fa02015-12-18 10:57:10 +000045 static const size_t kDefaultInlineMaxCodeUnits = 32;
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +000046 static constexpr size_t kUnsetInlineDepthLimit = -1;
47 static constexpr size_t kUnsetInlineMaxCodeUnits = -1;
Brian Carlstrom6449c622014-02-10 23:48:36 -080048
Roland Levillaina215b952015-08-07 11:38:32 +010049 // Default inlining settings when the space filter is used.
50 static constexpr size_t kSpaceFilterInlineDepthLimit = 3;
51 static constexpr size_t kSpaceFilterInlineMaxCodeUnits = 10;
52
Mathieu Chartier5bdab122015-01-26 18:30:19 -080053 CompilerOptions();
Vladimir Markob163bb72015-03-31 21:49:49 +010054 ~CompilerOptions();
Brian Carlstrom6449c622014-02-10 23:48:36 -080055
Andreas Gampe29d38e72016-03-23 15:31:51 +000056 CompilerOptions(CompilerFilter::Filter compiler_filter,
Brian Carlstrom6449c622014-02-10 23:48:36 -080057 size_t huge_method_threshold,
58 size_t large_method_threshold,
59 size_t small_method_threshold,
60 size_t tiny_method_threshold,
Mark Mendellae9fd932014-02-10 16:14:35 -080061 size_t num_dex_methods_threshold,
Calin Juravleec748352015-07-29 13:52:12 +010062 size_t inline_depth_limit,
63 size_t inline_max_code_units,
Vladimir Marko47496c22016-01-27 16:15:08 +000064 const std::vector<const DexFile*>* no_inline_from,
Alex Light53cb16b2014-06-12 11:26:29 -070065 bool include_patch_information,
Alex Light78382fa2014-06-06 15:45:32 -070066 double top_k_profile_threshold,
Andreas Gampe7b2f09e2015-03-02 14:07:33 -080067 bool debuggable,
David Srbecky8363c772015-05-28 16:12:43 +010068 bool generate_debug_info,
Dave Allison69dfe512014-07-11 17:11:58 +000069 bool implicit_null_checks,
70 bool implicit_so_checks,
Igor Murashkind6dee672014-10-16 18:36:16 -070071 bool implicit_suspend_checks,
Ian Rogersc7dd2952014-10-21 23:31:19 -070072 bool compile_pic,
Andreas Gampedbfe2542014-11-25 22:21:42 -080073 const std::vector<std::string>* verbose_methods,
Andreas Gampe6cf49e52015-03-05 13:08:45 -080074 std::ostream* init_failure_output,
Nicolas Geoffrayc903b6a2016-01-18 12:56:06 +000075 bool abort_on_hard_verifier_failure,
76 const std::string& dump_cfg_file_name,
Andreas Gampeace0dc12016-01-20 13:33:13 -080077 bool dump_cfg_append,
Matthew Gharrity2cd05b72016-08-03 16:57:37 -070078 bool force_determinism,
Wojciech Staszkiewicz5319d3c2016-08-01 17:48:59 -070079 RegisterAllocator::Strategy regalloc_strategy,
80 const std::vector<std::string>* passes_to_run);
Brian Carlstrom6449c622014-02-10 23:48:36 -080081
Andreas Gampe29d38e72016-03-23 15:31:51 +000082 CompilerFilter::Filter GetCompilerFilter() const {
Brian Carlstrom6449c622014-02-10 23:48:36 -080083 return compiler_filter_;
84 }
85
Andreas Gampe29d38e72016-03-23 15:31:51 +000086 void SetCompilerFilter(CompilerFilter::Filter compiler_filter) {
Brian Carlstrom6449c622014-02-10 23:48:36 -080087 compiler_filter_ = compiler_filter;
88 }
89
Mathieu Chartiere86deef2015-03-19 13:43:37 -070090 bool VerifyAtRuntime() const {
Andreas Gampe29d38e72016-03-23 15:31:51 +000091 return compiler_filter_ == CompilerFilter::kVerifyAtRuntime;
Mathieu Chartiere86deef2015-03-19 13:43:37 -070092 }
93
Vladimir Markof6d1e0f2016-05-23 15:32:42 +010094 bool IsBytecodeCompilationEnabled() const {
95 return CompilerFilter::IsBytecodeCompilationEnabled(compiler_filter_);
96 }
97
98 bool IsJniCompilationEnabled() const {
99 return CompilerFilter::IsJniCompilationEnabled(compiler_filter_);
Jeff Hao4a200f52014-04-01 14:58:49 -0700100 }
101
102 bool IsVerificationEnabled() const {
Andreas Gampe29d38e72016-03-23 15:31:51 +0000103 return CompilerFilter::IsVerificationEnabled(compiler_filter_);
Mathieu Chartiere86deef2015-03-19 13:43:37 -0700104 }
105
106 bool NeverVerify() const {
Andreas Gampe29d38e72016-03-23 15:31:51 +0000107 return compiler_filter_ == CompilerFilter::kVerifyNone;
David Brazdilce4b0ba2016-01-28 15:05:49 +0000108 }
109
Mathieu Chartiera8077802016-03-16 19:08:31 -0700110 bool VerifyOnlyProfile() const {
Andreas Gampe29d38e72016-03-23 15:31:51 +0000111 return compiler_filter_ == CompilerFilter::kVerifyProfile;
Mathieu Chartiera8077802016-03-16 19:08:31 -0700112 }
113
Brian Carlstrom6449c622014-02-10 23:48:36 -0800114 size_t GetHugeMethodThreshold() const {
115 return huge_method_threshold_;
116 }
117
118 size_t GetLargeMethodThreshold() const {
119 return large_method_threshold_;
120 }
121
122 size_t GetSmallMethodThreshold() const {
123 return small_method_threshold_;
124 }
125
126 size_t GetTinyMethodThreshold() const {
127 return tiny_method_threshold_;
128 }
129
130 bool IsHugeMethod(size_t num_dalvik_instructions) const {
131 return num_dalvik_instructions > huge_method_threshold_;
132 }
133
134 bool IsLargeMethod(size_t num_dalvik_instructions) const {
135 return num_dalvik_instructions > large_method_threshold_;
136 }
137
138 bool IsSmallMethod(size_t num_dalvik_instructions) const {
139 return num_dalvik_instructions > small_method_threshold_;
140 }
141
142 bool IsTinyMethod(size_t num_dalvik_instructions) const {
143 return num_dalvik_instructions > tiny_method_threshold_;
144 }
145
146 size_t GetNumDexMethodsThreshold() const {
147 return num_dex_methods_threshold_;
148 }
149
Calin Juravleec748352015-07-29 13:52:12 +0100150 size_t GetInlineDepthLimit() const {
151 return inline_depth_limit_;
152 }
Andreas Gampe3f41a012016-02-18 16:53:41 -0800153 void SetInlineDepthLimit(size_t limit) {
154 inline_depth_limit_ = limit;
155 }
Calin Juravleec748352015-07-29 13:52:12 +0100156
157 size_t GetInlineMaxCodeUnits() const {
158 return inline_max_code_units_;
159 }
Andreas Gampe3f41a012016-02-18 16:53:41 -0800160 void SetInlineMaxCodeUnits(size_t units) {
161 inline_max_code_units_ = units;
162 }
Calin Juravleec748352015-07-29 13:52:12 +0100163
Calin Juravlec1b643c2014-05-30 23:44:11 +0100164 double GetTopKProfileThreshold() const {
165 return top_k_profile_threshold_;
166 }
167
Andreas Gampe7b2f09e2015-03-02 14:07:33 -0800168 bool GetDebuggable() const {
169 return debuggable_;
170 }
171
David Srbecky0cf44932015-12-09 14:09:59 +0000172 bool GetNativeDebuggable() const {
David Srbecky346dc992016-03-13 22:00:07 +0000173 return GetDebuggable() && GetGenerateDebugInfo();
David Srbecky0cf44932015-12-09 14:09:59 +0000174 }
175
David Srbecky5b1c2ca2016-01-25 17:32:41 +0000176 // This flag controls whether the compiler collects debugging information.
177 // The other flags control how the information is written to disk.
178 bool GenerateAnyDebugInfo() const {
179 return GetGenerateDebugInfo() || GetGenerateMiniDebugInfo();
180 }
181
David Srbecky8363c772015-05-28 16:12:43 +0100182 bool GetGenerateDebugInfo() const {
183 return generate_debug_info_;
David Srbecky8dc73242015-04-12 11:40:39 +0100184 }
185
David Srbecky5b1c2ca2016-01-25 17:32:41 +0000186 bool GetGenerateMiniDebugInfo() const {
187 return generate_mini_debug_info_;
188 }
189
Dave Allison69dfe512014-07-11 17:11:58 +0000190 bool GetImplicitNullChecks() const {
191 return implicit_null_checks_;
Andreas Gampe5655e842014-06-17 16:36:07 -0700192 }
193
Dave Allison69dfe512014-07-11 17:11:58 +0000194 bool GetImplicitStackOverflowChecks() const {
195 return implicit_so_checks_;
Andreas Gampe5655e842014-06-17 16:36:07 -0700196 }
197
Dave Allison69dfe512014-07-11 17:11:58 +0000198 bool GetImplicitSuspendChecks() const {
199 return implicit_suspend_checks_;
Andreas Gampe5655e842014-06-17 16:36:07 -0700200 }
201
Alex Light53cb16b2014-06-12 11:26:29 -0700202 bool GetIncludePatchInformation() const {
203 return include_patch_information_;
204 }
205
Vladimir Markoaad75c62016-10-03 08:46:48 +0000206 bool IsBootImage() const {
207 return boot_image_;
208 }
209
210 bool IsAppImage() const {
211 return app_image_;
212 }
213
Igor Murashkind6dee672014-10-16 18:36:16 -0700214 // Should the code be compiled as position independent?
215 bool GetCompilePic() const {
216 return compile_pic_;
217 }
218
Ian Rogersc7dd2952014-10-21 23:31:19 -0700219 bool HasVerboseMethods() const {
220 return verbose_methods_ != nullptr && !verbose_methods_->empty();
221 }
222
223 bool IsVerboseMethod(const std::string& pretty_method) const {
224 for (const std::string& cur_method : *verbose_methods_) {
225 if (pretty_method.find(cur_method) != std::string::npos) {
226 return true;
227 }
228 }
229 return false;
230 }
231
Andreas Gampedbfe2542014-11-25 22:21:42 -0800232 std::ostream* GetInitFailureOutput() const {
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000233 return init_failure_output_.get();
Andreas Gampedbfe2542014-11-25 22:21:42 -0800234 }
235
Andreas Gampe6cf49e52015-03-05 13:08:45 -0800236 bool AbortOnHardVerifierFailure() const {
237 return abort_on_hard_verifier_failure_;
238 }
239
Vladimir Marko47496c22016-01-27 16:15:08 +0000240 const std::vector<const DexFile*>* GetNoInlineFromDexFile() const {
Jeff Haodcdc85b2015-12-04 14:06:18 -0800241 return no_inline_from_;
242 }
243
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000244 bool ParseCompilerOption(const StringPiece& option, UsageFn Usage);
245
Nicolas Geoffrayc903b6a2016-01-18 12:56:06 +0000246 const std::string& GetDumpCfgFileName() const {
247 return dump_cfg_file_name_;
248 }
249
250 bool GetDumpCfgAppend() const {
251 return dump_cfg_append_;
252 }
253
Andreas Gampeace0dc12016-01-20 13:33:13 -0800254 bool IsForceDeterminism() const {
255 return force_determinism_;
256 }
257
Matthew Gharrity2cd05b72016-08-03 16:57:37 -0700258 RegisterAllocator::Strategy GetRegisterAllocationStrategy() const {
259 return register_allocation_strategy_;
260 }
261
Wojciech Staszkiewicz5319d3c2016-08-01 17:48:59 -0700262 const std::vector<std::string>* GetPassesToRun() const {
263 return passes_to_run_;
264 }
265
Brian Carlstrom6449c622014-02-10 23:48:36 -0800266 private:
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000267 void ParseDumpInitFailures(const StringPiece& option, UsageFn Usage);
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000268 void ParseDumpCfgPasses(const StringPiece& option, UsageFn Usage);
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000269 void ParseInlineMaxCodeUnits(const StringPiece& option, UsageFn Usage);
270 void ParseInlineDepthLimit(const StringPiece& option, UsageFn Usage);
271 void ParseNumDexMethods(const StringPiece& option, UsageFn Usage);
272 void ParseTinyMethodMax(const StringPiece& option, UsageFn Usage);
273 void ParseSmallMethodMax(const StringPiece& option, UsageFn Usage);
274 void ParseLargeMethodMax(const StringPiece& option, UsageFn Usage);
275 void ParseHugeMethodMax(const StringPiece& option, UsageFn Usage);
Matthew Gharrity2cd05b72016-08-03 16:57:37 -0700276 void ParseRegisterAllocationStrategy(const StringPiece& option, UsageFn Usage);
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000277
Andreas Gampe29d38e72016-03-23 15:31:51 +0000278 CompilerFilter::Filter compiler_filter_;
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000279 size_t huge_method_threshold_;
280 size_t large_method_threshold_;
281 size_t small_method_threshold_;
282 size_t tiny_method_threshold_;
283 size_t num_dex_methods_threshold_;
284 size_t inline_depth_limit_;
285 size_t inline_max_code_units_;
Jeff Haodcdc85b2015-12-04 14:06:18 -0800286
Vladimir Marko47496c22016-01-27 16:15:08 +0000287 // Dex files from which we should not inline code.
288 // This is usually a very short list (i.e. a single dex file), so we
289 // prefer vector<> over a lookup-oriented container, such as set<>.
290 const std::vector<const DexFile*>* no_inline_from_;
Jeff Haodcdc85b2015-12-04 14:06:18 -0800291
Vladimir Markoaad75c62016-10-03 08:46:48 +0000292 bool boot_image_;
293 bool app_image_;
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000294 bool include_patch_information_;
Calin Juravlec1b643c2014-05-30 23:44:11 +0100295 // When using a profile file only the top K% of the profiled samples will be compiled.
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000296 double top_k_profile_threshold_;
297 bool debuggable_;
298 bool generate_debug_info_;
David Srbecky5b1c2ca2016-01-25 17:32:41 +0000299 bool generate_mini_debug_info_;
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000300 bool implicit_null_checks_;
301 bool implicit_so_checks_;
302 bool implicit_suspend_checks_;
303 bool compile_pic_;
Ian Rogersc7dd2952014-10-21 23:31:19 -0700304
Ian Rogersc7dd2952014-10-21 23:31:19 -0700305 // Vector of methods to have verbose output enabled for.
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000306 const std::vector<std::string>* verbose_methods_;
Ian Rogersc7dd2952014-10-21 23:31:19 -0700307
Andreas Gampe6cf49e52015-03-05 13:08:45 -0800308 // Abort compilation with an error if we find a class that fails verification with a hard
309 // failure.
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000310 bool abort_on_hard_verifier_failure_;
Andreas Gampe6cf49e52015-03-05 13:08:45 -0800311
Andreas Gampedbfe2542014-11-25 22:21:42 -0800312 // Log initialization of initialization failures to this stream if not null.
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000313 std::unique_ptr<std::ostream> init_failure_output_;
314
Nicolas Geoffrayc903b6a2016-01-18 12:56:06 +0000315 std::string dump_cfg_file_name_;
316 bool dump_cfg_append_;
317
Vladimir Markoaad75c62016-10-03 08:46:48 +0000318 // Whether the compiler should trade performance for determinism to guarantee exactly reproducible
Andreas Gampeace0dc12016-01-20 13:33:13 -0800319 // outcomes.
320 bool force_determinism_;
321
Matthew Gharrity2cd05b72016-08-03 16:57:37 -0700322 RegisterAllocator::Strategy register_allocation_strategy_;
323
Wojciech Staszkiewicz5319d3c2016-08-01 17:48:59 -0700324 // If not null, specifies optimization passes which will be run instead of defaults.
325 // Note that passes_to_run_ is not checked for correctness and providing an incorrect
326 // list of passes can lead to unexpected compiler behaviour. This is caused by dependencies
327 // between passes. Failing to satisfy them can for example lead to compiler crashes.
328 // Passing pass names which are not recognized by the compiler will result in
329 // compiler-dependant behavior.
330 const std::vector<std::string>* passes_to_run_;
331
Nicolas Geoffrayabbb0f72015-10-29 18:55:58 +0000332 friend class Dex2Oat;
Vladimir Markoaad75c62016-10-03 08:46:48 +0000333 friend class CommonCompilerTest;
Andreas Gampedbfe2542014-11-25 22:21:42 -0800334
Ian Rogersc7dd2952014-10-21 23:31:19 -0700335 DISALLOW_COPY_AND_ASSIGN(CompilerOptions);
Brian Carlstrom6449c622014-02-10 23:48:36 -0800336};
Brian Carlstrom6449c622014-02-10 23:48:36 -0800337
338} // namespace art
339
340#endif // ART_COMPILER_DRIVER_COMPILER_OPTIONS_H_