/* * Copyright (C) 2016 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 * * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ART_RUNTIME_JIT_PROFILE_SAVER_OPTIONS_H_ #define ART_RUNTIME_JIT_PROFILE_SAVER_OPTIONS_H_ #include <ostream> #include <string> namespace art { struct ProfileSaverOptions { public: static constexpr uint32_t kMinSavePeriodMs = 40 * 1000; // 40 seconds static constexpr uint32_t kSaveResolvedClassesDelayMs = 5 * 1000; // 5 seconds // Minimum number of JIT samples during launch to mark a method as hot in the profile. static constexpr uint32_t kHotStartupMethodSamples = 1; static constexpr uint32_t kHotStartupMethodSamplesLowRam = 256; static constexpr uint32_t kMinMethodsToSave = 10; static constexpr uint32_t kMinClassesToSave = 10; static constexpr uint32_t kMinNotificationBeforeWake = 10; static constexpr uint32_t kMaxNotificationBeforeWake = 50; static constexpr uint32_t kHotStartupMethodSamplesNotSet = std::numeric_limits<uint32_t>::max(); ProfileSaverOptions() : enabled_(false), min_save_period_ms_(kMinSavePeriodMs), save_resolved_classes_delay_ms_(kSaveResolvedClassesDelayMs), hot_startup_method_samples_(kHotStartupMethodSamplesNotSet), min_methods_to_save_(kMinMethodsToSave), min_classes_to_save_(kMinClassesToSave), min_notification_before_wake_(kMinNotificationBeforeWake), max_notification_before_wake_(kMaxNotificationBeforeWake), profile_path_(""), profile_boot_class_path_(false), profile_aot_code_(false), wait_for_jit_notifications_to_save_(true) {} ProfileSaverOptions( bool enabled, uint32_t min_save_period_ms, uint32_t save_resolved_classes_delay_ms, uint32_t hot_startup_method_samples, uint32_t min_methods_to_save, uint32_t min_classes_to_save, uint32_t min_notification_before_wake, uint32_t max_notification_before_wake, const std::string& profile_path, bool profile_boot_class_path, bool profile_aot_code = false, bool wait_for_jit_notifications_to_save = true) : enabled_(enabled), min_save_period_ms_(min_save_period_ms), save_resolved_classes_delay_ms_(save_resolved_classes_delay_ms), hot_startup_method_samples_(hot_startup_method_samples), min_methods_to_save_(min_methods_to_save), min_classes_to_save_(min_classes_to_save), min_notification_before_wake_(min_notification_before_wake), max_notification_before_wake_(max_notification_before_wake), profile_path_(profile_path), profile_boot_class_path_(profile_boot_class_path), profile_aot_code_(profile_aot_code), wait_for_jit_notifications_to_save_(wait_for_jit_notifications_to_save) {} bool IsEnabled() const { return enabled_; } void SetEnabled(bool enabled) { enabled_ = enabled; } uint32_t GetMinSavePeriodMs() const { return min_save_period_ms_; } uint32_t GetSaveResolvedClassesDelayMs() const { return save_resolved_classes_delay_ms_; } uint32_t GetHotStartupMethodSamples(bool is_low_ram) const { uint32_t ret = hot_startup_method_samples_; if (ret == kHotStartupMethodSamplesNotSet) { ret = is_low_ram ? kHotStartupMethodSamplesLowRam : kHotStartupMethodSamples; } return ret; } uint32_t GetMinMethodsToSave() const { return min_methods_to_save_; } uint32_t GetMinClassesToSave() const { return min_classes_to_save_; } uint32_t GetMinNotificationBeforeWake() const { return min_notification_before_wake_; } uint32_t GetMaxNotificationBeforeWake() const { return max_notification_before_wake_; } std::string GetProfilePath() const { return profile_path_; } bool GetProfileBootClassPath() const { return profile_boot_class_path_; } bool GetProfileAOTCode() const { return profile_aot_code_; } void SetProfileAOTCode(bool value) { profile_aot_code_ = value; } bool GetWaitForJitNotificationsToSave() const { return wait_for_jit_notifications_to_save_; } void SetWaitForJitNotificationsToSave(bool value) { wait_for_jit_notifications_to_save_ = value; } friend std::ostream & operator<<(std::ostream &os, const ProfileSaverOptions& pso) { os << "enabled_" << pso.enabled_ << ", min_save_period_ms_" << pso.min_save_period_ms_ << ", save_resolved_classes_delay_ms_" << pso.save_resolved_classes_delay_ms_ << ", hot_startup_method_samples_" << pso.hot_startup_method_samples_ << ", min_methods_to_save_" << pso.min_methods_to_save_ << ", min_classes_to_save_" << pso.min_classes_to_save_ << ", min_notification_before_wake_" << pso.min_notification_before_wake_ << ", max_notification_before_wake_" << pso.max_notification_before_wake_ << ", profile_boot_class_path_" << pso.profile_boot_class_path_ << ", profile_aot_code_" << pso.profile_aot_code_ << ", wait_for_jit_notifications_to_save_" << pso.wait_for_jit_notifications_to_save_; return os; } bool enabled_; uint32_t min_save_period_ms_; uint32_t save_resolved_classes_delay_ms_; // Do not access hot_startup_method_samples_ directly for reading since it may be set to the // placeholder default. uint32_t hot_startup_method_samples_; uint32_t min_methods_to_save_; uint32_t min_classes_to_save_; uint32_t min_notification_before_wake_; uint32_t max_notification_before_wake_; std::string profile_path_; bool profile_boot_class_path_; bool profile_aot_code_; bool wait_for_jit_notifications_to_save_; }; } // namespace art #endif // ART_RUNTIME_JIT_PROFILE_SAVER_OPTIONS_H_