blob: ffe20c653ae9e81e233b30ef7c4c1451121927ca [file] [log] [blame]
Wei Wang61c2a332020-01-08 16:51:47 -08001/*
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#include <aidl/Gtest.h>
17#include <aidl/Vintf.h>
18
Wei Wang05003412021-04-01 10:44:29 -070019#include <aidl/android/hardware/power/BnPower.h>
20#include <aidl/android/hardware/power/BnPowerHintSession.h>
Dan Stozacca80272020-01-13 13:06:13 -080021#include <android-base/properties.h>
Wei Wang05003412021-04-01 10:44:29 -070022#include <android/binder_ibinder.h>
23#include <android/binder_manager.h>
24#include <android/binder_process.h>
Wei Wang9df909d2021-06-12 18:26:38 -070025#include <android/binder_status.h>
Wei Wang61c2a332020-01-08 16:51:47 -080026
Matt Buckleycaac1472023-12-12 03:55:50 +000027#include <fmq/AidlMessageQueue.h>
28#include <fmq/EventFlag.h>
29
Wei Wang05003412021-04-01 10:44:29 -070030#include <unistd.h>
Matt Buckleycaac1472023-12-12 03:55:50 +000031#include <cstdint>
32#include "aidl/android/hardware/common/fmq/SynchronizedReadWrite.h"
Xiang Wangaf052822024-10-21 23:18:29 +000033#include "aidl/android/hardware/power/CpuHeadroomParams.h"
34#include "aidl/android/hardware/power/GpuHeadroomParams.h"
Wei Wang61c2a332020-01-08 16:51:47 -080035
Wei Wang05003412021-04-01 10:44:29 -070036namespace aidl::android::hardware::power {
37namespace {
38
Matt Buckley0efc7482024-10-29 18:39:20 +000039using namespace std::chrono_literals;
40
Matt Buckleycaac1472023-12-12 03:55:50 +000041using ::aidl::android::hardware::common::fmq::SynchronizedReadWrite;
42using ::android::AidlMessageQueue;
Matt Buckleyf7c36d42024-02-27 01:31:43 +000043using ::android::hardware::EventFlag;
Wei Wang61c2a332020-01-08 16:51:47 -080044using android::hardware::power::Boost;
Matt Buckleycaac1472023-12-12 03:55:50 +000045using android::hardware::power::ChannelConfig;
46using android::hardware::power::ChannelMessage;
Xiang Wangaf052822024-10-21 23:18:29 +000047using android::hardware::power::CpuHeadroomParams;
Xiang Wangb0d667e2024-11-16 06:19:21 +000048using android::hardware::power::CpuHeadroomResult;
Xiang Wangaf052822024-10-21 23:18:29 +000049using android::hardware::power::GpuHeadroomParams;
Xiang Wangb0d667e2024-11-16 06:19:21 +000050using android::hardware::power::GpuHeadroomResult;
Wei Wang61c2a332020-01-08 16:51:47 -080051using android::hardware::power::IPower;
Wei Wang05003412021-04-01 10:44:29 -070052using android::hardware::power::IPowerHintSession;
Wei Wang61c2a332020-01-08 16:51:47 -080053using android::hardware::power::Mode;
Matt Buckley13843882022-09-15 22:32:56 +000054using android::hardware::power::SessionHint;
Matt Buckley1fde90c2023-06-28 19:55:26 +000055using android::hardware::power::SessionMode;
Matt Buckley607720e2024-10-28 19:21:37 +000056using android::hardware::power::SupportInfo;
Wei Wang05003412021-04-01 10:44:29 -070057using android::hardware::power::WorkDuration;
Matt Buckleyf7c36d42024-02-27 01:31:43 +000058using ChannelMessageContents = ChannelMessage::ChannelMessageContents;
59using ModeSetter = ChannelMessage::ChannelMessageContents::SessionModeSetter;
60using MessageTag = ChannelMessage::ChannelMessageContents::Tag;
Wei Wang61c2a332020-01-08 16:51:47 -080061
Matt Buckleycaac1472023-12-12 03:55:50 +000062using SessionMessageQueue = AidlMessageQueue<ChannelMessage, SynchronizedReadWrite>;
Matt Buckleyf7c36d42024-02-27 01:31:43 +000063using FlagMessageQueue = AidlMessageQueue<int8_t, SynchronizedReadWrite>;
Matt Buckleycaac1472023-12-12 03:55:50 +000064
Wei Wang05003412021-04-01 10:44:29 -070065const std::vector<Boost> kBoosts{ndk::enum_range<Boost>().begin(), ndk::enum_range<Boost>().end()};
Wei Wang61c2a332020-01-08 16:51:47 -080066
Wei Wang05003412021-04-01 10:44:29 -070067const std::vector<Mode> kModes{ndk::enum_range<Mode>().begin(), ndk::enum_range<Mode>().end()};
Wei Wang61c2a332020-01-08 16:51:47 -080068
Matt Buckley13843882022-09-15 22:32:56 +000069const std::vector<SessionHint> kSessionHints{ndk::enum_range<SessionHint>().begin(),
70 ndk::enum_range<SessionHint>().end()};
71
Matt Buckley1fde90c2023-06-28 19:55:26 +000072const std::vector<SessionMode> kSessionModes{ndk::enum_range<SessionMode>().begin(),
73 ndk::enum_range<SessionMode>().end()};
74
Wei Wang61c2a332020-01-08 16:51:47 -080075const std::vector<Boost> kInvalidBoosts = {
76 static_cast<Boost>(static_cast<int32_t>(kBoosts.front()) - 1),
77 static_cast<Boost>(static_cast<int32_t>(kBoosts.back()) + 1),
78};
79
80const std::vector<Mode> kInvalidModes = {
81 static_cast<Mode>(static_cast<int32_t>(kModes.front()) - 1),
82 static_cast<Mode>(static_cast<int32_t>(kModes.back()) + 1),
83};
84
Matt Buckley13843882022-09-15 22:32:56 +000085const std::vector<SessionHint> kInvalidSessionHints = {
86 static_cast<SessionHint>(static_cast<int32_t>(kSessionHints.front()) - 1),
87 static_cast<SessionHint>(static_cast<int32_t>(kSessionHints.back()) + 1),
88};
89
Matt Buckley1fde90c2023-06-28 19:55:26 +000090const std::vector<SessionMode> kInvalidSessionModes = {
91 static_cast<SessionMode>(static_cast<int32_t>(kSessionModes.front()) - 1),
92 static_cast<SessionMode>(static_cast<int32_t>(kSessionModes.back()) + 1),
93};
94
Matt Buckley607720e2024-10-28 19:21:37 +000095template <class T>
96constexpr size_t enum_size() {
97 return static_cast<size_t>(*(ndk::enum_range<T>().end() - 1)) + 1;
98}
99
100template <class E>
101bool supportFromBitset(int64_t& supportInt, E type) {
102 return (supportInt >> static_cast<int>(type)) % 2;
103}
104
Wei Wang05003412021-04-01 10:44:29 -0700105class DurationWrapper : public WorkDuration {
106 public:
107 DurationWrapper(int64_t dur, int64_t time) {
108 durationNanos = dur;
109 timeStampNanos = time;
110 }
111};
112
113const std::vector<int32_t> kSelfTids = {
114 gettid(),
115};
116
117const std::vector<int32_t> kEmptyTids = {};
118
Wei Wang05003412021-04-01 10:44:29 -0700119const std::vector<WorkDuration> kDurationsWithZero = {
120 DurationWrapper(1000L, 1L),
121 DurationWrapper(0L, 2L),
122};
123
124const std::vector<WorkDuration> kDurationsWithNegative = {
125 DurationWrapper(1000L, 1L),
126 DurationWrapper(-1000L, 2L),
127};
128
129const std::vector<WorkDuration> kDurations = {
130 DurationWrapper(1L, 1L),
131 DurationWrapper(1000L, 2L),
132 DurationWrapper(1000000L, 3L),
133 DurationWrapper(1000000000L, 4L),
134};
135
Wei Wang61c2a332020-01-08 16:51:47 -0800136class PowerAidl : public testing::TestWithParam<std::string> {
137 public:
138 virtual void SetUp() override {
Wei Wang05003412021-04-01 10:44:29 -0700139 AIBinder* binder = AServiceManager_waitForService(GetParam().c_str());
140 ASSERT_NE(binder, nullptr);
141 power = IPower::fromBinder(ndk::SpAIBinder(binder));
Matt Buckley42027e02023-08-07 23:50:04 +0000142 auto status = power->getInterfaceVersion(&mServiceVersion);
143 ASSERT_TRUE(status.isOk());
Matt Buckley0efc7482024-10-29 18:39:20 +0000144 if (mServiceVersion >= 6) {
145 mSupportInfo = std::make_optional<SupportInfo>();
146 ASSERT_TRUE(power->getSupportInfo(&(*mSupportInfo)).isOk());
147 mSessionSupport = mSupportInfo->usesSessions;
148 } else if (mServiceVersion >= 2) {
jimmyshiu81915752024-03-15 16:37:19 +0000149 status = power->createHintSession(getpid(), getuid(), kSelfTids, 16666666L, &mSession);
150 mSessionSupport = status.isOk();
151 }
Wei Wang61c2a332020-01-08 16:51:47 -0800152 }
153
Wei Wang05003412021-04-01 10:44:29 -0700154 std::shared_ptr<IPower> power;
Matt Buckley42027e02023-08-07 23:50:04 +0000155 int32_t mServiceVersion;
jimmyshiu81915752024-03-15 16:37:19 +0000156 std::shared_ptr<IPowerHintSession> mSession;
157 bool mSessionSupport = false;
Matt Buckley0efc7482024-10-29 18:39:20 +0000158 std::optional<SupportInfo> mSupportInfo = std::nullopt;
Matt Buckley42027e02023-08-07 23:50:04 +0000159};
160
161class HintSessionAidl : public PowerAidl {
162 public:
163 virtual void SetUp() override {
164 PowerAidl::SetUp();
165 if (mServiceVersion < 2) {
166 GTEST_SKIP() << "DEVICE not launching with Power V2 and beyond.";
167 }
jimmyshiu81915752024-03-15 16:37:19 +0000168 if (!mSessionSupport) {
169 GTEST_SKIP() << "DEVICE not support Hint Session.";
170 }
Matt Buckley42027e02023-08-07 23:50:04 +0000171 ASSERT_NE(nullptr, mSession);
172 }
Wei Wang61c2a332020-01-08 16:51:47 -0800173};
174
Matt Buckleyf7c36d42024-02-27 01:31:43 +0000175class FMQAidl : public PowerAidl {
176 public:
177 virtual void SetUp() override {
178 PowerAidl::SetUp();
179 if (mServiceVersion < 5) {
180 GTEST_SKIP() << "DEVICE not launching with Power V5 and beyond.";
181 }
182
183 auto status =
184 power->createHintSessionWithConfig(getpid(), getuid(), kSelfTids, 16666666L,
185 SessionTag::OTHER, &mSessionConfig, &mSession);
Jimmy Shiua18a54d2024-03-20 08:21:22 +0000186 mSessionSupport = status.isOk();
187 if (!mSessionSupport) {
188 GTEST_SKIP() << "DEVICE not support Hint Session.";
189 }
Matt Buckleyf7c36d42024-02-27 01:31:43 +0000190 ASSERT_NE(nullptr, mSession);
191
192 status = power->getSessionChannel(getpid(), getuid(), &mChannelConfig);
193 ASSERT_TRUE(status.isOk());
194 mChannel = std::make_shared<SessionMessageQueue>(mChannelConfig.channelDescriptor, true);
195 ASSERT_TRUE(mChannel->isValid());
196
197 if (mChannelConfig.eventFlagDescriptor.has_value()) {
198 mFlagChannel =
199 std::make_shared<FlagMessageQueue>(*mChannelConfig.eventFlagDescriptor, true);
200 ASSERT_EQ(EventFlag::createEventFlag(mFlagChannel->getEventFlagWord(), &mEventFlag),
201 ::android::OK);
202 } else {
203 ASSERT_EQ(EventFlag::createEventFlag(mChannel->getEventFlagWord(), &mEventFlag),
204 ::android::OK);
205 }
206
207 ASSERT_NE(mEventFlag, nullptr);
208 }
209 virtual void TearDown() {
jimmyshiud3753ec2024-03-19 08:56:42 +0000210 if (mSession) {
211 mSession->close();
212 if (mChannel->isValid()) {
213 ASSERT_TRUE(power->closeSessionChannel(getpid(), getuid()).isOk());
214 }
215 }
Matt Buckleyf7c36d42024-02-27 01:31:43 +0000216 }
217
218 protected:
219 std::shared_ptr<IPowerHintSession> mSession;
220 std::shared_ptr<SessionMessageQueue> mChannel;
221 std::shared_ptr<FlagMessageQueue> mFlagChannel;
222 SessionConfig mSessionConfig;
223 ChannelConfig mChannelConfig;
224 ::android::hardware::EventFlag* mEventFlag;
225};
226
Wei Wang61c2a332020-01-08 16:51:47 -0800227TEST_P(PowerAidl, setMode) {
228 for (const auto& mode : kModes) {
229 ASSERT_TRUE(power->setMode(mode, true).isOk());
230 ASSERT_TRUE(power->setMode(mode, false).isOk());
231 }
232 for (const auto& mode : kInvalidModes) {
233 ASSERT_TRUE(power->setMode(mode, true).isOk());
234 ASSERT_TRUE(power->setMode(mode, false).isOk());
235 }
236}
237
238TEST_P(PowerAidl, isModeSupported) {
239 for (const auto& mode : kModes) {
240 bool supported;
241 ASSERT_TRUE(power->isModeSupported(mode, &supported).isOk());
242 }
243 for (const auto& mode : kInvalidModes) {
244 bool supported;
245 ASSERT_TRUE(power->isModeSupported(mode, &supported).isOk());
Dan Stozacca80272020-01-13 13:06:13 -0800246 // Should return false for values outside enum
Wei Wang61c2a332020-01-08 16:51:47 -0800247 ASSERT_FALSE(supported);
248 }
249}
250
251TEST_P(PowerAidl, setBoost) {
252 for (const auto& boost : kBoosts) {
253 ASSERT_TRUE(power->setBoost(boost, 0).isOk());
254 ASSERT_TRUE(power->setBoost(boost, 1000).isOk());
255 ASSERT_TRUE(power->setBoost(boost, -1).isOk());
256 }
257 for (const auto& boost : kInvalidBoosts) {
258 ASSERT_TRUE(power->setBoost(boost, 0).isOk());
259 ASSERT_TRUE(power->setBoost(boost, 1000).isOk());
260 ASSERT_TRUE(power->setBoost(boost, -1).isOk());
261 }
262}
263
264TEST_P(PowerAidl, isBoostSupported) {
265 for (const auto& boost : kBoosts) {
266 bool supported;
267 ASSERT_TRUE(power->isBoostSupported(boost, &supported).isOk());
268 }
269 for (const auto& boost : kInvalidBoosts) {
270 bool supported;
271 ASSERT_TRUE(power->isBoostSupported(boost, &supported).isOk());
Dan Stozacca80272020-01-13 13:06:13 -0800272 // Should return false for values outside enum
Wei Wang61c2a332020-01-08 16:51:47 -0800273 ASSERT_FALSE(supported);
274 }
275}
276
Wei Wang05003412021-04-01 10:44:29 -0700277TEST_P(PowerAidl, getHintSessionPreferredRate) {
jimmyshiu81915752024-03-15 16:37:19 +0000278 if (!mSessionSupport) {
279 GTEST_SKIP() << "DEVICE not support Hint Session.";
280 }
Matt Buckley42027e02023-08-07 23:50:04 +0000281 if (mServiceVersion < 2) {
282 GTEST_SKIP() << "DEVICE not launching with Power V2 and beyond.";
Wei Wang05003412021-04-01 10:44:29 -0700283 }
Matt Buckley42027e02023-08-07 23:50:04 +0000284
285 int64_t rate = -1;
286 ASSERT_TRUE(power->getHintSessionPreferredRate(&rate).isOk());
Wei Wang05003412021-04-01 10:44:29 -0700287 // At least 1ms rate limit from HAL
288 ASSERT_GE(rate, 1000000);
289}
290
Matt Buckleycaac1472023-12-12 03:55:50 +0000291TEST_P(PowerAidl, createHintSessionWithConfig) {
jimmyshiu81915752024-03-15 16:37:19 +0000292 if (!mSessionSupport) {
293 GTEST_SKIP() << "DEVICE not support Hint Session.";
294 }
Matt Buckleycaac1472023-12-12 03:55:50 +0000295 if (mServiceVersion < 5) {
296 GTEST_SKIP() << "DEVICE not launching with Power V5 and beyond.";
297 }
298 std::shared_ptr<IPowerHintSession> session;
299 SessionConfig config;
300
301 auto status = power->createHintSessionWithConfig(getpid(), getuid(), kSelfTids, 16666666L,
302 SessionTag::OTHER, &config, &session);
303 ASSERT_TRUE(status.isOk());
304 ASSERT_NE(nullptr, session);
305}
306
Xiang Wangaf052822024-10-21 23:18:29 +0000307TEST_P(PowerAidl, getCpuHeadroom) {
308 if (mServiceVersion < 6) {
309 GTEST_SKIP() << "DEVICE not launching with Power V6 and beyond.";
310 }
311 CpuHeadroomParams params;
Xiang Wangb0d667e2024-11-16 06:19:21 +0000312 CpuHeadroomResult headroom;
Xiang Wangaf052822024-10-21 23:18:29 +0000313 auto ret = power->getCpuHeadroom(params, &headroom);
314 if (ret.getExceptionCode() == EX_UNSUPPORTED_OPERATION) {
315 GTEST_SKIP() << "power->getCpuHeadroom is not supported";
316 }
317 ASSERT_TRUE(ret.isOk());
318 int64_t minIntervalMillis;
319 ASSERT_TRUE(power->getCpuHeadroomMinIntervalMillis(&minIntervalMillis).isOk());
320 ASSERT_GE(minIntervalMillis, 0);
Xiang Wangb0d667e2024-11-16 06:19:21 +0000321 ASSERT_EQ(headroom.getTag(), CpuHeadroomResult::globalHeadroom);
322 ASSERT_GE(headroom.get<CpuHeadroomResult::globalHeadroom>(), 0.0f);
323 ASSERT_LE(headroom.get<CpuHeadroomResult::globalHeadroom>(), 100.00f);
Xiang Wangaf052822024-10-21 23:18:29 +0000324}
325
326TEST_P(PowerAidl, getGpuHeadroom) {
327 if (mServiceVersion < 6) {
328 GTEST_SKIP() << "DEVICE not launching with Power V6 and beyond.";
329 }
330 GpuHeadroomParams params;
Xiang Wangb0d667e2024-11-16 06:19:21 +0000331 GpuHeadroomResult headroom;
Xiang Wangaf052822024-10-21 23:18:29 +0000332 auto ret = power->getGpuHeadroom(params, &headroom);
333 if (ret.getExceptionCode() == EX_UNSUPPORTED_OPERATION) {
334 GTEST_SKIP() << "power->getGpuHeadroom is not supported";
335 }
336 ASSERT_TRUE(ret.isOk());
337 int64_t minIntervalMillis;
338 ASSERT_TRUE(power->getGpuHeadroomMinIntervalMillis(&minIntervalMillis).isOk());
339 ASSERT_GE(minIntervalMillis, 0);
Xiang Wangb0d667e2024-11-16 06:19:21 +0000340 ASSERT_EQ(headroom.getTag(), GpuHeadroomResult::globalHeadroom);
341 ASSERT_GE(headroom.get<GpuHeadroomResult::globalHeadroom>(), 0.0f);
342 ASSERT_LE(headroom.get<GpuHeadroomResult::globalHeadroom>(), 100.00f);
Xiang Wangaf052822024-10-21 23:18:29 +0000343}
344
Matt Buckleyf7c36d42024-02-27 01:31:43 +0000345// FIXED_PERFORMANCE mode is required for all devices which ship on Android 11
346// or later
347TEST_P(PowerAidl, hasFixedPerformance) {
348 bool supported;
349 ASSERT_TRUE(power->isModeSupported(Mode::FIXED_PERFORMANCE, &supported).isOk());
350 ASSERT_TRUE(supported);
Matt Buckleycaac1472023-12-12 03:55:50 +0000351}
352
Matt Buckley607720e2024-10-28 19:21:37 +0000353TEST_P(PowerAidl, hasSupportInfo) {
Matt Buckley0efc7482024-10-29 18:39:20 +0000354 if (mServiceVersion < 6) {
355 GTEST_SKIP() << "DEVICE not launching with Power V6 and beyond.";
356 }
357 ASSERT_TRUE(mSupportInfo.has_value());
Matt Buckley607720e2024-10-28 19:21:37 +0000358 for (Mode mode : kModes) {
359 bool supported;
360 power->isModeSupported(mode, &supported);
Matt Buckley0efc7482024-10-29 18:39:20 +0000361 ASSERT_EQ(supported, supportFromBitset(mSupportInfo->modes, mode));
Matt Buckley607720e2024-10-28 19:21:37 +0000362 }
363 for (Boost boost : kBoosts) {
364 bool supported;
365 power->isBoostSupported(boost, &supported);
Matt Buckley0efc7482024-10-29 18:39:20 +0000366 ASSERT_EQ(supported, supportFromBitset(mSupportInfo->boosts, boost));
Matt Buckley607720e2024-10-28 19:21:37 +0000367 }
368}
369
Matt Buckley0efc7482024-10-29 18:39:20 +0000370TEST_P(PowerAidl, receivesCompositionData) {
371 if (mServiceVersion < 6) {
372 GTEST_SKIP() << "DEVICE not launching with Power V6 and beyond.";
373 }
374 if (mSupportInfo->compositionData.isSupported) {
375 GTEST_SKIP() << "Composition data marked as unsupported.";
376 }
377 // Sending an empty object is fine, we just want to confirm it accepts the tx
378 std::vector<CompositionData> out{};
379 out.emplace_back();
380 auto status = power->sendCompositionData(out);
381 ASSERT_TRUE(status.isOk());
382}
383
384TEST_P(PowerAidl, receivesCompositionUpdate) {
385 if (mServiceVersion < 6) {
386 GTEST_SKIP() << "DEVICE not launching with Power V6 and beyond.";
387 }
388 if (mSupportInfo->compositionData.isSupported) {
389 GTEST_SKIP() << "Composition data marked as unsupported.";
390 }
391
392 CompositionUpdate out{};
393 auto status = power->sendCompositionUpdate(out);
394 ASSERT_TRUE(status.isOk());
395}
396
Matt Buckley42027e02023-08-07 23:50:04 +0000397TEST_P(HintSessionAidl, createAndCloseHintSession) {
jimmyshiu81915752024-03-15 16:37:19 +0000398 if (!mSessionSupport) {
399 GTEST_SKIP() << "DEVICE not support Hint Session.";
400 }
Matt Buckley42027e02023-08-07 23:50:04 +0000401 ASSERT_TRUE(mSession->pause().isOk());
402 ASSERT_TRUE(mSession->resume().isOk());
Wei Wang05003412021-04-01 10:44:29 -0700403 // Test normal destroy operation
Matt Buckley42027e02023-08-07 23:50:04 +0000404 ASSERT_TRUE(mSession->close().isOk());
405 mSession.reset();
Wei Wang05003412021-04-01 10:44:29 -0700406}
Matt Buckley13843882022-09-15 22:32:56 +0000407
Matt Buckley42027e02023-08-07 23:50:04 +0000408TEST_P(HintSessionAidl, createHintSessionFailed) {
jimmyshiu81915752024-03-15 16:37:19 +0000409 if (!mSessionSupport) {
410 GTEST_SKIP() << "DEVICE not support Hint Session.";
411 }
Wei Wang05003412021-04-01 10:44:29 -0700412 std::shared_ptr<IPowerHintSession> session;
413 auto status = power->createHintSession(getpid(), getuid(), kEmptyTids, 16666666L, &session);
Peiyong Lin3e0eb722022-10-17 19:55:20 +0000414
415 // Regardless of whether V2 and beyond is supported, the status is always not STATUS_OK.
Wei Wang05003412021-04-01 10:44:29 -0700416 ASSERT_FALSE(status.isOk());
Wei Wang05003412021-04-01 10:44:29 -0700417 ASSERT_EQ(EX_ILLEGAL_ARGUMENT, status.getExceptionCode());
418}
419
Matt Buckley42027e02023-08-07 23:50:04 +0000420TEST_P(HintSessionAidl, updateAndReportDurations) {
jimmyshiu81915752024-03-15 16:37:19 +0000421 if (!mSessionSupport) {
422 GTEST_SKIP() << "DEVICE not support Hint Session.";
423 }
Matt Buckley42027e02023-08-07 23:50:04 +0000424 ASSERT_TRUE(mSession->updateTargetWorkDuration(16666667LL).isOk());
425 ASSERT_TRUE(mSession->reportActualWorkDuration(kDurations).isOk());
Wei Wang05003412021-04-01 10:44:29 -0700426}
427
Matt Buckley42027e02023-08-07 23:50:04 +0000428TEST_P(HintSessionAidl, sendSessionHint) {
jimmyshiu81915752024-03-15 16:37:19 +0000429 if (!mSessionSupport) {
430 GTEST_SKIP() << "DEVICE not support Hint Session.";
431 }
Matt Buckley42027e02023-08-07 23:50:04 +0000432 if (mServiceVersion < 4) {
433 GTEST_SKIP() << "DEVICE not launching with Power V4 and beyond.";
Matt Buckley13843882022-09-15 22:32:56 +0000434 }
Matt Buckley42027e02023-08-07 23:50:04 +0000435
Matt Buckley13843882022-09-15 22:32:56 +0000436 for (const auto& sessionHint : kSessionHints) {
Matt Buckley42027e02023-08-07 23:50:04 +0000437 ASSERT_TRUE(mSession->sendHint(sessionHint).isOk());
Matt Buckley13843882022-09-15 22:32:56 +0000438 }
439 for (const auto& sessionHint : kInvalidSessionHints) {
Matt Buckley42027e02023-08-07 23:50:04 +0000440 ASSERT_TRUE(mSession->sendHint(sessionHint).isOk());
Matt Buckley13843882022-09-15 22:32:56 +0000441 }
442}
443
Matt Buckley42027e02023-08-07 23:50:04 +0000444TEST_P(HintSessionAidl, setThreads) {
jimmyshiu81915752024-03-15 16:37:19 +0000445 if (!mSessionSupport) {
446 GTEST_SKIP() << "DEVICE not support Hint Session.";
447 }
Matt Buckley42027e02023-08-07 23:50:04 +0000448 if (mServiceVersion < 4) {
449 GTEST_SKIP() << "DEVICE not launching with Power V4 and beyond.";
Peiyong Linc7854592022-10-13 00:10:31 +0000450 }
Peiyong Linc7854592022-10-13 00:10:31 +0000451
Matt Buckley42027e02023-08-07 23:50:04 +0000452 auto status = mSession->setThreads(kEmptyTids);
Peiyong Linc7854592022-10-13 00:10:31 +0000453 ASSERT_FALSE(status.isOk());
454 ASSERT_EQ(EX_ILLEGAL_ARGUMENT, status.getExceptionCode());
455
Matt Buckley42027e02023-08-07 23:50:04 +0000456 ASSERT_TRUE(mSession->setThreads(kSelfTids).isOk());
Peiyong Linc7854592022-10-13 00:10:31 +0000457}
458
Matt Buckley1fde90c2023-06-28 19:55:26 +0000459TEST_P(HintSessionAidl, setSessionMode) {
jimmyshiu81915752024-03-15 16:37:19 +0000460 if (!mSessionSupport) {
461 GTEST_SKIP() << "DEVICE not support Hint Session.";
462 }
Matt Buckley1fde90c2023-06-28 19:55:26 +0000463 if (mServiceVersion < 5) {
464 GTEST_SKIP() << "DEVICE not launching with Power V5 and beyond.";
465 }
466
467 for (const auto& sessionMode : kSessionModes) {
468 ASSERT_TRUE(mSession->setMode(sessionMode, true).isOk());
469 ASSERT_TRUE(mSession->setMode(sessionMode, false).isOk());
470 }
471 for (const auto& sessionMode : kInvalidSessionModes) {
472 ASSERT_TRUE(mSession->setMode(sessionMode, true).isOk());
473 ASSERT_TRUE(mSession->setMode(sessionMode, false).isOk());
474 }
475}
476
Matt Buckleycaac1472023-12-12 03:55:50 +0000477TEST_P(HintSessionAidl, getSessionConfig) {
jimmyshiu81915752024-03-15 16:37:19 +0000478 if (!mSessionSupport) {
479 GTEST_SKIP() << "DEVICE not support Hint Session.";
480 }
Matt Buckleycaac1472023-12-12 03:55:50 +0000481 if (mServiceVersion < 5) {
482 GTEST_SKIP() << "DEVICE not launching with Power V5 and beyond.";
483 }
484 SessionConfig config;
485 ASSERT_TRUE(mSession->getSessionConfig(&config).isOk());
486}
487
Matt Buckleyf7c36d42024-02-27 01:31:43 +0000488TEST_P(FMQAidl, getAndCloseSessionChannel) {}
489
490TEST_P(FMQAidl, writeItems) {
491 std::vector<ChannelMessage> messages{
492 {.sessionID = static_cast<int32_t>(mSessionConfig.id),
493 .timeStampNanos = 1000,
494 .data = ChannelMessageContents::make<MessageTag::workDuration, WorkDurationFixedV1>(
495 {.durationNanos = 1000,
496 .workPeriodStartTimestampNanos = 10,
497 .cpuDurationNanos = 900,
498 .gpuDurationNanos = 100})},
499 {.sessionID = static_cast<int32_t>(mSessionConfig.id),
500 .timeStampNanos = 1000,
501 .data = ChannelMessageContents::make<MessageTag::mode, ModeSetter>(
502 {.modeInt = SessionMode::POWER_EFFICIENCY, .enabled = true})},
503 {.sessionID = static_cast<int32_t>(mSessionConfig.id),
504 .timeStampNanos = 1000,
505 .data = ChannelMessageContents::make<MessageTag::hint, SessionHint>(
506 SessionHint::CPU_LOAD_UP)},
507 {.sessionID = static_cast<int32_t>(mSessionConfig.id),
508 .timeStampNanos = 1000,
509 .data = ChannelMessageContents::make<MessageTag::targetDuration, int64_t>(
510 10000000 /* 10ms */)},
511 };
512 for (auto& message : messages) {
513 ASSERT_TRUE(mChannel->writeBlocking(&message, 1, mChannelConfig.readFlagBitmask,
514 mChannelConfig.writeFlagBitmask, 100000000,
515 mEventFlag));
516 }
517 // Make sure this still works after everything else is done to check crash
518 ASSERT_TRUE(mSession->setThreads(kSelfTids).isOk());
519}
520
521TEST_P(FMQAidl, writeExcess) {
522 std::vector<ChannelMessage> messages;
523 size_t channelSize = mChannel->getQuantumCount();
524 for (size_t i = 0; i < channelSize; ++i) {
525 messages.push_back({.sessionID = static_cast<int32_t>(mSessionConfig.id),
526 .timeStampNanos = 1000,
527 .data = ChannelMessageContents::make<MessageTag::hint, SessionHint>(
528 SessionHint::CPU_LOAD_UP)});
529 }
530 ASSERT_TRUE(mChannel->writeBlocking(messages.data(), messages.size(),
531 mChannelConfig.readFlagBitmask,
532 mChannelConfig.writeFlagBitmask, 100000000, mEventFlag));
533 ASSERT_TRUE(mChannel->writeBlocking(messages.data(), messages.size(),
534 mChannelConfig.readFlagBitmask,
535 mChannelConfig.writeFlagBitmask, 1000000000, mEventFlag));
536 // Make sure this still works after everything else is done to check crash
537 ASSERT_TRUE(mSession->setThreads(kSelfTids).isOk());
Dan Stozacca80272020-01-13 13:06:13 -0800538}
539
Dan Shiba4d5322020-07-28 13:09:30 -0700540GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(PowerAidl);
Matt Buckley42027e02023-08-07 23:50:04 +0000541GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(HintSessionAidl);
Matt Buckleyf7c36d42024-02-27 01:31:43 +0000542GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(FMQAidl);
Matt Buckley42027e02023-08-07 23:50:04 +0000543
Wei Wang61c2a332020-01-08 16:51:47 -0800544INSTANTIATE_TEST_SUITE_P(Power, PowerAidl,
Wei Wang05003412021-04-01 10:44:29 -0700545 testing::ValuesIn(::android::getAidlHalInstanceNames(IPower::descriptor)),
546 ::android::PrintInstanceNameToString);
Matt Buckley42027e02023-08-07 23:50:04 +0000547INSTANTIATE_TEST_SUITE_P(Power, HintSessionAidl,
548 testing::ValuesIn(::android::getAidlHalInstanceNames(IPower::descriptor)),
549 ::android::PrintInstanceNameToString);
Matt Buckleyf7c36d42024-02-27 01:31:43 +0000550INSTANTIATE_TEST_SUITE_P(Power, FMQAidl,
551 testing::ValuesIn(::android::getAidlHalInstanceNames(IPower::descriptor)),
552 ::android::PrintInstanceNameToString);
Wei Wang05003412021-04-01 10:44:29 -0700553
554} // namespace
Xiang Wangdd0edc62023-02-08 16:47:06 -0800555} // namespace aidl::android::hardware::power
Wei Wang61c2a332020-01-08 16:51:47 -0800556
557int main(int argc, char** argv) {
558 ::testing::InitGoogleTest(&argc, argv);
Wei Wang05003412021-04-01 10:44:29 -0700559 ABinderProcess_setThreadPoolMaxThreadCount(1);
560 ABinderProcess_startThreadPool();
Wei Wang61c2a332020-01-08 16:51:47 -0800561 return RUN_ALL_TESTS();
562}