blob: 6edecff6a6c4f420fb1e51404dc6429c7026cccd [file] [log] [blame]
Lloyd Pique4603f3c2020-02-11 12:06:56 -08001/*
2 * Copyright 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
17// TODO(b/129481165): remove the #pragma below and fix conversion issues
18#pragma clang diagnostic push
19#pragma clang diagnostic ignored "-Wconversion"
20
21#undef LOG_TAG
22#define LOG_TAG "LibSurfaceFlingerUnittests"
23
24#include <vector>
25
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070026// StrictMock<T> derives from T and is not marked final, so the destructor of T is expected to be
27// virtual in case StrictMock<T> is used as a polymorphic base class. That is not the case here.
28#pragma clang diagnostic push
29#pragma clang diagnostic ignored "-Wnon-virtual-dtor"
Lloyd Pique4603f3c2020-02-11 12:06:56 -080030#include <gmock/gmock.h>
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070031#pragma clang diagnostic pop
32
Alec Mouri9b133ca2023-11-14 19:00:01 +000033#include <common/FlagManager.h>
Lloyd Pique4603f3c2020-02-11 12:06:56 -080034#include <gui/LayerMetadata.h>
35#include <log/log.h>
ramindanib90711b2023-10-02 15:13:19 -070036#include <chrono>
Lloyd Pique4603f3c2020-02-11 12:06:56 -080037
Ady Abraham3db8a3c2023-11-20 17:53:47 -080038#include <common/test/FlagUtils.h>
Marin Shalamanov23c44202020-12-22 19:09:20 +010039#include "DisplayHardware/DisplayMode.h"
Lloyd Pique4603f3c2020-02-11 12:06:56 -080040#include "DisplayHardware/HWComposer.h"
Marin Shalamanov12c9e5a2021-01-07 00:25:35 +010041#include "DisplayHardware/Hal.h"
Alec Mouriff793872022-01-13 17:45:06 -080042#include "DisplayIdentificationTestHelpers.h"
Lloyd Pique4603f3c2020-02-11 12:06:56 -080043#include "mock/DisplayHardware/MockComposer.h"
Lloyd Piquea516c002021-05-07 14:36:58 -070044#include "mock/DisplayHardware/MockHWC2.h"
Lloyd Pique4603f3c2020-02-11 12:06:56 -080045
Sally Qid57eb0d2023-11-07 16:46:15 -080046#include <com_android_graphics_surfaceflinger_flags.h>
47
Lloyd Pique4603f3c2020-02-11 12:06:56 -080048// TODO(b/129481165): remove the #pragma below and fix conversion issues
49#pragma clang diagnostic pop // ignored "-Wconversion"
50
51namespace android {
Lloyd Pique4603f3c2020-02-11 12:06:56 -080052
Marin Shalamanov6e840172020-12-14 22:13:28 +010053namespace V2_1 = hardware::graphics::composer::V2_1;
54namespace V2_4 = hardware::graphics::composer::V2_4;
Ady Abrahamde549d42022-01-26 19:19:17 -080055namespace aidl = aidl::android::hardware::graphics::composer3;
ramindanib90711b2023-10-02 15:13:19 -070056using namespace std::chrono_literals;
Marin Shalamanov6e840172020-12-14 22:13:28 +010057
58using Hwc2::Config;
Peiyong Line9d809e2020-04-14 13:10:48 -070059
Huihong Luo791bef92023-09-19 21:18:45 -070060using ::aidl::android::hardware::graphics::common::DisplayHotplugEvent;
ramindani12bfe6b2023-02-03 13:29:19 -080061using ::aidl::android::hardware::graphics::composer3::RefreshRateChangedDebugData;
ramindani0cd1d8d2023-06-13 13:43:23 -070062using hal::IComposerClient;
Lloyd Pique4603f3c2020-02-11 12:06:56 -080063using ::testing::_;
64using ::testing::DoAll;
Lloyd Pique4603f3c2020-02-11 12:06:56 -080065using ::testing::Return;
66using ::testing::SetArgPointee;
67using ::testing::StrictMock;
68
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -070069struct HWComposerTest : testing::Test {
70 using HalError = hardware::graphics::composer::V2_1::Error;
Marin Shalamanov8b196592021-08-09 16:24:42 +020071
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -070072 Hwc2::mock::Composer* const mHal = new StrictMock<Hwc2::mock::Composer>();
73 impl::HWComposer mHwc{std::unique_ptr<Hwc2::Composer>(mHal)};
Marin Shalamanov8b196592021-08-09 16:24:42 +020074
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -070075 void expectHotplugConnect(hal::HWDisplayId hwcDisplayId) {
76 constexpr uint8_t kPort = 255;
77 EXPECT_CALL(*mHal, getDisplayIdentificationData(hwcDisplayId, _, _))
78 .WillOnce(DoAll(SetArgPointee<1>(kPort),
79 SetArgPointee<2>(getExternalEdid()), Return(HalError::NONE)));
Marin Shalamanov8b196592021-08-09 16:24:42 +020080
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -070081 EXPECT_CALL(*mHal, setClientTargetSlotCount(_));
82 EXPECT_CALL(*mHal, setVsyncEnabled(hwcDisplayId, Hwc2::IComposerClient::Vsync::DISABLE));
Leon Scroggins IIIe24d78f2022-09-20 16:38:19 -040083 EXPECT_CALL(*mHal, onHotplugConnect(hwcDisplayId));
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -070084 }
85};
Marin Shalamanov8b196592021-08-09 16:24:42 +020086
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -070087TEST_F(HWComposerTest, isHeadless) {
88 ASSERT_TRUE(mHwc.isHeadless());
89
90 constexpr hal::HWDisplayId kHwcDisplayId = 1;
91 expectHotplugConnect(kHwcDisplayId);
92
93 const auto info = mHwc.onHotplug(kHwcDisplayId, hal::Connection::CONNECTED);
Marin Shalamanov8b196592021-08-09 16:24:42 +020094 ASSERT_TRUE(info);
Marin Shalamanov8b196592021-08-09 16:24:42 +020095
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -070096 ASSERT_FALSE(mHwc.isHeadless());
97
98 mHwc.disconnectDisplay(info->id);
99 ASSERT_TRUE(mHwc.isHeadless());
100}
101
102TEST_F(HWComposerTest, getActiveMode) {
103 // Unknown display.
104 EXPECT_EQ(mHwc.getActiveMode(PhysicalDisplayId::fromPort(0)), std::nullopt);
105
106 constexpr hal::HWDisplayId kHwcDisplayId = 2;
107 expectHotplugConnect(kHwcDisplayId);
108
109 const auto info = mHwc.onHotplug(kHwcDisplayId, hal::Connection::CONNECTED);
110 ASSERT_TRUE(info);
111
112 {
113 // Display is known to SF but not HWC, e.g. the hotplug disconnect is pending.
114 EXPECT_CALL(*mHal, getActiveConfig(kHwcDisplayId, _))
115 .WillOnce(Return(HalError::BAD_DISPLAY));
116
117 EXPECT_EQ(mHwc.getActiveMode(info->id), std::nullopt);
118 }
119 {
120 constexpr hal::HWConfigId kConfigId = 42;
121 EXPECT_CALL(*mHal, getActiveConfig(kHwcDisplayId, _))
122 .WillOnce(DoAll(SetArgPointee<1>(kConfigId), Return(HalError::NONE)));
123
124 EXPECT_EQ(mHwc.getActiveMode(info->id), kConfigId);
125 }
Marin Shalamanov8b196592021-08-09 16:24:42 +0200126}
127
ramindani0cd1d8d2023-06-13 13:43:23 -0700128TEST_F(HWComposerTest, getModesWithLegacyDisplayConfigs) {
129 constexpr hal::HWDisplayId kHwcDisplayId = 2;
130 constexpr hal::HWConfigId kConfigId = 42;
ramindani263a3f12023-07-18 20:44:49 -0700131 constexpr int32_t kMaxFrameIntervalNs = 50000000; // 20Fps
ramindani0cd1d8d2023-06-13 13:43:23 -0700132
133 expectHotplugConnect(kHwcDisplayId);
134 const auto info = mHwc.onHotplug(kHwcDisplayId, hal::Connection::CONNECTED);
135 ASSERT_TRUE(info);
136
ramindani19919ff2023-12-07 11:27:06 -0800137 EXPECT_CALL(*mHal, isVrrSupported()).WillRepeatedly(Return(false));
ramindani0cd1d8d2023-06-13 13:43:23 -0700138
139 {
140 EXPECT_CALL(*mHal, getDisplayConfigs(kHwcDisplayId, _))
141 .WillOnce(Return(HalError::BAD_DISPLAY));
ramindani263a3f12023-07-18 20:44:49 -0700142 EXPECT_TRUE(mHwc.getModes(info->id, kMaxFrameIntervalNs).empty());
ramindani0cd1d8d2023-06-13 13:43:23 -0700143 }
144 {
145 constexpr int32_t kWidth = 480;
146 constexpr int32_t kHeight = 720;
147 constexpr int32_t kConfigGroup = 1;
148 constexpr int32_t kVsyncPeriod = 16666667;
149
150 EXPECT_CALL(*mHal,
151 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::WIDTH,
152 _))
153 .WillRepeatedly(DoAll(SetArgPointee<3>(kWidth), Return(HalError::NONE)));
154 EXPECT_CALL(*mHal,
155 getDisplayAttribute(kHwcDisplayId, kConfigId,
156 IComposerClient::Attribute::HEIGHT, _))
157 .WillRepeatedly(DoAll(SetArgPointee<3>(kHeight), Return(HalError::NONE)));
158 EXPECT_CALL(*mHal,
159 getDisplayAttribute(kHwcDisplayId, kConfigId,
160 IComposerClient::Attribute::CONFIG_GROUP, _))
161 .WillRepeatedly(DoAll(SetArgPointee<3>(kConfigGroup), Return(HalError::NONE)));
162 EXPECT_CALL(*mHal,
163 getDisplayAttribute(kHwcDisplayId, kConfigId,
164 IComposerClient::Attribute::VSYNC_PERIOD, _))
165 .WillRepeatedly(DoAll(SetArgPointee<3>(kVsyncPeriod), Return(HalError::NONE)));
166
167 // Optional Parameters UNSUPPORTED
168 EXPECT_CALL(*mHal,
169 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::DPI_X,
170 _))
171 .WillOnce(Return(HalError::UNSUPPORTED));
172 EXPECT_CALL(*mHal,
173 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::DPI_Y,
174 _))
175 .WillOnce(Return(HalError::UNSUPPORTED));
176
177 EXPECT_CALL(*mHal, getDisplayConfigs(kHwcDisplayId, _))
178 .WillRepeatedly(DoAll(SetArgPointee<1>(std::vector<hal::HWConfigId>{kConfigId}),
179 Return(HalError::NONE)));
180
ramindani263a3f12023-07-18 20:44:49 -0700181 auto modes = mHwc.getModes(info->id, kMaxFrameIntervalNs);
ramindani0cd1d8d2023-06-13 13:43:23 -0700182 EXPECT_EQ(modes.size(), size_t{1});
183 EXPECT_EQ(modes.front().hwcId, kConfigId);
184 EXPECT_EQ(modes.front().width, kWidth);
185 EXPECT_EQ(modes.front().height, kHeight);
186 EXPECT_EQ(modes.front().configGroup, kConfigGroup);
187 EXPECT_EQ(modes.front().vsyncPeriod, kVsyncPeriod);
188 EXPECT_EQ(modes.front().dpiX, -1);
189 EXPECT_EQ(modes.front().dpiY, -1);
190
191 // Optional parameters are supported
192 constexpr int32_t kDpi = 320;
193 EXPECT_CALL(*mHal,
194 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::DPI_X,
195 _))
196 .WillOnce(DoAll(SetArgPointee<3>(kDpi), Return(HalError::NONE)));
197 EXPECT_CALL(*mHal,
198 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::DPI_Y,
199 _))
200 .WillOnce(DoAll(SetArgPointee<3>(kDpi), Return(HalError::NONE)));
201
ramindani263a3f12023-07-18 20:44:49 -0700202 modes = mHwc.getModes(info->id, kMaxFrameIntervalNs);
ramindani0cd1d8d2023-06-13 13:43:23 -0700203 EXPECT_EQ(modes.size(), size_t{1});
204 EXPECT_EQ(modes.front().hwcId, kConfigId);
205 EXPECT_EQ(modes.front().width, kWidth);
206 EXPECT_EQ(modes.front().height, kHeight);
207 EXPECT_EQ(modes.front().configGroup, kConfigGroup);
208 EXPECT_EQ(modes.front().vsyncPeriod, kVsyncPeriod);
209 // DPI values are scaled by 1000 in the legacy implementation.
210 EXPECT_EQ(modes.front().dpiX, kDpi / 1000.f);
211 EXPECT_EQ(modes.front().dpiY, kDpi / 1000.f);
212 }
213}
214
Sally Qid57eb0d2023-11-07 16:46:15 -0800215TEST_F(HWComposerTest, getModesWithDisplayConfigurations_VRR_OFF) {
216 // if vrr_config is off, getDisplayConfigurationsSupported() is off as well
217 // then getModesWithLegacyDisplayConfigs should be called instead
218 SET_FLAG_FOR_TEST(com::android::graphics::surfaceflinger::flags::vrr_config, false);
219 ASSERT_FALSE(FlagManager::getInstance().vrr_config());
220
221 constexpr hal::HWDisplayId kHwcDisplayId = 2;
222 constexpr hal::HWConfigId kConfigId = 42;
223 constexpr int32_t kMaxFrameIntervalNs = 50000000; // 20Fps
224
225 expectHotplugConnect(kHwcDisplayId);
226 const auto info = mHwc.onHotplug(kHwcDisplayId, hal::Connection::CONNECTED);
227 ASSERT_TRUE(info);
228
ramindani19919ff2023-12-07 11:27:06 -0800229 EXPECT_CALL(*mHal, isVrrSupported()).WillRepeatedly(Return(false));
Sally Qid57eb0d2023-11-07 16:46:15 -0800230
231 {
232 EXPECT_CALL(*mHal, getDisplayConfigs(kHwcDisplayId, _))
233 .WillOnce(Return(HalError::BAD_DISPLAY));
234 EXPECT_TRUE(mHwc.getModes(info->id, kMaxFrameIntervalNs).empty());
235 }
236 {
237 constexpr int32_t kWidth = 480;
238 constexpr int32_t kHeight = 720;
239 constexpr int32_t kConfigGroup = 1;
240 constexpr int32_t kVsyncPeriod = 16666667;
241
242 EXPECT_CALL(*mHal,
243 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::WIDTH,
244 _))
245 .WillRepeatedly(DoAll(SetArgPointee<3>(kWidth), Return(HalError::NONE)));
246 EXPECT_CALL(*mHal,
247 getDisplayAttribute(kHwcDisplayId, kConfigId,
248 IComposerClient::Attribute::HEIGHT, _))
249 .WillRepeatedly(DoAll(SetArgPointee<3>(kHeight), Return(HalError::NONE)));
250 EXPECT_CALL(*mHal,
251 getDisplayAttribute(kHwcDisplayId, kConfigId,
252 IComposerClient::Attribute::CONFIG_GROUP, _))
253 .WillRepeatedly(DoAll(SetArgPointee<3>(kConfigGroup), Return(HalError::NONE)));
254 EXPECT_CALL(*mHal,
255 getDisplayAttribute(kHwcDisplayId, kConfigId,
256 IComposerClient::Attribute::VSYNC_PERIOD, _))
257 .WillRepeatedly(DoAll(SetArgPointee<3>(kVsyncPeriod), Return(HalError::NONE)));
258
259 // Optional Parameters UNSUPPORTED
260 EXPECT_CALL(*mHal,
261 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::DPI_X,
262 _))
263 .WillOnce(Return(HalError::UNSUPPORTED));
264 EXPECT_CALL(*mHal,
265 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::DPI_Y,
266 _))
267 .WillOnce(Return(HalError::UNSUPPORTED));
268
269 EXPECT_CALL(*mHal, getDisplayConfigs(kHwcDisplayId, _))
270 .WillRepeatedly(DoAll(SetArgPointee<1>(std::vector<hal::HWConfigId>{kConfigId}),
271 Return(HalError::NONE)));
272
273 auto modes = mHwc.getModes(info->id, kMaxFrameIntervalNs);
274 EXPECT_EQ(modes.size(), size_t{1});
275 EXPECT_EQ(modes.front().hwcId, kConfigId);
276 EXPECT_EQ(modes.front().width, kWidth);
277 EXPECT_EQ(modes.front().height, kHeight);
278 EXPECT_EQ(modes.front().configGroup, kConfigGroup);
279 EXPECT_EQ(modes.front().vsyncPeriod, kVsyncPeriod);
280 EXPECT_EQ(modes.front().dpiX, -1);
281 EXPECT_EQ(modes.front().dpiY, -1);
282
283 // Optional parameters are supported
284 constexpr int32_t kDpi = 320;
285 EXPECT_CALL(*mHal,
286 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::DPI_X,
287 _))
288 .WillOnce(DoAll(SetArgPointee<3>(kDpi), Return(HalError::NONE)));
289 EXPECT_CALL(*mHal,
290 getDisplayAttribute(kHwcDisplayId, kConfigId, IComposerClient::Attribute::DPI_Y,
291 _))
292 .WillOnce(DoAll(SetArgPointee<3>(kDpi), Return(HalError::NONE)));
293
294 modes = mHwc.getModes(info->id, kMaxFrameIntervalNs);
295 EXPECT_EQ(modes.size(), size_t{1});
296 EXPECT_EQ(modes.front().hwcId, kConfigId);
297 EXPECT_EQ(modes.front().width, kWidth);
298 EXPECT_EQ(modes.front().height, kHeight);
299 EXPECT_EQ(modes.front().configGroup, kConfigGroup);
300 EXPECT_EQ(modes.front().vsyncPeriod, kVsyncPeriod);
301 // DPI values are scaled by 1000 in the legacy implementation.
302 EXPECT_EQ(modes.front().dpiX, kDpi / 1000.f);
303 EXPECT_EQ(modes.front().dpiY, kDpi / 1000.f);
304 }
305}
306
307TEST_F(HWComposerTest, getModesWithDisplayConfigurations_VRR_ON) {
308 SET_FLAG_FOR_TEST(com::android::graphics::surfaceflinger::flags::vrr_config, true);
309 ASSERT_TRUE(FlagManager::getInstance().vrr_config());
310
ramindani0cd1d8d2023-06-13 13:43:23 -0700311 constexpr hal::HWDisplayId kHwcDisplayId = 2;
312 constexpr hal::HWConfigId kConfigId = 42;
ramindani263a3f12023-07-18 20:44:49 -0700313 constexpr int32_t kMaxFrameIntervalNs = 50000000; // 20Fps
ramindani0cd1d8d2023-06-13 13:43:23 -0700314 expectHotplugConnect(kHwcDisplayId);
315 const auto info = mHwc.onHotplug(kHwcDisplayId, hal::Connection::CONNECTED);
316 ASSERT_TRUE(info);
317
ramindani19919ff2023-12-07 11:27:06 -0800318 EXPECT_CALL(*mHal, isVrrSupported()).WillRepeatedly(Return(true));
ramindani0cd1d8d2023-06-13 13:43:23 -0700319
320 {
ramindani263a3f12023-07-18 20:44:49 -0700321 EXPECT_CALL(*mHal, getDisplayConfigurations(kHwcDisplayId, _, _))
ramindani0cd1d8d2023-06-13 13:43:23 -0700322 .WillOnce(Return(HalError::BAD_DISPLAY));
ramindani263a3f12023-07-18 20:44:49 -0700323 EXPECT_TRUE(mHwc.getModes(info->id, kMaxFrameIntervalNs).empty());
ramindani0cd1d8d2023-06-13 13:43:23 -0700324 }
325 {
326 constexpr int32_t kWidth = 480;
327 constexpr int32_t kHeight = 720;
328 constexpr int32_t kConfigGroup = 1;
329 constexpr int32_t kVsyncPeriod = 16666667;
ramindanib90711b2023-10-02 15:13:19 -0700330 const hal::VrrConfig vrrConfig =
331 hal::VrrConfig{.minFrameIntervalNs = static_cast<Fps>(120_Hz).getPeriodNsecs(),
332 .notifyExpectedPresentConfig = hal::VrrConfig::
333 NotifyExpectedPresentConfig{.notifyExpectedPresentHeadsUpNs =
334 ms2ns(30),
335 .notifyExpectedPresentTimeoutNs =
336 ms2ns(30)}};
337 hal::DisplayConfiguration displayConfiguration{.configId = kConfigId,
338 .width = kWidth,
339 .height = kHeight,
340 .configGroup = kConfigGroup,
341 .vsyncPeriod = kVsyncPeriod,
342 .vrrConfig = vrrConfig};
ramindani0cd1d8d2023-06-13 13:43:23 -0700343
ramindani263a3f12023-07-18 20:44:49 -0700344 EXPECT_CALL(*mHal, getDisplayConfigurations(kHwcDisplayId, _, _))
345 .WillOnce(DoAll(SetArgPointee<2>(std::vector<hal::DisplayConfiguration>{
ramindani0cd1d8d2023-06-13 13:43:23 -0700346 displayConfiguration}),
347 Return(HalError::NONE)));
348
349 // Optional dpi not supported
ramindani263a3f12023-07-18 20:44:49 -0700350 auto modes = mHwc.getModes(info->id, kMaxFrameIntervalNs);
ramindani0cd1d8d2023-06-13 13:43:23 -0700351 EXPECT_EQ(modes.size(), size_t{1});
352 EXPECT_EQ(modes.front().hwcId, kConfigId);
353 EXPECT_EQ(modes.front().width, kWidth);
354 EXPECT_EQ(modes.front().height, kHeight);
355 EXPECT_EQ(modes.front().configGroup, kConfigGroup);
356 EXPECT_EQ(modes.front().vsyncPeriod, kVsyncPeriod);
ramindanib90711b2023-10-02 15:13:19 -0700357 EXPECT_EQ(modes.front().vrrConfig, vrrConfig);
ramindani0cd1d8d2023-06-13 13:43:23 -0700358 EXPECT_EQ(modes.front().dpiX, -1);
359 EXPECT_EQ(modes.front().dpiY, -1);
360
361 // Supports optional dpi parameter
362 constexpr int32_t kDpi = 320;
363 displayConfiguration.dpi = {kDpi, kDpi};
364
ramindani263a3f12023-07-18 20:44:49 -0700365 EXPECT_CALL(*mHal, getDisplayConfigurations(kHwcDisplayId, _, _))
366 .WillOnce(DoAll(SetArgPointee<2>(std::vector<hal::DisplayConfiguration>{
ramindani0cd1d8d2023-06-13 13:43:23 -0700367 displayConfiguration}),
368 Return(HalError::NONE)));
369
ramindani263a3f12023-07-18 20:44:49 -0700370 modes = mHwc.getModes(info->id, kMaxFrameIntervalNs);
ramindani0cd1d8d2023-06-13 13:43:23 -0700371 EXPECT_EQ(modes.size(), size_t{1});
372 EXPECT_EQ(modes.front().hwcId, kConfigId);
373 EXPECT_EQ(modes.front().width, kWidth);
374 EXPECT_EQ(modes.front().height, kHeight);
375 EXPECT_EQ(modes.front().configGroup, kConfigGroup);
376 EXPECT_EQ(modes.front().vsyncPeriod, kVsyncPeriod);
ramindanib90711b2023-10-02 15:13:19 -0700377 EXPECT_EQ(modes.front().vrrConfig, vrrConfig);
ramindani0cd1d8d2023-06-13 13:43:23 -0700378 EXPECT_EQ(modes.front().dpiX, kDpi);
379 EXPECT_EQ(modes.front().dpiY, kDpi);
380 }
381}
382
Leon Scroggins III959a7ff2023-02-07 11:24:25 -0500383TEST_F(HWComposerTest, onVsync) {
384 constexpr hal::HWDisplayId kHwcDisplayId = 1;
385 expectHotplugConnect(kHwcDisplayId);
386
387 const auto info = mHwc.onHotplug(kHwcDisplayId, hal::Connection::CONNECTED);
388 ASSERT_TRUE(info);
389
390 const auto physicalDisplayId = info->id;
391
392 // Deliberately chosen not to match DisplayData.lastPresentTimestamp's
393 // initial value.
394 constexpr nsecs_t kTimestamp = 1;
395 auto displayIdOpt = mHwc.onVsync(kHwcDisplayId, kTimestamp);
396 ASSERT_TRUE(displayIdOpt);
397 EXPECT_EQ(physicalDisplayId, displayIdOpt);
398
399 // Attempt to send the same time stamp again.
400 displayIdOpt = mHwc.onVsync(kHwcDisplayId, kTimestamp);
401 EXPECT_FALSE(displayIdOpt);
402}
403
404TEST_F(HWComposerTest, onVsyncInvalid) {
405 constexpr hal::HWDisplayId kInvalidHwcDisplayId = 2;
406 constexpr nsecs_t kTimestamp = 1;
407 const auto displayIdOpt = mHwc.onVsync(kInvalidHwcDisplayId, kTimestamp);
408 EXPECT_FALSE(displayIdOpt);
409}
410
Dominik Laskowski8b01cc02020-07-14 19:02:41 -0700411struct MockHWC2ComposerCallback final : StrictMock<HWC2::ComposerCallback> {
Huihong Luo791bef92023-09-19 21:18:45 -0700412 MOCK_METHOD(void, onComposerHalHotplugEvent, (hal::HWDisplayId, DisplayHotplugEvent),
413 (override));
Dominik Laskowski0deb06e2021-04-16 23:18:31 -0700414 MOCK_METHOD1(onComposerHalRefresh, void(hal::HWDisplayId));
415 MOCK_METHOD3(onComposerHalVsync,
416 void(hal::HWDisplayId, int64_t timestamp, std::optional<hal::VsyncPeriodNanos>));
417 MOCK_METHOD2(onComposerHalVsyncPeriodTimingChanged,
418 void(hal::HWDisplayId, const hal::VsyncPeriodChangeTimeline&));
419 MOCK_METHOD1(onComposerHalSeamlessPossible, void(hal::HWDisplayId));
Yichi Chen1a417af2022-01-21 15:29:52 +0800420 MOCK_METHOD1(onComposerHalVsyncIdle, void(hal::HWDisplayId));
ramindani12bfe6b2023-02-03 13:29:19 -0800421 MOCK_METHOD(void, onRefreshRateChangedDebug, (const RefreshRateChangedDebugData&), (override));
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800422};
423
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -0700424struct HWComposerSetCallbackTest : HWComposerTest {
Dominik Laskowski8b01cc02020-07-14 19:02:41 -0700425 MockHWC2ComposerCallback mCallback;
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800426};
427
Dominik Laskowski0deb06e2021-04-16 23:18:31 -0700428TEST_F(HWComposerSetCallbackTest, loadsLayerMetadataSupport) {
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800429 const std::string kMetadata1Name = "com.example.metadata.1";
430 constexpr bool kMetadata1Mandatory = false;
431 const std::string kMetadata2Name = "com.example.metadata.2";
432 constexpr bool kMetadata2Mandatory = true;
433
Ady Abrahamde549d42022-01-26 19:19:17 -0800434 EXPECT_CALL(*mHal, getCapabilities()).WillOnce(Return(std::vector<aidl::Capability>{}));
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800435 EXPECT_CALL(*mHal, getLayerGenericMetadataKeys(_))
Peiyong Line9d809e2020-04-14 13:10:48 -0700436 .WillOnce(DoAll(SetArgPointee<0>(std::vector<hal::LayerGenericMetadataKey>{
437 {kMetadata1Name, kMetadata1Mandatory},
438 {kMetadata2Name, kMetadata2Mandatory},
439 }),
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800440 Return(hardware::graphics::composer::V2_4::Error::NONE)));
Sally Qibb866c12022-10-17 11:31:20 -0700441 EXPECT_CALL(*mHal, getOverlaySupport(_)).WillOnce(Return(HalError::NONE));
Kriti Dang674b9372022-11-18 10:58:44 +0100442 EXPECT_CALL(*mHal, getHdrConversionCapabilities(_)).WillOnce(Return(HalError::NONE));
Sally Qibb866c12022-10-17 11:31:20 -0700443
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800444 EXPECT_CALL(*mHal, registerCallback(_));
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800445
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -0700446 mHwc.setCallback(mCallback);
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800447
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -0700448 const auto& supported = mHwc.getSupportedLayerGenericMetadata();
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800449 EXPECT_EQ(2u, supported.size());
450 EXPECT_EQ(1u, supported.count(kMetadata1Name));
451 EXPECT_EQ(kMetadata1Mandatory, supported.find(kMetadata1Name)->second);
452 EXPECT_EQ(1u, supported.count(kMetadata2Name));
453 EXPECT_EQ(kMetadata2Mandatory, supported.find(kMetadata2Name)->second);
454}
455
Dominik Laskowski0deb06e2021-04-16 23:18:31 -0700456TEST_F(HWComposerSetCallbackTest, handlesUnsupportedCallToGetLayerGenericMetadataKeys) {
Ady Abrahamde549d42022-01-26 19:19:17 -0800457 EXPECT_CALL(*mHal, getCapabilities()).WillOnce(Return(std::vector<aidl::Capability>{}));
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800458 EXPECT_CALL(*mHal, getLayerGenericMetadataKeys(_))
459 .WillOnce(Return(hardware::graphics::composer::V2_4::Error::UNSUPPORTED));
Sally Qibb866c12022-10-17 11:31:20 -0700460 EXPECT_CALL(*mHal, getOverlaySupport(_)).WillOnce(Return(HalError::UNSUPPORTED));
Kriti Dang674b9372022-11-18 10:58:44 +0100461 EXPECT_CALL(*mHal, getHdrConversionCapabilities(_)).WillOnce(Return(HalError::UNSUPPORTED));
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800462 EXPECT_CALL(*mHal, registerCallback(_));
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800463
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -0700464 mHwc.setCallback(mCallback);
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800465
Dominik Laskowskie2c5b0a2022-08-10 14:53:53 -0700466 const auto& supported = mHwc.getSupportedLayerGenericMetadata();
467 EXPECT_TRUE(supported.empty());
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800468}
469
470struct HWComposerLayerTest : public testing::Test {
Peiyong Line9d809e2020-04-14 13:10:48 -0700471 static constexpr hal::HWDisplayId kDisplayId = static_cast<hal::HWDisplayId>(1001);
472 static constexpr hal::HWLayerId kLayerId = static_cast<hal::HWLayerId>(1002);
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800473
Ady Abrahamde549d42022-01-26 19:19:17 -0800474 HWComposerLayerTest(const std::unordered_set<aidl::Capability>& capabilities)
Lloyd Piquea516c002021-05-07 14:36:58 -0700475 : mCapabilies(capabilities) {
476 EXPECT_CALL(mDisplay, getId()).WillRepeatedly(Return(kDisplayId));
477 }
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800478
Lloyd Piquea516c002021-05-07 14:36:58 -0700479 ~HWComposerLayerTest() override {
480 EXPECT_CALL(mDisplay, onLayerDestroyed(kLayerId));
481 EXPECT_CALL(*mHal, destroyLayer(kDisplayId, kLayerId));
482 }
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800483
484 std::unique_ptr<Hwc2::mock::Composer> mHal{new StrictMock<Hwc2::mock::Composer>()};
Ady Abrahamde549d42022-01-26 19:19:17 -0800485 const std::unordered_set<aidl::Capability> mCapabilies;
Lloyd Piquea516c002021-05-07 14:36:58 -0700486 StrictMock<HWC2::mock::Display> mDisplay;
487 HWC2::impl::Layer mLayer{*mHal, mCapabilies, mDisplay, kLayerId};
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800488};
489
490struct HWComposerLayerGenericMetadataTest : public HWComposerLayerTest {
491 static const std::string kLayerGenericMetadata1Name;
492 static constexpr bool kLayerGenericMetadata1Mandatory = false;
493 static const std::vector<uint8_t> kLayerGenericMetadata1Value;
494 static const std::string kLayerGenericMetadata2Name;
495 static constexpr bool kLayerGenericMetadata2Mandatory = true;
496 static const std::vector<uint8_t> kLayerGenericMetadata2Value;
497
498 HWComposerLayerGenericMetadataTest() : HWComposerLayerTest({}) {}
499};
500
501const std::string HWComposerLayerGenericMetadataTest::kLayerGenericMetadata1Name =
502 "com.example.metadata.1";
503
504const std::vector<uint8_t> HWComposerLayerGenericMetadataTest::kLayerGenericMetadata1Value = {1u,
505 2u,
506 3u};
507
508const std::string HWComposerLayerGenericMetadataTest::kLayerGenericMetadata2Name =
509 "com.example.metadata.2";
510
511const std::vector<uint8_t> HWComposerLayerGenericMetadataTest::kLayerGenericMetadata2Value = {45u,
512 67u};
513
514TEST_F(HWComposerLayerGenericMetadataTest, forwardsSupportedMetadata) {
515 EXPECT_CALL(*mHal,
516 setLayerGenericMetadata(kDisplayId, kLayerId, kLayerGenericMetadata1Name,
517 kLayerGenericMetadata1Mandatory,
518 kLayerGenericMetadata1Value))
519 .WillOnce(Return(hardware::graphics::composer::V2_4::Error::NONE));
520 auto result = mLayer.setLayerGenericMetadata(kLayerGenericMetadata1Name,
521 kLayerGenericMetadata1Mandatory,
522 kLayerGenericMetadata1Value);
Peiyong Line9d809e2020-04-14 13:10:48 -0700523 EXPECT_EQ(hal::Error::NONE, result);
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800524
525 EXPECT_CALL(*mHal,
526 setLayerGenericMetadata(kDisplayId, kLayerId, kLayerGenericMetadata2Name,
527 kLayerGenericMetadata2Mandatory,
528 kLayerGenericMetadata2Value))
529 .WillOnce(Return(hardware::graphics::composer::V2_4::Error::UNSUPPORTED));
530 result = mLayer.setLayerGenericMetadata(kLayerGenericMetadata2Name,
531 kLayerGenericMetadata2Mandatory,
532 kLayerGenericMetadata2Value);
Peiyong Line9d809e2020-04-14 13:10:48 -0700533 EXPECT_EQ(hal::Error::UNSUPPORTED, result);
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800534}
535
Dominik Laskowski3dce4f42021-03-08 20:48:28 -0800536} // namespace android