blob: 8cd83726262d9abb5a3583c7335da7abd76375b9 [file] [log] [blame]
Ana Krulecc84d09b2019-11-02 23:10:29 +01001/*
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#undef LOG_TAG
18#define LOG_TAG "LibSurfaceFlingerUnittests"
19
20#include <gmock/gmock.h>
21#include <gtest/gtest.h>
22#include <gui/LayerMetadata.h>
23
24#include "BufferQueueLayer.h"
25#include "BufferStateLayer.h"
Vishnu Nairfa247b12020-02-11 08:58:26 -080026#include "EffectLayer.h"
Ana Krulecc84d09b2019-11-02 23:10:29 +010027#include "Layer.h"
28#include "TestableSurfaceFlinger.h"
29#include "mock/DisplayHardware/MockComposer.h"
Ana Krulecc84d09b2019-11-02 23:10:29 +010030#include "mock/MockEventThread.h"
Ady Abraham8cb21882020-08-26 18:22:05 -070031#include "mock/MockVsyncController.h"
Ana Krulecc84d09b2019-11-02 23:10:29 +010032
33namespace android {
34
35using testing::_;
36using testing::DoAll;
37using testing::Mock;
38using testing::Return;
39using testing::SetArgPointee;
40
41using android::Hwc2::IComposer;
42using android::Hwc2::IComposerClient;
43
44using FakeHwcDisplayInjector = TestableSurfaceFlinger::FakeHwcDisplayInjector;
45
46/**
47 * This class covers all the test that are related to refresh rate selection.
48 */
49class RefreshRateSelectionTest : public testing::Test {
50public:
51 RefreshRateSelectionTest();
52 ~RefreshRateSelectionTest() override;
53
54protected:
55 static constexpr int DEFAULT_DISPLAY_WIDTH = 1920;
56 static constexpr int DEFAULT_DISPLAY_HEIGHT = 1024;
57 static constexpr uint32_t WIDTH = 100;
58 static constexpr uint32_t HEIGHT = 100;
59 static constexpr uint32_t LAYER_FLAGS = 0;
60 static constexpr int32_t PRIORITY_UNSET = -1;
61
62 void setupScheduler();
Ady Abraham8cb21882020-08-26 18:22:05 -070063 void setupComposer(uint32_t virtualDisplayCount);
Ana Krulecc84d09b2019-11-02 23:10:29 +010064 sp<BufferQueueLayer> createBufferQueueLayer();
65 sp<BufferStateLayer> createBufferStateLayer();
Vishnu Nairfa247b12020-02-11 08:58:26 -080066 sp<EffectLayer> createEffectLayer();
Ana Krulecc84d09b2019-11-02 23:10:29 +010067
68 void setParent(Layer* child, Layer* parent);
69 void commitTransaction(Layer* layer);
70
71 TestableSurfaceFlinger mFlinger;
72 Hwc2::mock::Composer* mComposer = nullptr;
73
74 sp<Client> mClient;
75 sp<Layer> mParent;
76 sp<Layer> mChild;
77 sp<Layer> mGrandChild;
78};
79
80RefreshRateSelectionTest::RefreshRateSelectionTest() {
81 const ::testing::TestInfo* const test_info =
82 ::testing::UnitTest::GetInstance()->current_test_info();
83 ALOGD("**** Setting up for %s.%s\n", test_info->test_case_name(), test_info->name());
84
85 setupScheduler();
86 setupComposer(0);
87}
88
89RefreshRateSelectionTest::~RefreshRateSelectionTest() {
90 const ::testing::TestInfo* const test_info =
91 ::testing::UnitTest::GetInstance()->current_test_info();
92 ALOGD("**** Tearing down after %s.%s\n", test_info->test_case_name(), test_info->name());
93}
94
95sp<BufferQueueLayer> RefreshRateSelectionTest::createBufferQueueLayer() {
96 sp<Client> client;
97 LayerCreationArgs args(mFlinger.flinger(), client, "buffer-queue-layer", WIDTH, HEIGHT,
98 LAYER_FLAGS, LayerMetadata());
99 return new BufferQueueLayer(args);
100}
101
102sp<BufferStateLayer> RefreshRateSelectionTest::createBufferStateLayer() {
103 sp<Client> client;
104 LayerCreationArgs args(mFlinger.flinger(), client, "buffer-queue-layer", WIDTH, HEIGHT,
105 LAYER_FLAGS, LayerMetadata());
106 return new BufferStateLayer(args);
107}
108
Vishnu Nairfa247b12020-02-11 08:58:26 -0800109sp<EffectLayer> RefreshRateSelectionTest::createEffectLayer() {
Ana Krulecc84d09b2019-11-02 23:10:29 +0100110 sp<Client> client;
111 LayerCreationArgs args(mFlinger.flinger(), client, "color-layer", WIDTH, HEIGHT, LAYER_FLAGS,
112 LayerMetadata());
Vishnu Nairfa247b12020-02-11 08:58:26 -0800113 return new EffectLayer(args);
Ana Krulecc84d09b2019-11-02 23:10:29 +0100114}
115
116void RefreshRateSelectionTest::setParent(Layer* child, Layer* parent) {
117 child->setParent(parent);
118}
119
120void RefreshRateSelectionTest::commitTransaction(Layer* layer) {
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700121 layer->pushPendingState();
122 auto c = layer->getCurrentState();
123 if (layer->applyPendingStates(&c)) {
124 layer->commitTransaction(c);
125 }
Ana Krulecc84d09b2019-11-02 23:10:29 +0100126}
127
128void RefreshRateSelectionTest::setupScheduler() {
129 auto eventThread = std::make_unique<mock::EventThread>();
130 auto sfEventThread = std::make_unique<mock::EventThread>();
131
132 EXPECT_CALL(*eventThread, registerDisplayEventConnection(_));
133 EXPECT_CALL(*eventThread, createEventConnection(_, _))
Ady Abraham0bb6a472020-10-12 10:22:13 -0700134 .WillOnce(Return(new EventThreadConnection(eventThread.get(), /*callingUid=*/0,
135 ResyncCallback(),
Ana Krulecc84d09b2019-11-02 23:10:29 +0100136 ISurfaceComposer::eConfigChangedSuppress)));
137
138 EXPECT_CALL(*sfEventThread, registerDisplayEventConnection(_));
139 EXPECT_CALL(*sfEventThread, createEventConnection(_, _))
Ady Abraham0bb6a472020-10-12 10:22:13 -0700140 .WillOnce(Return(new EventThreadConnection(sfEventThread.get(), /*callingUid=*/0,
141 ResyncCallback(),
Ana Krulecc84d09b2019-11-02 23:10:29 +0100142 ISurfaceComposer::eConfigChangedSuppress)));
143
Ady Abraham8cb21882020-08-26 18:22:05 -0700144 auto vsyncController = std::make_unique<mock::VsyncController>();
145 auto vsyncTracker = std::make_unique<mock::VSyncTracker>();
Ana Krulecc84d09b2019-11-02 23:10:29 +0100146
Ady Abraham8cb21882020-08-26 18:22:05 -0700147 EXPECT_CALL(*vsyncTracker, nextAnticipatedVSyncTimeFrom(_)).WillRepeatedly(Return(0));
148 EXPECT_CALL(*vsyncTracker, currentPeriod())
Ana Krulecc84d09b2019-11-02 23:10:29 +0100149 .WillRepeatedly(Return(FakeHwcDisplayInjector::DEFAULT_REFRESH_RATE));
Ady Abraham8cb21882020-08-26 18:22:05 -0700150 EXPECT_CALL(*vsyncTracker, nextAnticipatedVSyncTimeFrom(_)).WillRepeatedly(Return(0));
151 mFlinger.setupScheduler(std::move(vsyncController), std::move(vsyncTracker),
152 std::move(eventThread), std::move(sfEventThread));
Ana Krulecc84d09b2019-11-02 23:10:29 +0100153}
154
Ady Abraham8cb21882020-08-26 18:22:05 -0700155void RefreshRateSelectionTest::setupComposer(uint32_t virtualDisplayCount) {
Ana Krulecc84d09b2019-11-02 23:10:29 +0100156 mComposer = new Hwc2::mock::Composer();
Ana Krulecc84d09b2019-11-02 23:10:29 +0100157 EXPECT_CALL(*mComposer, getMaxVirtualDisplayCount()).WillOnce(Return(virtualDisplayCount));
158 mFlinger.setupComposer(std::unique_ptr<Hwc2::Composer>(mComposer));
159
160 Mock::VerifyAndClear(mComposer);
161}
162
163namespace {
164/* ------------------------------------------------------------------------
165 * Test cases
166 */
167TEST_F(RefreshRateSelectionTest, testPriorityOnBufferQueueLayers) {
168 mParent = createBufferQueueLayer();
169 mChild = createBufferQueueLayer();
170 setParent(mChild.get(), mParent.get());
171 mGrandChild = createBufferQueueLayer();
172 setParent(mGrandChild.get(), mChild.get());
173
174 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
175 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
176 ASSERT_EQ(PRIORITY_UNSET, mGrandChild->getFrameRateSelectionPriority());
177
178 // Child has its own priority.
179 mGrandChild->setFrameRateSelectionPriority(1);
180 commitTransaction(mGrandChild.get());
181 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
182 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
183 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
184
185 // Child inherits from his parent.
186 mChild->setFrameRateSelectionPriority(1);
187 commitTransaction(mChild.get());
188 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
189 commitTransaction(mGrandChild.get());
190
191 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
192 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
193 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
194
195 // Grandchild inherits from his grand parent.
196 mParent->setFrameRateSelectionPriority(1);
197 commitTransaction(mParent.get());
198 mChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
199 commitTransaction(mChild.get());
200 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
201 commitTransaction(mGrandChild.get());
202 ASSERT_EQ(1, mParent->getFrameRateSelectionPriority());
203 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
204 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
205}
206
207TEST_F(RefreshRateSelectionTest, testPriorityOnBufferStateLayers) {
208 mParent = createBufferStateLayer();
209 mChild = createBufferStateLayer();
210 setParent(mChild.get(), mParent.get());
211 mGrandChild = createBufferStateLayer();
212 setParent(mGrandChild.get(), mChild.get());
213
214 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
215 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
216 ASSERT_EQ(PRIORITY_UNSET, mGrandChild->getFrameRateSelectionPriority());
217
218 // Child has its own priority.
219 mGrandChild->setFrameRateSelectionPriority(1);
220 commitTransaction(mGrandChild.get());
221 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
222 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
223 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
224
225 // Child inherits from his parent.
226 mChild->setFrameRateSelectionPriority(1);
227 commitTransaction(mChild.get());
228 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
229 commitTransaction(mGrandChild.get());
230 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
231 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
232 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
233
234 // Grandchild inherits from his grand parent.
235 mParent->setFrameRateSelectionPriority(1);
236 commitTransaction(mParent.get());
237 mChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
238 commitTransaction(mChild.get());
239 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
240 commitTransaction(mGrandChild.get());
241 ASSERT_EQ(1, mParent->getFrameRateSelectionPriority());
242 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
243 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
244}
245
Vishnu Nairfa247b12020-02-11 08:58:26 -0800246TEST_F(RefreshRateSelectionTest, testPriorityOnEffectLayers) {
247 mParent = createEffectLayer();
248 mChild = createEffectLayer();
Ana Krulecc84d09b2019-11-02 23:10:29 +0100249 setParent(mChild.get(), mParent.get());
Vishnu Nairfa247b12020-02-11 08:58:26 -0800250 mGrandChild = createEffectLayer();
Ana Krulecc84d09b2019-11-02 23:10:29 +0100251 setParent(mGrandChild.get(), mChild.get());
252
253 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
254 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
255 ASSERT_EQ(PRIORITY_UNSET, mGrandChild->getFrameRateSelectionPriority());
256
257 // Child has its own priority.
258 mGrandChild->setFrameRateSelectionPriority(1);
259 commitTransaction(mGrandChild.get());
260 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
261 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
262 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
263
264 // Child inherits from his parent.
265 mChild->setFrameRateSelectionPriority(1);
266 commitTransaction(mChild.get());
267 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
268 commitTransaction(mGrandChild.get());
269 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
270 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
271 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
272
273 // Grandchild inherits from his grand parent.
274 mParent->setFrameRateSelectionPriority(1);
275 commitTransaction(mParent.get());
276 mChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
277 commitTransaction(mChild.get());
278 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
279 commitTransaction(mGrandChild.get());
280 ASSERT_EQ(1, mParent->getFrameRateSelectionPriority());
281 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
282 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
283}
284
285} // namespace
Ady Abraham2b55c3b2020-01-16 16:38:51 -0800286} // namespace android