diff options
| author | 2014-05-30 23:44:11 +0100 | |
|---|---|---|
| committer | 2014-06-06 12:14:01 +0100 | |
| commit | c1b643cc6ac45dbd0eabdcd7425c7e86006c27d6 (patch) | |
| tree | 250455427da979409a075a2b3197bd43ccd40fe1 /compiler/driver/compiler_options.h | |
| parent | bb0b53f58f11c628f077603b56077dfed1a18f11 (diff) | |
Fixed and refactored profiler options handling
- extracted profiler options in a separate class
- switched from system property reading to command line arguments
- added profile based compilation options to CompilerOptions
- removed no longer used kProfile compilation filter
- optimize dex files only if the profiler is enabled
- clean up unused arguments
Bug: 12877748
Bug: 15275634
Change-Id: I37ff68e7694370950ce8db2360562e9058ecebb7
Diffstat (limited to 'compiler/driver/compiler_options.h')
| -rw-r--r-- | compiler/driver/compiler_options.h | 20 | 
1 files changed, 14 insertions, 6 deletions
| diff --git a/compiler/driver/compiler_options.h b/compiler/driver/compiler_options.h index 20c6bc8e4e..05a9ac7ee9 100644 --- a/compiler/driver/compiler_options.h +++ b/compiler/driver/compiler_options.h @@ -24,7 +24,6 @@ class CompilerOptions {    enum CompilerFilter {      kVerifyNone,          // Skip verification and compile nothing except JNI stubs.      kInterpretOnly,       // Compile nothing except JNI stubs. -    kProfiled,            // Compile based on profile.      kSpace,               // Maximize space savings.      kBalanced,            // Try to get the best performance return on compilation investment.      kSpeed,               // Maximize runtime performance. @@ -33,7 +32,7 @@ class CompilerOptions {    // Guide heuristics to determine whether to compile method if profile data not available.  #if ART_SMALL_MODE -  static const CompilerFilter kDefaultCompilerFilter = kProfiled; +  static const CompilerFilter kDefaultCompilerFilter = kInterpretOnly;  #else    static const CompilerFilter kDefaultCompilerFilter = kSpeed;  #endif @@ -42,6 +41,7 @@ class CompilerOptions {    static const size_t kDefaultSmallMethodThreshold = 60;    static const size_t kDefaultTinyMethodThreshold = 20;    static const size_t kDefaultNumDexMethodsThreshold = 900; +  static constexpr double kDefaultTopKProfileThreshold = 90.0;    CompilerOptions() :      compiler_filter_(kDefaultCompilerFilter), @@ -50,7 +50,8 @@ class CompilerOptions {      small_method_threshold_(kDefaultSmallMethodThreshold),      tiny_method_threshold_(kDefaultTinyMethodThreshold),      num_dex_methods_threshold_(kDefaultNumDexMethodsThreshold), -    generate_gdb_information_(false) +    generate_gdb_information_(false), +    top_k_profile_threshold_(kDefaultTopKProfileThreshold)  #ifdef ART_SEA_IR_MODE      , sea_ir_mode_(false)  #endif @@ -62,7 +63,8 @@ class CompilerOptions {                    size_t small_method_threshold,                    size_t tiny_method_threshold,                    size_t num_dex_methods_threshold, -                  bool generate_gdb_information +                  bool generate_gdb_information, +                  double top_k_profile_threshold  #ifdef ART_SEA_IR_MODE                    , bool sea_ir_mode  #endif @@ -73,7 +75,8 @@ class CompilerOptions {      small_method_threshold_(small_method_threshold),      tiny_method_threshold_(tiny_method_threshold),      num_dex_methods_threshold_(num_dex_methods_threshold), -    generate_gdb_information_(generate_gdb_information) +    generate_gdb_information_(generate_gdb_information), +    top_k_profile_threshold_(top_k_profile_threshold)  #ifdef ART_SEA_IR_MODE      , sea_ir_mode_(sea_ir_mode)  #endif @@ -132,6 +135,10 @@ class CompilerOptions {      return num_dex_methods_threshold_;    } +  double GetTopKProfileThreshold() const { +    return top_k_profile_threshold_; +  } +  #ifdef ART_SEA_IR_MODE    bool GetSeaIrMode();  #endif @@ -148,7 +155,8 @@ class CompilerOptions {    size_t tiny_method_threshold_;    size_t num_dex_methods_threshold_;    bool generate_gdb_information_; - +  // When using a profile file only the top K% of the profiled samples will be compiled. +  double top_k_profile_threshold_;  #ifdef ART_SEA_IR_MODE    bool sea_ir_mode_;  #endif |