blob: 1e24c0a7dee251b6f99dab609407419c18b70bbe [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
Lloyd Pique4603f3c2020-02-11 12:06:56 -080033#include <gui/LayerMetadata.h>
34#include <log/log.h>
35
Marin Shalamanov23c44202020-12-22 19:09:20 +010036#include "DisplayHardware/DisplayMode.h"
Lloyd Pique4603f3c2020-02-11 12:06:56 -080037#include "DisplayHardware/HWComposer.h"
Marin Shalamanov12c9e5a2021-01-07 00:25:35 +010038#include "DisplayHardware/Hal.h"
Lloyd Pique4603f3c2020-02-11 12:06:56 -080039#include "mock/DisplayHardware/MockComposer.h"
40
41// TODO(b/129481165): remove the #pragma below and fix conversion issues
42#pragma clang diagnostic pop // ignored "-Wconversion"
43
44namespace android {
45namespace {
46
Marin Shalamanov6e840172020-12-14 22:13:28 +010047namespace V2_1 = hardware::graphics::composer::V2_1;
48namespace V2_4 = hardware::graphics::composer::V2_4;
49
50using Hwc2::Config;
Peiyong Line9d809e2020-04-14 13:10:48 -070051
Lloyd Pique4603f3c2020-02-11 12:06:56 -080052using ::testing::_;
53using ::testing::DoAll;
54using ::testing::ElementsAreArray;
55using ::testing::Return;
56using ::testing::SetArgPointee;
57using ::testing::StrictMock;
58
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070059struct MockHWC2ComposerCallback final : StrictMock<HWC2::ComposerCallback> {
60 MOCK_METHOD3(onHotplugReceived, void(int32_t sequenceId, hal::HWDisplayId, hal::Connection));
61 MOCK_METHOD2(onRefreshReceived, void(int32_t sequenceId, hal::HWDisplayId));
Lloyd Pique4603f3c2020-02-11 12:06:56 -080062 MOCK_METHOD4(onVsyncReceived,
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070063 void(int32_t sequenceId, hal::HWDisplayId, int64_t timestamp,
64 std::optional<hal::VsyncPeriodNanos>));
Lloyd Pique4603f3c2020-02-11 12:06:56 -080065 MOCK_METHOD3(onVsyncPeriodTimingChangedReceived,
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070066 void(int32_t sequenceId, hal::HWDisplayId, const hal::VsyncPeriodChangeTimeline&));
67 MOCK_METHOD2(onSeamlessPossible, void(int32_t sequenceId, hal::HWDisplayId));
Lloyd Pique4603f3c2020-02-11 12:06:56 -080068};
69
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070070struct HWComposerSetConfigurationTest : testing::Test {
Lloyd Pique4603f3c2020-02-11 12:06:56 -080071 Hwc2::mock::Composer* mHal = new StrictMock<Hwc2::mock::Composer>();
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070072 MockHWC2ComposerCallback mCallback;
Lloyd Pique4603f3c2020-02-11 12:06:56 -080073};
74
75TEST_F(HWComposerSetConfigurationTest, loadsLayerMetadataSupport) {
76 const std::string kMetadata1Name = "com.example.metadata.1";
77 constexpr bool kMetadata1Mandatory = false;
78 const std::string kMetadata2Name = "com.example.metadata.2";
79 constexpr bool kMetadata2Mandatory = true;
80
81 EXPECT_CALL(*mHal, getMaxVirtualDisplayCount()).WillOnce(Return(0));
Peiyong Line9d809e2020-04-14 13:10:48 -070082 EXPECT_CALL(*mHal, getCapabilities()).WillOnce(Return(std::vector<hal::Capability>{}));
Lloyd Pique4603f3c2020-02-11 12:06:56 -080083 EXPECT_CALL(*mHal, getLayerGenericMetadataKeys(_))
Peiyong Line9d809e2020-04-14 13:10:48 -070084 .WillOnce(DoAll(SetArgPointee<0>(std::vector<hal::LayerGenericMetadataKey>{
85 {kMetadata1Name, kMetadata1Mandatory},
86 {kMetadata2Name, kMetadata2Mandatory},
87 }),
Lloyd Pique4603f3c2020-02-11 12:06:56 -080088 Return(hardware::graphics::composer::V2_4::Error::NONE)));
89 EXPECT_CALL(*mHal, registerCallback(_));
90 EXPECT_CALL(*mHal, isVsyncPeriodSwitchSupported()).WillOnce(Return(false));
91
92 impl::HWComposer hwc{std::unique_ptr<Hwc2::Composer>(mHal)};
93 hwc.setConfiguration(&mCallback, 123);
94
95 const auto& supported = hwc.getSupportedLayerGenericMetadata();
96 EXPECT_EQ(2u, supported.size());
97 EXPECT_EQ(1u, supported.count(kMetadata1Name));
98 EXPECT_EQ(kMetadata1Mandatory, supported.find(kMetadata1Name)->second);
99 EXPECT_EQ(1u, supported.count(kMetadata2Name));
100 EXPECT_EQ(kMetadata2Mandatory, supported.find(kMetadata2Name)->second);
101}
102
103TEST_F(HWComposerSetConfigurationTest, handlesUnsupportedCallToGetLayerGenericMetadataKeys) {
104 EXPECT_CALL(*mHal, getMaxVirtualDisplayCount()).WillOnce(Return(0));
Peiyong Line9d809e2020-04-14 13:10:48 -0700105 EXPECT_CALL(*mHal, getCapabilities()).WillOnce(Return(std::vector<hal::Capability>{}));
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800106 EXPECT_CALL(*mHal, getLayerGenericMetadataKeys(_))
107 .WillOnce(Return(hardware::graphics::composer::V2_4::Error::UNSUPPORTED));
108 EXPECT_CALL(*mHal, registerCallback(_));
109 EXPECT_CALL(*mHal, isVsyncPeriodSwitchSupported()).WillOnce(Return(false));
110
111 impl::HWComposer hwc{std::unique_ptr<Hwc2::Composer>(mHal)};
112 hwc.setConfiguration(&mCallback, 123);
113
114 const auto& supported = hwc.getSupportedLayerGenericMetadata();
115 EXPECT_EQ(0u, supported.size());
116}
117
118struct HWComposerLayerTest : public testing::Test {
Peiyong Line9d809e2020-04-14 13:10:48 -0700119 static constexpr hal::HWDisplayId kDisplayId = static_cast<hal::HWDisplayId>(1001);
120 static constexpr hal::HWLayerId kLayerId = static_cast<hal::HWLayerId>(1002);
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800121
Peiyong Line9d809e2020-04-14 13:10:48 -0700122 HWComposerLayerTest(const std::unordered_set<hal::Capability>& capabilities)
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800123 : mCapabilies(capabilities) {}
124
125 ~HWComposerLayerTest() override { EXPECT_CALL(*mHal, destroyLayer(kDisplayId, kLayerId)); }
126
127 std::unique_ptr<Hwc2::mock::Composer> mHal{new StrictMock<Hwc2::mock::Composer>()};
Peiyong Line9d809e2020-04-14 13:10:48 -0700128 const std::unordered_set<hal::Capability> mCapabilies;
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800129 HWC2::impl::Layer mLayer{*mHal, mCapabilies, kDisplayId, kLayerId};
130};
131
132struct HWComposerLayerGenericMetadataTest : public HWComposerLayerTest {
133 static const std::string kLayerGenericMetadata1Name;
134 static constexpr bool kLayerGenericMetadata1Mandatory = false;
135 static const std::vector<uint8_t> kLayerGenericMetadata1Value;
136 static const std::string kLayerGenericMetadata2Name;
137 static constexpr bool kLayerGenericMetadata2Mandatory = true;
138 static const std::vector<uint8_t> kLayerGenericMetadata2Value;
139
140 HWComposerLayerGenericMetadataTest() : HWComposerLayerTest({}) {}
141};
142
143const std::string HWComposerLayerGenericMetadataTest::kLayerGenericMetadata1Name =
144 "com.example.metadata.1";
145
146const std::vector<uint8_t> HWComposerLayerGenericMetadataTest::kLayerGenericMetadata1Value = {1u,
147 2u,
148 3u};
149
150const std::string HWComposerLayerGenericMetadataTest::kLayerGenericMetadata2Name =
151 "com.example.metadata.2";
152
153const std::vector<uint8_t> HWComposerLayerGenericMetadataTest::kLayerGenericMetadata2Value = {45u,
154 67u};
155
156TEST_F(HWComposerLayerGenericMetadataTest, forwardsSupportedMetadata) {
157 EXPECT_CALL(*mHal,
158 setLayerGenericMetadata(kDisplayId, kLayerId, kLayerGenericMetadata1Name,
159 kLayerGenericMetadata1Mandatory,
160 kLayerGenericMetadata1Value))
161 .WillOnce(Return(hardware::graphics::composer::V2_4::Error::NONE));
162 auto result = mLayer.setLayerGenericMetadata(kLayerGenericMetadata1Name,
163 kLayerGenericMetadata1Mandatory,
164 kLayerGenericMetadata1Value);
Peiyong Line9d809e2020-04-14 13:10:48 -0700165 EXPECT_EQ(hal::Error::NONE, result);
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800166
167 EXPECT_CALL(*mHal,
168 setLayerGenericMetadata(kDisplayId, kLayerId, kLayerGenericMetadata2Name,
169 kLayerGenericMetadata2Mandatory,
170 kLayerGenericMetadata2Value))
171 .WillOnce(Return(hardware::graphics::composer::V2_4::Error::UNSUPPORTED));
172 result = mLayer.setLayerGenericMetadata(kLayerGenericMetadata2Name,
173 kLayerGenericMetadata2Mandatory,
174 kLayerGenericMetadata2Value);
Peiyong Line9d809e2020-04-14 13:10:48 -0700175 EXPECT_EQ(hal::Error::UNSUPPORTED, result);
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800176}
177
Marin Shalamanov6e840172020-12-14 22:13:28 +0100178class HWComposerConfigsTest : public testing::Test {
179public:
180 Hwc2::mock::Composer* mHal = new StrictMock<Hwc2::mock::Composer>();
181 MockHWC2ComposerCallback mCallback;
182
183 void setActiveConfig(Config config) {
184 EXPECT_CALL(*mHal, getActiveConfig(_, _))
185 .WillRepeatedly(DoAll(SetArgPointee<1>(config), Return(V2_1::Error::NONE)));
186 }
187
188 void setDisplayConfigs(std::vector<Config> configs) {
189 EXPECT_CALL(*mHal, getDisplayConfigs(_, _))
190 .WillOnce(DoAll(SetArgPointee<1>(configs), Return(V2_1::Error::NONE)));
191 EXPECT_CALL(*mHal, getDisplayAttribute(_, _, _, _))
192 .WillRepeatedly(DoAll(SetArgPointee<3>(1), Return(V2_1::Error::NONE)));
193 }
194
Marin Shalamanov3ea1d602020-12-16 19:59:39 +0100195 void testSetActiveModeWithConstraintsCommon(bool isVsyncPeriodSwitchSupported);
Marin Shalamanov6e840172020-12-14 22:13:28 +0100196};
197
Marin Shalamanov3ea1d602020-12-16 19:59:39 +0100198void HWComposerConfigsTest::testSetActiveModeWithConstraintsCommon(
Marin Shalamanov6e840172020-12-14 22:13:28 +0100199 bool isVsyncPeriodSwitchSupported) {
200 EXPECT_CALL(*mHal, getMaxVirtualDisplayCount()).WillOnce(Return(0));
201 EXPECT_CALL(*mHal, getCapabilities()).WillOnce(Return(std::vector<hal::Capability>{}));
202 EXPECT_CALL(*mHal, getLayerGenericMetadataKeys(_)).WillOnce(Return(V2_4::Error::UNSUPPORTED));
203 EXPECT_CALL(*mHal, registerCallback(_));
204 EXPECT_CALL(*mHal, setVsyncEnabled(_, _)).WillRepeatedly(Return(V2_1::Error::NONE));
205 EXPECT_CALL(*mHal, getDisplayIdentificationData(_, _, _))
206 .WillRepeatedly(Return(V2_1::Error::UNSUPPORTED));
207 EXPECT_CALL(*mHal, setClientTargetSlotCount(_)).WillRepeatedly(Return(V2_1::Error::NONE));
208
209 EXPECT_CALL(*mHal, isVsyncPeriodSwitchSupported())
210 .WillRepeatedly(Return(isVsyncPeriodSwitchSupported));
211
212 if (isVsyncPeriodSwitchSupported) {
213 EXPECT_CALL(*mHal, setActiveConfigWithConstraints(_, _, _, _))
214 .WillRepeatedly(Return(V2_4::Error::NONE));
215 } else {
216 EXPECT_CALL(*mHal, setActiveConfig(_, _)).WillRepeatedly(Return(V2_1::Error::NONE));
217 }
218
219 impl::HWComposer hwc{std::unique_ptr<Hwc2::Composer>(mHal)};
220 hwc.setConfiguration(&mCallback, 123);
221
222 setDisplayConfigs({15});
223 setActiveConfig(15);
224
225 const auto physicalId = PhysicalDisplayId::fromPort(0);
226 const hal::HWDisplayId hwcId = 0;
227 hwc.allocatePhysicalDisplay(hwcId, physicalId);
228
229 hal::VsyncPeriodChangeConstraints constraints;
230 constraints.desiredTimeNanos = systemTime();
231 constraints.seamlessRequired = false;
232
233 hal::VsyncPeriodChangeTimeline timeline = {0, 0, 0};
Marin Shalamanov12c9e5a2021-01-07 00:25:35 +0100234 constexpr Config kConfigIndex = 0;
Marin Shalamanov6e840172020-12-14 22:13:28 +0100235 const auto status =
Marin Shalamanov3ea1d602020-12-16 19:59:39 +0100236 hwc.setActiveModeWithConstraints(physicalId, kConfigIndex, constraints, &timeline);
Marin Shalamanov6e840172020-12-14 22:13:28 +0100237 EXPECT_EQ(NO_ERROR, status);
238
239 const std::vector<Config> kConfigs{7, 8, 9, 10, 11};
240 // Change the set of supported modes.
241 setDisplayConfigs(kConfigs);
242 setActiveConfig(11);
243 hwc.onHotplug(hwcId, hal::Connection::CONNECTED);
244 hwc.allocatePhysicalDisplay(hwcId, physicalId);
245
246 for (size_t configIndex = 0; configIndex < kConfigs.size(); configIndex++) {
Marin Shalamanov12c9e5a2021-01-07 00:25:35 +0100247 const auto status =
248 hwc.setActiveModeWithConstraints(physicalId,
249 static_cast<hal::HWConfigId>(configIndex),
250 constraints, &timeline);
Marin Shalamanov6e840172020-12-14 22:13:28 +0100251 EXPECT_EQ(NO_ERROR, status) << "Error when switching to config " << configIndex;
252 }
253}
254
Marin Shalamanov3ea1d602020-12-16 19:59:39 +0100255TEST_F(HWComposerConfigsTest, setActiveModeWithConstraintsWithVsyncSwitchingSupported) {
256 testSetActiveModeWithConstraintsCommon(/*supported=*/true);
Marin Shalamanov6e840172020-12-14 22:13:28 +0100257}
258
Marin Shalamanov3ea1d602020-12-16 19:59:39 +0100259TEST_F(HWComposerConfigsTest, setActiveModeWithConstraintsWithVsyncSwitchingNotSupported) {
260 testSetActiveModeWithConstraintsCommon(/*supported=*/false);
Marin Shalamanov6e840172020-12-14 22:13:28 +0100261}
262
Lloyd Pique4603f3c2020-02-11 12:06:56 -0800263} // namespace
Marin Shalamanov6e840172020-12-14 22:13:28 +0100264} // namespace android