blob: 1009100cc2d9dc5f72cdb3f22ef02504f220f70b [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>
Lais Andrade4d51f6c2020-03-25 10:58:31 +000021#include <powermanager/PowerHalWrapper.h>
Lais Andradeb59a9b52020-05-07 17:23:42 +010022#include <utils/Log.h>
Lais Andrade4d51f6c2020-03-25 10:58:31 +000023
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080024#include <cinttypes>
25
Lais Andradeb59a9b52020-05-07 17:23:42 +010026using namespace android::hardware::power;
Xiang Wang99f6f3c2023-05-22 13:12:16 -070027namespace Aidl = aidl::android::hardware::power;
Lais Andrade4d51f6c2020-03-25 10:58:31 +000028
29namespace android {
30
Lais Andradeb59a9b52020-05-07 17:23:42 +010031namespace power {
32
Lais Andrade4d51f6c2020-03-25 10:58:31 +000033// -------------------------------------------------------------------------------------------------
Xiang Wang99f6f3c2023-05-22 13:12:16 -070034inline HalResult<void> toHalResult(const ndk::ScopedAStatus& result) {
Lais Andrade14e97b72020-07-14 12:27:44 +000035 if (result.isOk()) {
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080036 return HalResult<void>::ok();
Lais Andrade14e97b72020-07-14 12:27:44 +000037 }
Xiang Wang99f6f3c2023-05-22 13:12:16 -070038 ALOGE("Power HAL request failed: %s", result.getDescription().c_str());
39 return HalResult<void>::failed(result.getDescription());
Lais Andradeb59a9b52020-05-07 17:23:42 +010040}
41
42// -------------------------------------------------------------------------------------------------
43
Xiang Wang99f6f3c2023-05-22 13:12:16 -070044HalResult<void> EmptyHalWrapper::setBoost(Aidl::Boost boost, int32_t durationMs) {
Matt Buckleydb4192a2023-12-21 20:00:32 +000045 ALOGV("Skipped setBoost %s with duration %dms because %s", toString(boost).c_str(), durationMs,
46 getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080047 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +000048}
49
Xiang Wang99f6f3c2023-05-22 13:12:16 -070050HalResult<void> EmptyHalWrapper::setMode(Aidl::Mode mode, bool enabled) {
Matt Buckleydb4192a2023-12-21 20:00:32 +000051 ALOGV("Skipped setMode %s to %s because %s", toString(mode).c_str(), enabled ? "true" : "false",
52 getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080053 return HalResult<void>::unsupported();
54}
55
Xiang Wang99f6f3c2023-05-22 13:12:16 -070056HalResult<std::shared_ptr<Aidl::IPowerHintSession>> EmptyHalWrapper::createHintSession(
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080057 int32_t, int32_t, const std::vector<int32_t>& threadIds, int64_t) {
Matt Buckleydb4192a2023-12-21 20:00:32 +000058 ALOGV("Skipped createHintSession(task num=%zu) because %s", threadIds.size(),
59 getUnsupportedMessage());
60 return HalResult<std::shared_ptr<Aidl::IPowerHintSession>>::unsupported();
61}
62
63HalResult<std::shared_ptr<Aidl::IPowerHintSession>> EmptyHalWrapper::createHintSessionWithConfig(
64 int32_t, int32_t, const std::vector<int32_t>& threadIds, int64_t, Aidl::SessionTag,
65 Aidl::SessionConfig*) {
66 ALOGV("Skipped createHintSessionWithConfig(task num=%zu) because %s", threadIds.size(),
67 getUnsupportedMessage());
Xiang Wang99f6f3c2023-05-22 13:12:16 -070068 return HalResult<std::shared_ptr<Aidl::IPowerHintSession>>::unsupported();
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080069}
70
71HalResult<int64_t> EmptyHalWrapper::getHintSessionPreferredRate() {
Matt Buckleydb4192a2023-12-21 20:00:32 +000072 ALOGV("Skipped getHintSessionPreferredRate because %s", getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +080073 return HalResult<int64_t>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +000074}
75
Matt Buckleydb4192a2023-12-21 20:00:32 +000076HalResult<Aidl::ChannelConfig> EmptyHalWrapper::getSessionChannel(int, int) {
77 ALOGV("Skipped getSessionChannel because %s", getUnsupportedMessage());
78 return HalResult<Aidl::ChannelConfig>::unsupported();
79}
80
81HalResult<void> EmptyHalWrapper::closeSessionChannel(int, int) {
82 ALOGV("Skipped closeSessionChannel because %s", getUnsupportedMessage());
83 return HalResult<void>::unsupported();
84}
85
86const char* EmptyHalWrapper::getUnsupportedMessage() {
87 return "Power HAL is not supported";
88}
89
Lais Andrade4d51f6c2020-03-25 10:58:31 +000090// -------------------------------------------------------------------------------------------------
91
Xiang Wang99f6f3c2023-05-22 13:12:16 -070092HalResult<void> HidlHalWrapperV1_0::setBoost(Aidl::Boost boost, int32_t durationMs) {
93 if (boost == Aidl::Boost::INTERACTION) {
Matt Buckleyc3894a42022-09-01 21:17:15 +000094 return sendPowerHint(V1_3::PowerHint::INTERACTION, durationMs);
Lais Andrade4d51f6c2020-03-25 10:58:31 +000095 } else {
Matt Buckleydb4192a2023-12-21 20:00:32 +000096 return EmptyHalWrapper::setBoost(boost, durationMs);
Lais Andrade4d51f6c2020-03-25 10:58:31 +000097 }
98}
99
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700100HalResult<void> HidlHalWrapperV1_0::setMode(Aidl::Mode mode, bool enabled) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000101 uint32_t data = enabled ? 1 : 0;
102 switch (mode) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700103 case Aidl::Mode::LAUNCH:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000104 return sendPowerHint(V1_3::PowerHint::LAUNCH, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700105 case Aidl::Mode::LOW_POWER:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000106 return sendPowerHint(V1_3::PowerHint::LOW_POWER, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700107 case Aidl::Mode::SUSTAINED_PERFORMANCE:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000108 return sendPowerHint(V1_3::PowerHint::SUSTAINED_PERFORMANCE, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700109 case Aidl::Mode::VR:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000110 return sendPowerHint(V1_3::PowerHint::VR_MODE, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700111 case Aidl::Mode::INTERACTIVE:
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000112 return setInteractive(enabled);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700113 case Aidl::Mode::DOUBLE_TAP_TO_WAKE:
Lais Andradeb59a9b52020-05-07 17:23:42 +0100114 return setFeature(V1_0::Feature::POWER_FEATURE_DOUBLE_TAP_TO_WAKE, enabled);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000115 default:
Matt Buckleydb4192a2023-12-21 20:00:32 +0000116 return EmptyHalWrapper::setMode(mode, enabled);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000117 }
118}
119
Matt Buckleyc3894a42022-09-01 21:17:15 +0000120HalResult<void> HidlHalWrapperV1_0::sendPowerHint(V1_3::PowerHint hintId, uint32_t data) {
121 auto ret = mHandleV1_0->powerHint(static_cast<V1_0::PowerHint>(hintId), data);
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800122 return HalResult<void>::fromReturn(ret);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000123}
124
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800125HalResult<void> HidlHalWrapperV1_0::setInteractive(bool enabled) {
126 auto ret = mHandleV1_0->setInteractive(enabled);
127 return HalResult<void>::fromReturn(ret);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000128}
129
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800130HalResult<void> HidlHalWrapperV1_0::setFeature(V1_0::Feature feature, bool enabled) {
131 auto ret = mHandleV1_0->setFeature(feature, enabled);
132 return HalResult<void>::fromReturn(ret);
133}
134
Matt Buckleydb4192a2023-12-21 20:00:32 +0000135const char* HidlHalWrapperV1_0::getUnsupportedMessage() {
136 return "Power HAL AIDL is not supported";
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000137}
138
139// -------------------------------------------------------------------------------------------------
140
Matt Buckleyc3894a42022-09-01 21:17:15 +0000141HalResult<void> HidlHalWrapperV1_1::sendPowerHint(V1_3::PowerHint hintId, uint32_t data) {
142 auto handle = static_cast<V1_1::IPower*>(mHandleV1_0.get());
143 auto ret = handle->powerHintAsync(static_cast<V1_0::PowerHint>(hintId), data);
144 return HalResult<void>::fromReturn(ret);
145}
146
147// -------------------------------------------------------------------------------------------------
148
149HalResult<void> HidlHalWrapperV1_2::sendPowerHint(V1_3::PowerHint hintId, uint32_t data) {
150 auto handle = static_cast<V1_2::IPower*>(mHandleV1_0.get());
151 auto ret = handle->powerHintAsync_1_2(static_cast<V1_2::PowerHint>(hintId), data);
152 return HalResult<void>::fromReturn(ret);
153}
154
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700155HalResult<void> HidlHalWrapperV1_2::setBoost(Aidl::Boost boost, int32_t durationMs) {
Matt Buckleyc3894a42022-09-01 21:17:15 +0000156 switch (boost) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700157 case Aidl::Boost::CAMERA_SHOT:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000158 return sendPowerHint(V1_3::PowerHint::CAMERA_SHOT, durationMs);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700159 case Aidl::Boost::CAMERA_LAUNCH:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000160 return sendPowerHint(V1_3::PowerHint::CAMERA_LAUNCH, durationMs);
161 default:
162 return HidlHalWrapperV1_1::setBoost(boost, durationMs);
163 }
164}
165
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700166HalResult<void> HidlHalWrapperV1_2::setMode(Aidl::Mode mode, bool enabled) {
Matt Buckleyc3894a42022-09-01 21:17:15 +0000167 uint32_t data = enabled ? 1 : 0;
168 switch (mode) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700169 case Aidl::Mode::CAMERA_STREAMING_SECURE:
170 case Aidl::Mode::CAMERA_STREAMING_LOW:
171 case Aidl::Mode::CAMERA_STREAMING_MID:
172 case Aidl::Mode::CAMERA_STREAMING_HIGH:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000173 return sendPowerHint(V1_3::PowerHint::CAMERA_STREAMING, data);
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700174 case Aidl::Mode::AUDIO_STREAMING_LOW_LATENCY:
Matt Buckleyc3894a42022-09-01 21:17:15 +0000175 return sendPowerHint(V1_3::PowerHint::AUDIO_LOW_LATENCY, data);
176 default:
177 return HidlHalWrapperV1_1::setMode(mode, enabled);
178 }
179}
180
181// -------------------------------------------------------------------------------------------------
182
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700183HalResult<void> HidlHalWrapperV1_3::setMode(Aidl::Mode mode, bool enabled) {
Matt Buckleyc3894a42022-09-01 21:17:15 +0000184 uint32_t data = enabled ? 1 : 0;
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700185 if (mode == Aidl::Mode::EXPENSIVE_RENDERING) {
Matt Buckleyc3894a42022-09-01 21:17:15 +0000186 return sendPowerHint(V1_3::PowerHint::EXPENSIVE_RENDERING, data);
187 }
188 return HidlHalWrapperV1_2::setMode(mode, enabled);
189}
190
191HalResult<void> HidlHalWrapperV1_3::sendPowerHint(V1_3::PowerHint hintId, uint32_t data) {
192 auto handle = static_cast<V1_3::IPower*>(mHandleV1_0.get());
193 auto ret = handle->powerHintAsync_1_3(hintId, data);
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800194 return HalResult<void>::fromReturn(ret);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000195}
196
197// -------------------------------------------------------------------------------------------------
198
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700199HalResult<void> AidlHalWrapper::setBoost(Aidl::Boost boost, int32_t durationMs) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000200 std::unique_lock<std::mutex> lock(mBoostMutex);
Lais Andrade7b632a52020-12-03 21:07:48 +0000201 size_t idx = static_cast<size_t>(boost);
202
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000203 // Quick return if boost is not supported by HAL
Lais Andrade7b632a52020-12-03 21:07:48 +0000204 if (idx >= mBoostSupportedArray.size() || mBoostSupportedArray[idx] == HalSupport::OFF) {
Matt Buckleydb4192a2023-12-21 20:00:32 +0000205 ALOGV("Skipped setBoost %s because %s", toString(boost).c_str(), getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800206 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000207 }
208
Lais Andrade7b632a52020-12-03 21:07:48 +0000209 if (mBoostSupportedArray[idx] == HalSupport::UNKNOWN) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000210 bool isSupported = false;
Lais Andradeb59a9b52020-05-07 17:23:42 +0100211 auto isSupportedRet = mHandle->isBoostSupported(boost, &isSupported);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000212 if (!isSupportedRet.isOk()) {
Lais Andrade14e97b72020-07-14 12:27:44 +0000213 ALOGE("Skipped setBoost %s because check support failed with: %s",
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700214 toString(boost).c_str(), isSupportedRet.getDescription().c_str());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800215 // return HalResult::FAILED;
216 return HalResult<void>::fromStatus(isSupportedRet);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000217 }
218
Lais Andrade7b632a52020-12-03 21:07:48 +0000219 mBoostSupportedArray[idx] = isSupported ? HalSupport::ON : HalSupport::OFF;
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000220 if (!isSupported) {
Matt Buckleydb4192a2023-12-21 20:00:32 +0000221 ALOGV("Skipped setBoost %s because %s", toString(boost).c_str(),
222 getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800223 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000224 }
225 }
226 lock.unlock();
227
Lais Andradeb59a9b52020-05-07 17:23:42 +0100228 return toHalResult(mHandle->setBoost(boost, durationMs));
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000229}
230
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700231HalResult<void> AidlHalWrapper::setMode(Aidl::Mode mode, bool enabled) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000232 std::unique_lock<std::mutex> lock(mModeMutex);
Lais Andrade7b632a52020-12-03 21:07:48 +0000233 size_t idx = static_cast<size_t>(mode);
234
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000235 // Quick return if mode is not supported by HAL
Lais Andrade7b632a52020-12-03 21:07:48 +0000236 if (idx >= mModeSupportedArray.size() || mModeSupportedArray[idx] == HalSupport::OFF) {
Matt Buckleydb4192a2023-12-21 20:00:32 +0000237 ALOGV("Skipped setMode %s because %s", toString(mode).c_str(), getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800238 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000239 }
240
Lais Andrade7b632a52020-12-03 21:07:48 +0000241 if (mModeSupportedArray[idx] == HalSupport::UNKNOWN) {
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000242 bool isSupported = false;
Lais Andradeb59a9b52020-05-07 17:23:42 +0100243 auto isSupportedRet = mHandle->isModeSupported(mode, &isSupported);
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000244 if (!isSupportedRet.isOk()) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700245 return HalResult<void>::failed(isSupportedRet.getDescription());
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000246 }
247
Lais Andrade7b632a52020-12-03 21:07:48 +0000248 mModeSupportedArray[idx] = isSupported ? HalSupport::ON : HalSupport::OFF;
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000249 if (!isSupported) {
Matt Buckleydb4192a2023-12-21 20:00:32 +0000250 ALOGV("Skipped setMode %s because %s", toString(mode).c_str(), getUnsupportedMessage());
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800251 return HalResult<void>::unsupported();
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000252 }
253 }
254 lock.unlock();
255
Lais Andradeb59a9b52020-05-07 17:23:42 +0100256 return toHalResult(mHandle->setMode(mode, enabled));
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000257}
258
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700259HalResult<std::shared_ptr<Aidl::IPowerHintSession>> AidlHalWrapper::createHintSession(
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800260 int32_t tgid, int32_t uid, const std::vector<int32_t>& threadIds, int64_t durationNanos) {
Xiang Wang99f6f3c2023-05-22 13:12:16 -0700261 std::shared_ptr<Aidl::IPowerHintSession> appSession;
262 return HalResult<std::shared_ptr<Aidl::IPowerHintSession>>::
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800263 fromStatus(mHandle->createHintSession(tgid, uid, threadIds, durationNanos, &appSession),
Matt Buckleydb4192a2023-12-21 20:00:32 +0000264 std::move(appSession));
265}
266
267HalResult<std::shared_ptr<Aidl::IPowerHintSession>> AidlHalWrapper::createHintSessionWithConfig(
268 int32_t tgid, int32_t uid, const std::vector<int32_t>& threadIds, int64_t durationNanos,
269 Aidl::SessionTag tag, Aidl::SessionConfig* config) {
270 std::shared_ptr<Aidl::IPowerHintSession> appSession;
271 return HalResult<std::shared_ptr<Aidl::IPowerHintSession>>::
272 fromStatus(mHandle->createHintSessionWithConfig(tgid, uid, threadIds, durationNanos,
273 tag, config, &appSession),
274 std::move(appSession));
Jimmy Shiu0b264bb2021-03-03 00:30:50 +0800275}
276
277HalResult<int64_t> AidlHalWrapper::getHintSessionPreferredRate() {
278 int64_t rate = -1;
279 auto result = mHandle->getHintSessionPreferredRate(&rate);
280 return HalResult<int64_t>::fromStatus(result, rate);
281}
282
Matt Buckleydb4192a2023-12-21 20:00:32 +0000283HalResult<Aidl::ChannelConfig> AidlHalWrapper::getSessionChannel(int tgid, int uid) {
284 Aidl::ChannelConfig config;
285 auto result = mHandle->getSessionChannel(tgid, uid, &config);
286 return HalResult<Aidl::ChannelConfig>::fromStatus(result, std::move(config));
287}
288
289HalResult<void> AidlHalWrapper::closeSessionChannel(int tgid, int uid) {
290 return toHalResult(mHandle->closeSessionChannel(tgid, uid));
291}
292
293const char* AidlHalWrapper::getUnsupportedMessage() {
294 return "Power HAL doesn't support it";
295}
296
Lais Andrade4d51f6c2020-03-25 10:58:31 +0000297// -------------------------------------------------------------------------------------------------
298
Lais Andradeb59a9b52020-05-07 17:23:42 +0100299} // namespace power
300
301} // namespace android