"libbinder_ndk",
"libperfmgr",
"pixel-power-ext-ndk_platform",
- "vendor.lineage.power-ndk_platform",
],
srcs: [
"service.cpp",
"Power.cpp",
"PowerExt.cpp",
- "InteractionHandler.cpp",
- "LineagePower.cpp"
+ "InteractionHandler.cpp"
],
}
+++ /dev/null
-/*
- * Copyright (C) 2021 The LineageOS 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.
- */
-
-#include "LineagePower.h"
-
-namespace aidl {
-namespace vendor {
-namespace lineage {
-namespace power {
-namespace impl {
-
-LineagePower::LineagePower(std::shared_ptr<Power> power, int32_t serviceNumPerfProfiles)
- : mPower(power), mNumPerfProfiles(serviceNumPerfProfiles) {}
-
-
-ndk::ScopedAStatus LineagePower::getFeature(Feature feature, int* _aidl_return) {
- switch (feature) {
- case Feature::SUPPORTED_PROFILES:
- *_aidl_return = mNumPerfProfiles;
- break;
- default:
- *_aidl_return = -1;
- break;
- }
- return ndk::ScopedAStatus::ok();
-}
-
-ndk::ScopedAStatus LineagePower::setBoost(Boost type, int durationMs) {
- switch (type) {
- case Boost::SET_PROFILE:
- mPower->setProfile(static_cast<PowerProfile>(durationMs));
- break;
- default:
- break;
- }
- return ndk::ScopedAStatus::ok();
-}
-
-} // namespace impl
-} // namespace power
-} // namespace lineage
-} // namespace vendor
-} // namespace aidl
+++ /dev/null
-/*
- * Copyright (C) 2021 The LineageOS 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.
- */
-
-#pragma once
-
-#include <aidl/vendor/lineage/power/BnPower.h>
-#include "Power.h"
-
-namespace aidl {
-namespace vendor {
-namespace lineage {
-namespace power {
-namespace impl {
-
-using aidl::google::hardware::power::impl::pixel::Power;
-using aidl::google::hardware::power::impl::pixel::PowerProfile;
-
-class LineagePower : public BnPower {
- public:
- LineagePower(std::shared_ptr<Power> power, int32_t serviceNumPerfProfiles);
- ndk::ScopedAStatus getFeature(Feature feature, int* _aidl_return) override;
- ndk::ScopedAStatus setBoost(Boost type, int durationMs) override;
-
- private:
- std::shared_ptr<Power> mPower;
- int32_t mNumPerfProfiles;
-};
-
-} // namespace impl
-} // namespace power
-} // namespace lineage
-} // namespace vendor
-} // namespace aidl
\ No newline at end of file
constexpr char kPowerHalStateProp[] = "vendor.powerhal.state";
constexpr char kPowerHalAudioProp[] = "vendor.powerhal.audio";
constexpr char kPowerHalRenderingProp[] = "vendor.powerhal.rendering";
-constexpr char kPowerHalProfileProp[] = "vendor.powerhal.perf_profile";
Power::Power(std::shared_ptr<HintManager> hm)
: mHintManager(hm),
mInteractionHandler(nullptr),
mVRModeOn(false),
- mSustainedPerfModeOn(false),
- mCurrentPerfProfile(PowerProfile::BALANCED) {
+ mSustainedPerfModeOn(false) {
mInteractionHandler = std::make_unique<InteractionHandler>(mHintManager);
mInteractionHandler->Init();
mHintManager->DoHint("EXPENSIVE_RENDERING");
}
- state = ::android::base::GetProperty(kPowerHalProfileProp, "");
- if (state == "POWER_SAVE") {
- ALOGI("Initialize with POWER_SAVE profile");
- setProfile(PowerProfile::POWER_SAVE);
- } else if (state == "BIAS_POWER_SAVE") {
- ALOGI("Initialize with BIAS_POWER_SAVE profile");
- setProfile(PowerProfile::BIAS_POWER_SAVE);
- } else if (state == "BIAS_PERFORMANCE") {
- ALOGI("Initialize with BIAS_PERFORMANCE profile");
- setProfile(PowerProfile::BIAS_PERFORMANCE);
- } else if (state == "HIGH_PERFORMANCE") {
- ALOGI("Initialize with HIGH_PERFORMANCE profile");
- setProfile(PowerProfile::HIGH_PERFORMANCE);
- }
-
// Now start to take powerhint
ALOGI("PowerHAL ready to process hints");
}
return ndk::ScopedAStatus::ok();
}
-ndk::ScopedAStatus Power::setProfile(PowerProfile profile) {
- if (mCurrentPerfProfile == profile) {
- return ndk::ScopedAStatus::ok();
- }
-
- // End previous perf profile hints
- switch (mCurrentPerfProfile) {
- case PowerProfile::POWER_SAVE:
- mHintManager->EndHint("PROFILE_POWER_SAVE");
- break;
- case PowerProfile::BIAS_POWER_SAVE:
- mHintManager->EndHint("PROFILE_BIAS_POWER_SAVE");
- break;
- case PowerProfile::BIAS_PERFORMANCE:
- mHintManager->EndHint("PROFILE_BIAS_PERFORMANCE");
- break;
- case PowerProfile::HIGH_PERFORMANCE:
- mHintManager->EndHint("PROFILE_HIGH_PERFORMANCE");
- break;
- default:
- break;
- }
-
- // Apply perf profile hints
- switch (profile) {
- case PowerProfile::POWER_SAVE:
- mHintManager->DoHint("PROFILE_POWER_SAVE");
- break;
- case PowerProfile::BIAS_POWER_SAVE:
- mHintManager->DoHint("PROFILE_BIAS_POWER_SAVE");
- break;
- case PowerProfile::BIAS_PERFORMANCE:
- mHintManager->DoHint("PROFILE_BIAS_PERFORMANCE");
- break;
- case PowerProfile::HIGH_PERFORMANCE:
- mHintManager->DoHint("PROFILE_HIGH_PERFORMANCE");
- break;
- default:
- break;
- }
-
- mCurrentPerfProfile = profile;
-
- return ndk::ScopedAStatus::ok();
-}
-
ndk::ScopedAStatus Power::setBoost(Boost type, int32_t durationMs) {
LOG(DEBUG) << "Power setBoost: " << toString(type) << " duration: " << durationMs;
ATRACE_INT(toString(type).c_str(), durationMs);
using ::aidl::android::hardware::power::Mode;
using ::android::perfmgr::HintManager;
-enum PowerProfile {
- POWER_SAVE = 0,
- BALANCED,
- HIGH_PERFORMANCE,
- BIAS_POWER_SAVE,
- BIAS_PERFORMANCE,
- MAX
-};
-
class Power : public ::aidl::android::hardware::power::BnPower {
public:
Power(std::shared_ptr<HintManager> hm);
ndk::ScopedAStatus setMode(Mode type, bool enabled) override;
ndk::ScopedAStatus isModeSupported(Mode type, bool *_aidl_return) override;
- ndk::ScopedAStatus setProfile(PowerProfile profile);
ndk::ScopedAStatus setBoost(Boost type, int32_t durationMs) override;
ndk::ScopedAStatus isBoostSupported(Boost type, bool *_aidl_return) override;
binder_status_t dump(int fd, const char **args, uint32_t numArgs) override;
std::unique_ptr<InteractionHandler> mInteractionHandler;
std::atomic<bool> mVRModeOn;
std::atomic<bool> mSustainedPerfModeOn;
- std::atomic<PowerProfile> mCurrentPerfProfile;
};
} // namespace pixel
<name>android.hardware.power</name>
<fqname>IPower/default</fqname>
</hal>
- <hal format="aidl" override="true">
- <name>vendor.lineage.power</name>
- <fqname>IPower/default</fqname>
- </hal>
</manifest>
#include <android/binder_manager.h>
#include <android/binder_process.h>
-#include "LineagePower.h"
#include "Power.h"
#include "PowerExt.h"
using aidl::google::hardware::power::impl::pixel::Power;
using aidl::google::hardware::power::impl::pixel::PowerExt;
using ::android::perfmgr::HintManager;
-using aidl::vendor::lineage::power::impl::LineagePower;
-constexpr char kPowerHalProfileNumProp[] = "vendor.powerhal.perf_profiles";
constexpr char kPowerHalConfigPath[] = "/vendor/etc/powerhint.json";
constexpr char kPowerHalInitProp[] = "vendor.powerhal.init";
LOG(FATAL) << "Invalid config: " << kPowerHalConfigPath;
}
- // parse number of profiles
- int32_t serviceNumPerfProfiles = android::base::GetIntProperty(kPowerHalProfileNumProp, 0);
-
// single thread
ABinderProcess_setThreadPoolMaxThreadCount(0);
const std::string instance = std::string() + Power::descriptor + "/default";
binder_status_t status = AServiceManager_addService(pw->asBinder().get(), instance.c_str());
CHECK(status == STATUS_OK);
-
- // lineage service
- std::shared_ptr<LineagePower> lineagePw = ndk::SharedRefBase::make<LineagePower>(pw, serviceNumPerfProfiles);
- const std::string lineageInstance = std::string() + LineagePower::descriptor + "/default";
- binder_status_t lineageStatus = AServiceManager_addService(lineagePw->asBinder().get(), lineageInstance.c_str());
- CHECK(lineageStatus == STATUS_OK);
- LOG(INFO) << "Pixel Power HAL AIDL Service with Extension & Lineage Perf Profile is started.";
+ LOG(INFO) << "Pixel Power HAL AIDL Service with Extension is started.";
std::thread initThread([&]() {
::android::base::WaitForProperty(kPowerHalInitProp, "1");