|  | /* | 
|  | * Copyright (C) 2014 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_RUNTIME_PROFILER_OPTIONS_H_ | 
|  | #define ART_RUNTIME_PROFILER_OPTIONS_H_ | 
|  |  | 
|  | #include <string> | 
|  | #include <ostream> | 
|  |  | 
|  | namespace art { | 
|  |  | 
|  | enum ProfileDataType { | 
|  | kProfilerMethod,          // Method only | 
|  | kProfilerBoundedStack,    // Methods with Dex PC on top of the stack | 
|  | }; | 
|  | std::ostream& operator<<(std::ostream& os, const ProfileDataType& rhs); | 
|  |  | 
|  | class ProfilerOptions { | 
|  | public: | 
|  | static constexpr bool kDefaultEnabled = false; | 
|  | static constexpr uint32_t kDefaultPeriodS = 10; | 
|  | static constexpr uint32_t kDefaultDurationS = 20; | 
|  | static constexpr uint32_t kDefaultIntervalUs = 500; | 
|  | static constexpr double kDefaultBackoffCoefficient = 2.0; | 
|  | static constexpr bool kDefaultStartImmediately = false; | 
|  | static constexpr double kDefaultTopKThreshold = 90.0; | 
|  | static constexpr double kDefaultChangeInTopKThreshold = 10.0; | 
|  | static constexpr ProfileDataType kDefaultProfileData = kProfilerMethod; | 
|  | static constexpr uint32_t kDefaultMaxStackDepth = 3; | 
|  |  | 
|  | ProfilerOptions() : | 
|  | enabled_(kDefaultEnabled), | 
|  | period_s_(kDefaultPeriodS), | 
|  | duration_s_(kDefaultDurationS), | 
|  | interval_us_(kDefaultIntervalUs), | 
|  | backoff_coefficient_(kDefaultBackoffCoefficient), | 
|  | start_immediately_(kDefaultStartImmediately), | 
|  | top_k_threshold_(kDefaultTopKThreshold), | 
|  | top_k_change_threshold_(kDefaultChangeInTopKThreshold), | 
|  | profile_type_(kDefaultProfileData), | 
|  | max_stack_depth_(kDefaultMaxStackDepth) {} | 
|  |  | 
|  | ProfilerOptions(bool enabled, | 
|  | uint32_t period_s, | 
|  | uint32_t duration_s, | 
|  | uint32_t interval_us, | 
|  | double backoff_coefficient, | 
|  | bool start_immediately, | 
|  | double top_k_threshold, | 
|  | double top_k_change_threshold, | 
|  | ProfileDataType profile_type, | 
|  | uint32_t max_stack_depth): | 
|  | enabled_(enabled), | 
|  | period_s_(period_s), | 
|  | duration_s_(duration_s), | 
|  | interval_us_(interval_us), | 
|  | backoff_coefficient_(backoff_coefficient), | 
|  | start_immediately_(start_immediately), | 
|  | top_k_threshold_(top_k_threshold), | 
|  | top_k_change_threshold_(top_k_change_threshold), | 
|  | profile_type_(profile_type), | 
|  | max_stack_depth_(max_stack_depth) {} | 
|  |  | 
|  | bool IsEnabled() const { | 
|  | return enabled_; | 
|  | } | 
|  |  | 
|  | uint32_t GetPeriodS() const { | 
|  | return period_s_; | 
|  | } | 
|  |  | 
|  | uint32_t GetDurationS() const { | 
|  | return duration_s_; | 
|  | } | 
|  |  | 
|  | uint32_t GetIntervalUs() const { | 
|  | return interval_us_; | 
|  | } | 
|  |  | 
|  | double GetBackoffCoefficient() const { | 
|  | return backoff_coefficient_; | 
|  | } | 
|  |  | 
|  | bool GetStartImmediately() const { | 
|  | return start_immediately_; | 
|  | } | 
|  |  | 
|  | double GetTopKThreshold() const { | 
|  | return top_k_threshold_; | 
|  | } | 
|  |  | 
|  | double GetTopKChangeThreshold() const { | 
|  | return top_k_change_threshold_; | 
|  | } | 
|  |  | 
|  | ProfileDataType GetProfileType() const { | 
|  | return profile_type_; | 
|  | } | 
|  |  | 
|  | uint32_t GetMaxStackDepth() const { | 
|  | return max_stack_depth_; | 
|  | } | 
|  |  | 
|  | private: | 
|  | friend std::ostream & operator<<(std::ostream &os, const ProfilerOptions& po) { | 
|  | os << "enabled=" << po.enabled_ | 
|  | << ", period_s=" << po.period_s_ | 
|  | << ", duration_s=" << po.duration_s_ | 
|  | << ", interval_us=" << po.interval_us_ | 
|  | << ", backoff_coefficient=" << po.backoff_coefficient_ | 
|  | << ", start_immediately=" << po.start_immediately_ | 
|  | << ", top_k_threshold=" << po.top_k_threshold_ | 
|  | << ", top_k_change_threshold=" << po.top_k_change_threshold_ | 
|  | << ", profile_type=" << po.profile_type_ | 
|  | << ", max_stack_depth=" << po.max_stack_depth_; | 
|  | return os; | 
|  | } | 
|  |  | 
|  | friend class ParsedOptions; | 
|  |  | 
|  | // Whether or not the applications should be profiled. | 
|  | bool enabled_; | 
|  | // Generate profile every n seconds. | 
|  | uint32_t period_s_; | 
|  | // Run profile for n seconds. | 
|  | uint32_t duration_s_; | 
|  | // Microseconds between samples. | 
|  | uint32_t interval_us_; | 
|  | // Coefficient to exponential backoff. | 
|  | double backoff_coefficient_; | 
|  | // Whether the profile should start upon app startup or be delayed by some random offset. | 
|  | bool start_immediately_; | 
|  | // Top K% of samples that are considered relevant when deciding if the app should be recompiled. | 
|  | double top_k_threshold_; | 
|  | // How much the top K% samples needs to change in order for the app to be recompiled. | 
|  | double top_k_change_threshold_; | 
|  | // The type of profile data dumped to the disk. | 
|  | ProfileDataType profile_type_; | 
|  | // The max depth of the stack collected by the profiler | 
|  | uint32_t max_stack_depth_; | 
|  | }; | 
|  |  | 
|  | }  // namespace art | 
|  |  | 
|  |  | 
|  | #endif  // ART_RUNTIME_PROFILER_OPTIONS_H_ |