blob: bd6685cbad3c01946930ac35b638c92fecf55879 [file] [log] [blame]
Lais Andrade4d51f6c2020-03-25 10:58:31 +00001/*
2 * Copyright (C) 2020 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Lais Andradeb59a9b52020-05-07 17:23:42 +010017#define LOG_TAG "HalWrapper"
Xiang Wang99f6f3c2023-05-22 13:12:16 -070018#include <aidl/android/hardware/power/Boost.h>
19#include <aidl/android/hardware/power/IPowerHintSession.h>
20#include <aidl/android/hardware/power/Mode.h>
Matt Buckley6c18e6d2024-02-07 23:39:50 +000021#include <powermanager/HalResult.h>
Lais Andrade4d51f6c2020-03-25 10:58:31 +000022#include <powermanager/PowerHalWrapper.h>
Lais Andradeb59a9b52020-05-07 17:23:42 +010023#include <utils/Log.h>
Lais Andrade4d51f6c2020-03-25 10:58:31 +000024
Lais Andradeb59a9b52020-05-07 17:23:42 +010025using namespace android::hardware::power;
Xiang Wang99f6f3c2023-05-22 13:12:16 -070026namespace Aidl = aidl::android::hardware::power;
Lais Andrade4d51f6c2020-03-25 10:58:31 +000027
28namespace android {
29
Lais Andradeb59a9b52020-05-07 17:23:42 +010030namespace power {
31
Lais Andrade4d51f6c2020-03-25 10:58:31 +000032// -------------------------------------------------------------------------------------------------
Lais Andradeb59a9b52020-05-07 17:23:42 +010033
Xiang Wang99f6f3c2023-05-22 13:12:16 -070034HalResult<void> EmptyHalWrapper::setBoost(Aidl::Boost boost, int32_t durationMs) {
Matt Buckleydb4192a2023-12-21 20:00:32 +000035 ALOGV("Skipped setBoost %s with duration %dms because %s", toString(boost).c_str(), durationMs,
36 getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080037 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +000038}
39
Xiang Wang99f6f3c2023-05-22 13:12:16 -070040HalResult<void> EmptyHalWrapper::setMode(Aidl::Mode mode, bool enabled) {
Matt Buckleydb4192a2023-12-21 20:00:32 +000041 ALOGV("Skipped setMode %s to %s because %s", toString(mode).c_str(), enabled ? "true" : "false",
42 getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080043 return HalResult<void>::unsupported();
44}
45
Matt Buckley6c18e6d2024-02-07 23:39:50 +000046HalResult<std::shared_ptr<PowerHintSessionWrapper>> EmptyHalWrapper::createHintSession(
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080047 int32_t, int32_t, const std::vector<int32_t>& threadIds, int64_t) {
Matt Buckleydb4192a2023-12-21 20:00:32 +000048 ALOGV("Skipped createHintSession(task num=%zu) because %s", threadIds.size(),
49 getUnsupportedMessage());
Matt Buckley6c18e6d2024-02-07 23:39:50 +000050 return HalResult<std::shared_ptr<PowerHintSessionWrapper>>::unsupported();
Matt Buckleydb4192a2023-12-21 20:00:32 +000051}
52
Matt Buckley6c18e6d2024-02-07 23:39:50 +000053HalResult<std::shared_ptr<PowerHintSessionWrapper>> EmptyHalWrapper::createHintSessionWithConfig(
Matt Buckleydb4192a2023-12-21 20:00:32 +000054 int32_t, int32_t, const std::vector<int32_t>& threadIds, int64_t, Aidl::SessionTag,
55 Aidl::SessionConfig*) {
56 ALOGV("Skipped createHintSessionWithConfig(task num=%zu) because %s", threadIds.size(),
57 getUnsupportedMessage());
Matt Buckley6c18e6d2024-02-07 23:39:50 +000058 return HalResult<std::shared_ptr<PowerHintSessionWrapper>>::unsupported();
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080059}
60
61HalResult<int64_t> EmptyHalWrapper::getHintSessionPreferredRate() {
Matt Buckleydb4192a2023-12-21 20:00:32 +000062 ALOGV("Skipped getHintSessionPreferredRate because %s", getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080063 return HalResult<int64_t>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +000064}
65
Matt Buckleydb4192a2023-12-21 20:00:32 +000066HalResult<Aidl::ChannelConfig> EmptyHalWrapper::getSessionChannel(int, int) {
67 ALOGV("Skipped getSessionChannel because %s", getUnsupportedMessage());
68 return HalResult<Aidl::ChannelConfig>::unsupported();
69}
70
71HalResult<void> EmptyHalWrapper::closeSessionChannel(int, int) {
72 ALOGV("Skipped closeSessionChannel because %s", getUnsupportedMessage());
73 return HalResult<void>::unsupported();
74}
75
76const char* EmptyHalWrapper::getUnsupportedMessage() {
77 return "Power HAL is not supported";
78}
79
Lais Andrade4d51f6c2020-03-25 10:58:31 +000080// -------------------------------------------------------------------------------------------------
81
Xiang Wang99f6f3c2023-05-22 13:12:16 -070082HalResult<void> HidlHalWrapperV1_0::setBoost(Aidl::Boost boost, int32_t durationMs) {
83 if (boost == Aidl::Boost::INTERACTION) {
Matt Buckleyc3894a42022-09-01 21:17:15 +000084 return sendPowerHint(V1_3::PowerHint::INTERACTION, durationMs);
Lais Andrade4d51f6c2020-03-25 10:58:31 +000085 } else {
Matt Buckleydb4192a2023-12-21 20:00:32 +000086 return EmptyHalWrapper::setBoost(boost, durationMs);
Lais Andrade4d51f6c2020-03-25 10:58:31 +000087 }
88}
89
Xiang Wang99f6f3c2023-05-22 13:12:16 -070090HalResult<void> HidlHalWrapperV1_0::setMode(Aidl::Mode mode, bool enabled) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +000091 uint32_t data = enabled ? 1 : 0;
92 switch (mode) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -070093 case Aidl::Mode::LAUNCH:
Matt Buckleyc3894a42022-09-01 21:17:15 +000094 return sendPowerHint(V1_3::PowerHint::LAUNCH, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -070095 case Aidl::Mode::LOW_POWER:
Matt Buckleyc3894a42022-09-01 21:17:15 +000096 return sendPowerHint(V1_3::PowerHint::LOW_POWER, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -070097 case Aidl::Mode::SUSTAINED_PERFORMANCE:
Matt Buckleyc3894a42022-09-01 21:17:15 +000098 return sendPowerHint(V1_3::PowerHint::SUSTAINED_PERFORMANCE, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -070099 case Aidl::Mode::VR:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000100 return sendPowerHint(V1_3::PowerHint::VR_MODE, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700101 case Aidl::Mode::INTERACTIVE:
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000102 return setInteractive(enabled);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700103 case Aidl::Mode::DOUBLE_TAP_TO_WAKE:
Lais Andradeb59a9b52020-05-07 17:23:42 +0100104 return setFeature(V1_0::Feature::POWER_FEATURE_DOUBLE_TAP_TO_WAKE, enabled);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000105 default:
Matt Buckleydb4192a2023-12-21 20:00:32 +0000106 return EmptyHalWrapper::setMode(mode, enabled);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000107 }
108}
109
Matt Buckleyc3894a42022-09-01 21:17:15 +0000110HalResult<void> HidlHalWrapperV1_0::sendPowerHint(V1_3::PowerHint hintId, uint32_t data) {
111 auto ret = mHandleV1_0->powerHint(static_cast<V1_0::PowerHint>(hintId), data);
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800112 return HalResult<void>::fromReturn(ret);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000113}
114
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800115HalResult<void> HidlHalWrapperV1_0::setInteractive(bool enabled) {
116 auto ret = mHandleV1_0->setInteractive(enabled);
117 return HalResult<void>::fromReturn(ret);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000118}
119
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800120HalResult<void> HidlHalWrapperV1_0::setFeature(V1_0::Feature feature, bool enabled) {
121 auto ret = mHandleV1_0->setFeature(feature, enabled);
122 return HalResult<void>::fromReturn(ret);
123}
124
Matt Buckleydb4192a2023-12-21 20:00:32 +0000125const char* HidlHalWrapperV1_0::getUnsupportedMessage() {
126 return "Power HAL AIDL is not supported";
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000127}
128
129// -------------------------------------------------------------------------------------------------
130
Matt Buckleyc3894a42022-09-01 21:17:15 +0000131HalResult<void> HidlHalWrapperV1_1::sendPowerHint(V1_3::PowerHint hintId, uint32_t data) {
132 auto handle = static_cast<V1_1::IPower*>(mHandleV1_0.get());
133 auto ret = handle->powerHintAsync(static_cast<V1_0::PowerHint>(hintId), data);
134 return HalResult<void>::fromReturn(ret);
135}
136
137// -------------------------------------------------------------------------------------------------
138
139HalResult<void> HidlHalWrapperV1_2::sendPowerHint(V1_3::PowerHint hintId, uint32_t data) {
140 auto handle = static_cast<V1_2::IPower*>(mHandleV1_0.get());
141 auto ret = handle->powerHintAsync_1_2(static_cast<V1_2::PowerHint>(hintId), data);
142 return HalResult<void>::fromReturn(ret);
143}
144
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700145HalResult<void> HidlHalWrapperV1_2::setBoost(Aidl::Boost boost, int32_t durationMs) {
Matt Buckleyc3894a42022-09-01 21:17:15 +0000146 switch (boost) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700147 case Aidl::Boost::CAMERA_SHOT:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000148 return sendPowerHint(V1_3::PowerHint::CAMERA_SHOT, durationMs);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700149 case Aidl::Boost::CAMERA_LAUNCH:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000150 return sendPowerHint(V1_3::PowerHint::CAMERA_LAUNCH, durationMs);
151 default:
152 return HidlHalWrapperV1_1::setBoost(boost, durationMs);
153 }
154}
155
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700156HalResult<void> HidlHalWrapperV1_2::setMode(Aidl::Mode mode, bool enabled) {
Matt Buckleyc3894a42022-09-01 21:17:15 +0000157 uint32_t data = enabled ? 1 : 0;
158 switch (mode) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700159 case Aidl::Mode::CAMERA_STREAMING_SECURE:
160 case Aidl::Mode::CAMERA_STREAMING_LOW:
161 case Aidl::Mode::CAMERA_STREAMING_MID:
162 case Aidl::Mode::CAMERA_STREAMING_HIGH:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000163 return sendPowerHint(V1_3::PowerHint::CAMERA_STREAMING, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700164 case Aidl::Mode::AUDIO_STREAMING_LOW_LATENCY:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000165 return sendPowerHint(V1_3::PowerHint::AUDIO_LOW_LATENCY, data);
166 default:
167 return HidlHalWrapperV1_1::setMode(mode, enabled);
168 }
169}
170
171// -------------------------------------------------------------------------------------------------
172
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700173HalResult<void> HidlHalWrapperV1_3::setMode(Aidl::Mode mode, bool enabled) {
Matt Buckleyc3894a42022-09-01 21:17:15 +0000174 uint32_t data = enabled ? 1 : 0;
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700175 if (mode == Aidl::Mode::EXPENSIVE_RENDERING) {
Matt Buckleyc3894a42022-09-01 21:17:15 +0000176 return sendPowerHint(V1_3::PowerHint::EXPENSIVE_RENDERING, data);
177 }
178 return HidlHalWrapperV1_2::setMode(mode, enabled);
179}
180
181HalResult<void> HidlHalWrapperV1_3::sendPowerHint(V1_3::PowerHint hintId, uint32_t data) {
182 auto handle = static_cast<V1_3::IPower*>(mHandleV1_0.get());
183 auto ret = handle->powerHintAsync_1_3(hintId, data);
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800184 return HalResult<void>::fromReturn(ret);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000185}
186
187// -------------------------------------------------------------------------------------------------
188
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700189HalResult<void> AidlHalWrapper::setBoost(Aidl::Boost boost, int32_t durationMs) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000190 std::unique_lock<std::mutex> lock(mBoostMutex);
Lais Andrade7b632a52020-12-03 21:07:48 +0000191 size_t idx = static_cast<size_t>(boost);
192
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000193 // Quick return if boost is not supported by HAL
Lais Andrade7b632a52020-12-03 21:07:48 +0000194 if (idx >= mBoostSupportedArray.size() || mBoostSupportedArray[idx] == HalSupport::OFF) {
Matt Buckleydb4192a2023-12-21 20:00:32 +0000195 ALOGV("Skipped setBoost %s because %s", toString(boost).c_str(), getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800196 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000197 }
198
Lais Andrade7b632a52020-12-03 21:07:48 +0000199 if (mBoostSupportedArray[idx] == HalSupport::UNKNOWN) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000200 bool isSupported = false;
Lais Andradeb59a9b52020-05-07 17:23:42 +0100201 auto isSupportedRet = mHandle->isBoostSupported(boost, &isSupported);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000202 if (!isSupportedRet.isOk()) {
Lais Andrade14e97b72020-07-14 12:27:44 +0000203 ALOGE("Skipped setBoost %s because check support failed with: %s",
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700204 toString(boost).c_str(), isSupportedRet.getDescription().c_str());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800205 // return HalResult::FAILED;
206 return HalResult<void>::fromStatus(isSupportedRet);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000207 }
208
Lais Andrade7b632a52020-12-03 21:07:48 +0000209 mBoostSupportedArray[idx] = isSupported ? HalSupport::ON : HalSupport::OFF;
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000210 if (!isSupported) {
Matt Buckleydb4192a2023-12-21 20:00:32 +0000211 ALOGV("Skipped setBoost %s because %s", toString(boost).c_str(),
212 getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800213 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000214 }
215 }
216 lock.unlock();
217
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000218 return HalResult<void>::fromStatus(mHandle->setBoost(boost, durationMs));
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000219}
220
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700221HalResult<void> AidlHalWrapper::setMode(Aidl::Mode mode, bool enabled) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000222 std::unique_lock<std::mutex> lock(mModeMutex);
Lais Andrade7b632a52020-12-03 21:07:48 +0000223 size_t idx = static_cast<size_t>(mode);
224
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000225 // Quick return if mode is not supported by HAL
Lais Andrade7b632a52020-12-03 21:07:48 +0000226 if (idx >= mModeSupportedArray.size() || mModeSupportedArray[idx] == HalSupport::OFF) {
Matt Buckleydb4192a2023-12-21 20:00:32 +0000227 ALOGV("Skipped setMode %s because %s", toString(mode).c_str(), getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800228 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000229 }
230
Lais Andrade7b632a52020-12-03 21:07:48 +0000231 if (mModeSupportedArray[idx] == HalSupport::UNKNOWN) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000232 bool isSupported = false;
Lais Andradeb59a9b52020-05-07 17:23:42 +0100233 auto isSupportedRet = mHandle->isModeSupported(mode, &isSupported);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000234 if (!isSupportedRet.isOk()) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700235 return HalResult<void>::failed(isSupportedRet.getDescription());
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000236 }
237
Lais Andrade7b632a52020-12-03 21:07:48 +0000238 mModeSupportedArray[idx] = isSupported ? HalSupport::ON : HalSupport::OFF;
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000239 if (!isSupported) {
Matt Buckleydb4192a2023-12-21 20:00:32 +0000240 ALOGV("Skipped setMode %s because %s", toString(mode).c_str(), getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800241 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000242 }
243 }
244 lock.unlock();
245
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000246 return HalResult<void>::fromStatus(mHandle->setMode(mode, enabled));
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000247}
248
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000249HalResult<std::shared_ptr<PowerHintSessionWrapper>> AidlHalWrapper::createHintSession(
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800250 int32_t tgid, int32_t uid, const std::vector<int32_t>& threadIds, int64_t durationNanos) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700251 std::shared_ptr<Aidl::IPowerHintSession> appSession;
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000252 return HalResult<std::shared_ptr<PowerHintSessionWrapper>>::
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800253 fromStatus(mHandle->createHintSession(tgid, uid, threadIds, durationNanos, &appSession),
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000254 std::make_shared<PowerHintSessionWrapper>(std::move(appSession)));
Matt Buckleydb4192a2023-12-21 20:00:32 +0000255}
256
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000257HalResult<std::shared_ptr<PowerHintSessionWrapper>> AidlHalWrapper::createHintSessionWithConfig(
Matt Buckleydb4192a2023-12-21 20:00:32 +0000258 int32_t tgid, int32_t uid, const std::vector<int32_t>& threadIds, int64_t durationNanos,
259 Aidl::SessionTag tag, Aidl::SessionConfig* config) {
260 std::shared_ptr<Aidl::IPowerHintSession> appSession;
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000261 return HalResult<std::shared_ptr<PowerHintSessionWrapper>>::
Matt Buckleydb4192a2023-12-21 20:00:32 +0000262 fromStatus(mHandle->createHintSessionWithConfig(tgid, uid, threadIds, durationNanos,
263 tag, config, &appSession),
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000264 std::make_shared<PowerHintSessionWrapper>(std::move(appSession)));
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800265}
266
267HalResult<int64_t> AidlHalWrapper::getHintSessionPreferredRate() {
268 int64_t rate = -1;
269 auto result = mHandle->getHintSessionPreferredRate(&rate);
270 return HalResult<int64_t>::fromStatus(result, rate);
271}
272
Matt Buckleydb4192a2023-12-21 20:00:32 +0000273HalResult<Aidl::ChannelConfig> AidlHalWrapper::getSessionChannel(int tgid, int uid) {
274 Aidl::ChannelConfig config;
275 auto result = mHandle->getSessionChannel(tgid, uid, &config);
276 return HalResult<Aidl::ChannelConfig>::fromStatus(result, std::move(config));
277}
278
279HalResult<void> AidlHalWrapper::closeSessionChannel(int tgid, int uid) {
Matt Buckley6c18e6d2024-02-07 23:39:50 +0000280 return HalResult<void>::fromStatus(mHandle->closeSessionChannel(tgid, uid));
Matt Buckleydb4192a2023-12-21 20:00:32 +0000281}
282
283const char* AidlHalWrapper::getUnsupportedMessage() {
284 return "Power HAL doesn't support it";
285}
286
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000287// -------------------------------------------------------------------------------------------------
288
Lais Andradeb59a9b52020-05-07 17:23:42 +0100289} // namespace power
290
291} // namespace android