| /* |
| * Copyright (C) 2020 The Android Open Source Project |
| * |
| * SPDX-License-Identifier: Apache-2.0 |
| */ |
| |
| #define LOG_TAG "android.hardware.power-service.xiaomi.ext-libperfmgr" |
| |
| #include "PowerExt.h" |
| |
| #include <android-base/file.h> |
| #include <android-base/logging.h> |
| #include <android-base/properties.h> |
| #include <android-base/stringprintf.h> |
| #include <android-base/strings.h> |
| #include <perfmgr/HintManager.h> |
| #include <utils/Log.h> |
| |
| #include <mutex> |
| |
| #include "PowerSessionManager.h" |
| |
| namespace aidl { |
| namespace google { |
| namespace hardware { |
| namespace power { |
| namespace impl { |
| namespace pixel { |
| |
| using ::android::perfmgr::HintManager; |
| |
| ndk::ScopedAStatus PowerExt::setMode(const std::string &mode, bool enabled) { |
| LOG(DEBUG) << "PowerExt setMode: " << mode << " to: " << enabled; |
| |
| if (enabled) { |
| HintManager::GetInstance()->DoHint(mode); |
| } else { |
| HintManager::GetInstance()->EndHint(mode); |
| } |
| if (HintManager::GetInstance()->GetAdpfProfile() && |
| HintManager::GetInstance()->GetAdpfProfile()->mReportingRateLimitNs > 0) { |
| PowerSessionManager::getInstance()->updateHintMode(mode, enabled); |
| } |
| |
| return ndk::ScopedAStatus::ok(); |
| } |
| |
| ndk::ScopedAStatus PowerExt::isModeSupported(const std::string &mode, bool *_aidl_return) { |
| bool supported = HintManager::GetInstance()->IsHintSupported(mode); |
| LOG(INFO) << "PowerExt mode " << mode << " isModeSupported: " << supported; |
| *_aidl_return = supported; |
| return ndk::ScopedAStatus::ok(); |
| } |
| |
| ndk::ScopedAStatus PowerExt::setBoost(const std::string &boost, int32_t durationMs) { |
| LOG(DEBUG) << "PowerExt setBoost: " << boost << " duration: " << durationMs; |
| if (HintManager::GetInstance()->GetAdpfProfile() && |
| HintManager::GetInstance()->GetAdpfProfile()->mReportingRateLimitNs > 0) { |
| PowerSessionManager::getInstance()->updateHintBoost(boost, durationMs); |
| } |
| |
| if (durationMs > 0) { |
| HintManager::GetInstance()->DoHint(boost, std::chrono::milliseconds(durationMs)); |
| } else if (durationMs == 0) { |
| HintManager::GetInstance()->DoHint(boost); |
| } else { |
| HintManager::GetInstance()->EndHint(boost); |
| } |
| |
| return ndk::ScopedAStatus::ok(); |
| } |
| |
| ndk::ScopedAStatus PowerExt::isBoostSupported(const std::string &boost, bool *_aidl_return) { |
| bool supported = HintManager::GetInstance()->IsHintSupported(boost); |
| LOG(INFO) << "PowerExt boost " << boost << " isBoostSupported: " << supported; |
| *_aidl_return = supported; |
| return ndk::ScopedAStatus::ok(); |
| } |
| |
| } // namespace pixel |
| } // namespace impl |
| } // namespace power |
| } // namespace hardware |
| } // namespace google |
| } // namespace aidl |