blob: e092aed471187c377f8a6998c53af821efd42c82 [file] [log] [blame]
Lloyd Piqued6b579f2018-04-06 15:29:10 -07001/*
2 * Copyright 2018 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 "CompositionTest"
19
Lloyd Pique542307f2018-10-19 13:24:08 -070020#include <compositionengine/mock/DisplaySurface.h>
Lloyd Piqued6b579f2018-04-06 15:29:10 -070021#include <gmock/gmock.h>
22#include <gtest/gtest.h>
Lloyd Piqued6b579f2018-04-06 15:29:10 -070023#include <gui/IProducerListener.h>
24#include <log/log.h>
Lloyd Pique3823e7b2018-10-18 16:58:10 -070025#include <renderengine/mock/Framebuffer.h>
26#include <renderengine/mock/Image.h>
27#include <renderengine/mock/RenderEngine.h>
Lloyd Piqued6b579f2018-04-06 15:29:10 -070028#include <system/window.h>
29#include <utils/String8.h>
30
31#include "BufferQueueLayer.h"
32#include "ColorLayer.h"
33#include "Layer.h"
34
35#include "TestableSurfaceFlinger.h"
36#include "mock/DisplayHardware/MockComposer.h"
Lloyd Piqued6b579f2018-04-06 15:29:10 -070037#include "mock/MockDispSync.h"
38#include "mock/MockEventControlThread.h"
39#include "mock/MockEventThread.h"
40#include "mock/MockMessageQueue.h"
Alec Mouriba013fa2018-10-16 12:43:11 -070041#include "mock/system/window/MockNativeWindow.h"
Lloyd Piqued6b579f2018-04-06 15:29:10 -070042
43namespace android {
44namespace {
45
46using testing::_;
David Sodman15094112018-10-11 09:39:37 -070047using testing::AtLeast;
Lloyd Piqued6b579f2018-04-06 15:29:10 -070048using testing::ByMove;
49using testing::DoAll;
Alec Mouri0a9c7b82018-11-16 13:05:25 -080050using testing::Invoke;
Lloyd Piqued6b579f2018-04-06 15:29:10 -070051using testing::IsNull;
52using testing::Mock;
53using testing::NotNull;
54using testing::Ref;
55using testing::Return;
56using testing::ReturnRef;
57using testing::SetArgPointee;
58
59using android::Hwc2::Error;
60using android::Hwc2::IComposer;
61using android::Hwc2::IComposerClient;
62using android::Hwc2::Transform;
63
64using FakeHwcDisplayInjector = TestableSurfaceFlinger::FakeHwcDisplayInjector;
65using FakeDisplayDeviceInjector = TestableSurfaceFlinger::FakeDisplayDeviceInjector;
66
67constexpr hwc2_display_t HWC_DISPLAY = FakeHwcDisplayInjector::DEFAULT_HWC_DISPLAY_ID;
68constexpr hwc2_layer_t HWC_LAYER = 5000;
69constexpr Transform DEFAULT_TRANSFORM = static_cast<Transform>(0);
70
Dominik Laskowski34157762018-10-31 13:07:19 -070071constexpr DisplayId DEFAULT_DISPLAY_ID = DisplayId{42};
Lloyd Piqued6b579f2018-04-06 15:29:10 -070072constexpr int DEFAULT_DISPLAY_WIDTH = 1920;
73constexpr int DEFAULT_DISPLAY_HEIGHT = 1024;
74
75constexpr int DEFAULT_CONFIG_ID = 0;
76constexpr int DEFAULT_TEXTURE_ID = 6000;
77constexpr int DEFAULT_LAYER_STACK = 7000;
78
79constexpr int DEFAULT_DISPLAY_MAX_LUMINANCE = 500;
80
81constexpr int DEFAULT_SIDEBAND_STREAM = 51;
82
83class CompositionTest : public testing::Test {
84public:
85 CompositionTest() {
86 const ::testing::TestInfo* const test_info =
87 ::testing::UnitTest::GetInstance()->current_test_info();
88 ALOGD("**** Setting up for %s.%s\n", test_info->test_case_name(), test_info->name());
89
90 mFlinger.mutableEventControlThread().reset(mEventControlThread);
91 mFlinger.mutableEventThread().reset(mEventThread);
92 mFlinger.mutableEventQueue().reset(mMessageQueue);
93
94 mFlinger.mutablePrimaryDispSync().reset(mPrimaryDispSync);
95 EXPECT_CALL(*mPrimaryDispSync, computeNextRefresh(0)).WillRepeatedly(Return(0));
96 EXPECT_CALL(*mPrimaryDispSync, getPeriod())
97 .WillRepeatedly(Return(FakeHwcDisplayInjector::DEFAULT_REFRESH_RATE));
Lloyd Pique86fa3db2019-02-04 18:46:01 -080098 EXPECT_CALL(*mPrimaryDispSync, expectedPresentTime()).WillRepeatedly(Return(0));
Alec Mourif6fd29e2018-11-17 04:56:41 +000099 EXPECT_CALL(*mNativeWindow, query(NATIVE_WINDOW_WIDTH, _))
100 .WillRepeatedly(DoAll(SetArgPointee<1>(DEFAULT_DISPLAY_WIDTH), Return(0)));
101 EXPECT_CALL(*mNativeWindow, query(NATIVE_WINDOW_HEIGHT, _))
102 .WillRepeatedly(DoAll(SetArgPointee<1>(DEFAULT_DISPLAY_HEIGHT), Return(0)));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700103
104 mFlinger.setupRenderEngine(std::unique_ptr<renderengine::RenderEngine>(mRenderEngine));
105 setupComposer(0);
106 }
107
108 ~CompositionTest() {
109 const ::testing::TestInfo* const test_info =
110 ::testing::UnitTest::GetInstance()->current_test_info();
111 ALOGD("**** Tearing down after %s.%s\n", test_info->test_case_name(), test_info->name());
112 }
113
114 void setupComposer(int virtualDisplayCount) {
115 mComposer = new Hwc2::mock::Composer();
116 EXPECT_CALL(*mComposer, getCapabilities())
117 .WillOnce(Return(std::vector<IComposer::Capability>()));
118 EXPECT_CALL(*mComposer, getMaxVirtualDisplayCount()).WillOnce(Return(virtualDisplayCount));
119 mFlinger.setupComposer(std::unique_ptr<Hwc2::Composer>(mComposer));
120
121 Mock::VerifyAndClear(mComposer);
122 }
123
124 void setupForceGeometryDirty() {
125 // TODO: This requires the visible region and other related
126 // state to be set, and is problematic for BufferLayers since they are
127 // not visible without a buffer (and setting up a buffer looks like a
128 // pain)
129 // mFlinger.mutableVisibleRegionsDirty() = true;
130
131 mFlinger.mutableGeometryInvalid() = true;
132 }
133
134 template <typename Case>
135 void displayRefreshCompositionDirtyGeometry();
136
137 template <typename Case>
138 void displayRefreshCompositionDirtyFrame();
139
140 template <typename Case>
141 void captureScreenComposition();
142
143 std::unordered_set<HWC2::Capability> mDefaultCapabilities = {HWC2::Capability::SidebandStream};
144
145 TestableSurfaceFlinger mFlinger;
146 sp<DisplayDevice> mDisplay;
147 sp<DisplayDevice> mExternalDisplay;
Lloyd Pique542307f2018-10-19 13:24:08 -0700148 sp<compositionengine::mock::DisplaySurface> mDisplaySurface =
149 new compositionengine::mock::DisplaySurface();
Alec Mouriba013fa2018-10-16 12:43:11 -0700150 mock::NativeWindow* mNativeWindow = new mock::NativeWindow();
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700151
Alec Mouri0a9c7b82018-11-16 13:05:25 -0800152 sp<GraphicBuffer> mBuffer = new GraphicBuffer();
153 ANativeWindowBuffer* mNativeWindowBuffer = mBuffer->getNativeBuffer();
154
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700155 mock::EventThread* mEventThread = new mock::EventThread();
156 mock::EventControlThread* mEventControlThread = new mock::EventControlThread();
157
158 Hwc2::mock::Composer* mComposer = nullptr;
159 renderengine::mock::RenderEngine* mRenderEngine = new renderengine::mock::RenderEngine();
160 mock::MessageQueue* mMessageQueue = new mock::MessageQueue();
161 mock::DispSync* mPrimaryDispSync = new mock::DispSync();
Alec Mouri79108df2019-02-04 19:33:44 +0000162 renderengine::mock::Image* mReImage = new renderengine::mock::Image();
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700163 renderengine::mock::Framebuffer* mReFrameBuffer = new renderengine::mock::Framebuffer();
164
165 sp<Fence> mClientTargetAcquireFence = Fence::NO_FENCE;
166
167 sp<GraphicBuffer> mCaptureScreenBuffer;
168};
169
170template <typename LayerCase>
171void CompositionTest::displayRefreshCompositionDirtyGeometry() {
172 setupForceGeometryDirty();
173 LayerCase::setupForDirtyGeometry(this);
174
175 // --------------------------------------------------------------------
176 // Invocation
177
178 mFlinger.onMessageReceived(MessageQueue::INVALIDATE);
179 mFlinger.onMessageReceived(MessageQueue::REFRESH);
180
181 LayerCase::cleanup(this);
182}
183
184template <typename LayerCase>
185void CompositionTest::displayRefreshCompositionDirtyFrame() {
186 LayerCase::setupForDirtyFrame(this);
187
188 // --------------------------------------------------------------------
189 // Invocation
190
191 mFlinger.onMessageReceived(MessageQueue::INVALIDATE);
192 mFlinger.onMessageReceived(MessageQueue::REFRESH);
193
194 LayerCase::cleanup(this);
195}
196
197template <typename LayerCase>
198void CompositionTest::captureScreenComposition() {
199 LayerCase::setupForScreenCapture(this);
200
201 const Rect sourceCrop(0, 0, DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700202 constexpr bool useIdentityTransform = true;
203 constexpr bool forSystem = true;
204
205 DisplayRenderArea renderArea(mDisplay, sourceCrop, DEFAULT_DISPLAY_WIDTH,
Peiyong Lin0e003c92018-09-17 11:09:51 -0700206 DEFAULT_DISPLAY_HEIGHT, ui::Dataspace::V0_SRGB,
207 ui::Transform::ROT_0);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700208
209 auto traverseLayers = [this](const LayerVector::Visitor& visitor) {
chaviw0e3479f2018-09-10 16:49:30 -0700210 return mFlinger.traverseLayersInDisplay(mDisplay, visitor);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700211 };
212
213 // TODO: Eliminate expensive/real allocation if possible.
214 const uint32_t usage = GRALLOC_USAGE_SW_READ_OFTEN | GRALLOC_USAGE_SW_WRITE_OFTEN |
215 GRALLOC_USAGE_HW_RENDER | GRALLOC_USAGE_HW_TEXTURE;
216 mCaptureScreenBuffer = new GraphicBuffer(renderArea.getReqWidth(), renderArea.getReqHeight(),
217 HAL_PIXEL_FORMAT_RGBA_8888, 1, usage, "screenshot");
218
219 int fd = -1;
220 status_t result =
221 mFlinger.captureScreenImplLocked(renderArea, traverseLayers, mCaptureScreenBuffer.get(),
222 useIdentityTransform, forSystem, &fd);
223 if (fd >= 0) {
224 close(fd);
225 }
226
227 EXPECT_EQ(NO_ERROR, result);
228
229 LayerCase::cleanup(this);
230}
231
232/* ------------------------------------------------------------------------
233 * Variants for each display configuration which can be tested
234 */
235
236template <typename Derived>
237struct BaseDisplayVariant {
238 static constexpr bool IS_SECURE = true;
239 static constexpr int INIT_POWER_MODE = HWC_POWER_MODE_NORMAL;
240
241 static void setupPreconditions(CompositionTest* test) {
Lloyd Pique86fa3db2019-02-04 18:46:01 -0800242 EXPECT_CALL(*test->mComposer, getDisplayCapabilities(HWC_DISPLAY, _))
243 .WillOnce(DoAll(SetArgPointee<1>(std::vector<Hwc2::DisplayCapability>({})),
244 Return(Error::NONE)));
Alec Mouriba013fa2018-10-16 12:43:11 -0700245
Dominik Laskowski075d3172018-05-24 15:50:06 -0700246 FakeHwcDisplayInjector(DEFAULT_DISPLAY_ID, HWC2::DisplayType::Physical,
247 true /* isPrimary */)
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700248 .setCapabilities(&test->mDefaultCapabilities)
249 .inject(&test->mFlinger, test->mComposer);
Lloyd Pique86fa3db2019-02-04 18:46:01 -0800250 Mock::VerifyAndClear(test->mComposer);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700251
Lloyd Pique86fa3db2019-02-04 18:46:01 -0800252 EXPECT_CALL(*test->mNativeWindow, query(NATIVE_WINDOW_WIDTH, _))
253 .WillRepeatedly(DoAll(SetArgPointee<1>(DEFAULT_DISPLAY_WIDTH), Return(0)));
254 EXPECT_CALL(*test->mNativeWindow, query(NATIVE_WINDOW_HEIGHT, _))
255 .WillRepeatedly(DoAll(SetArgPointee<1>(DEFAULT_DISPLAY_HEIGHT), Return(0)));
256 EXPECT_CALL(*test->mNativeWindow, perform(NATIVE_WINDOW_SET_BUFFERS_FORMAT)).Times(1);
257 EXPECT_CALL(*test->mNativeWindow, perform(NATIVE_WINDOW_API_CONNECT)).Times(1);
258 EXPECT_CALL(*test->mNativeWindow, perform(NATIVE_WINDOW_SET_USAGE64)).Times(1);
Dominik Laskowski075d3172018-05-24 15:50:06 -0700259 test->mDisplay = FakeDisplayDeviceInjector(test->mFlinger, DEFAULT_DISPLAY_ID,
260 false /* isVirtual */, true /* isPrimary */)
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700261 .setDisplaySurface(test->mDisplaySurface)
Alec Mouriba013fa2018-10-16 12:43:11 -0700262 .setNativeWindow(test->mNativeWindow)
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700263 .setSecure(Derived::IS_SECURE)
264 .setPowerMode(Derived::INIT_POWER_MODE)
265 .inject();
Lloyd Pique86fa3db2019-02-04 18:46:01 -0800266 Mock::VerifyAndClear(test->mNativeWindow);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700267 test->mDisplay->setLayerStack(DEFAULT_LAYER_STACK);
268 }
269
270 template <typename Case>
271 static void setupCommonCompositionCallExpectations(CompositionTest* test) {
272 EXPECT_CALL(*test->mComposer,
273 setColorTransform(HWC_DISPLAY, _, Hwc2::ColorTransform::IDENTITY))
274 .Times(1);
275 EXPECT_CALL(*test->mComposer, presentOrValidateDisplay(HWC_DISPLAY, _, _, _, _)).Times(1);
276 EXPECT_CALL(*test->mComposer, getDisplayRequests(HWC_DISPLAY, _, _, _)).Times(1);
277 EXPECT_CALL(*test->mComposer, acceptDisplayChanges(HWC_DISPLAY)).Times(1);
278 EXPECT_CALL(*test->mComposer, presentDisplay(HWC_DISPLAY, _)).Times(1);
279 EXPECT_CALL(*test->mComposer, getReleaseFences(HWC_DISPLAY, _, _)).Times(1);
280
281 EXPECT_CALL(*test->mRenderEngine, useNativeFenceSync()).WillRepeatedly(Return(true));
Alec Mouri79108df2019-02-04 19:33:44 +0000282 EXPECT_CALL(*test->mRenderEngine, checkErrors()).WillRepeatedly(Return());
283 EXPECT_CALL(*test->mRenderEngine, isCurrent()).WillRepeatedly(Return(true));
284
Alec Mouri0a9c7b82018-11-16 13:05:25 -0800285 EXPECT_CALL(*test->mRenderEngine, flush()).WillRepeatedly(Invoke([]() {
Alec Mouri79108df2019-02-04 19:33:44 +0000286 return base::unique_fd(0);
Alec Mouri0a9c7b82018-11-16 13:05:25 -0800287 }));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700288
289 EXPECT_CALL(*test->mDisplaySurface, onFrameCommitted()).Times(1);
290 EXPECT_CALL(*test->mDisplaySurface, advanceFrame()).Times(1);
291
292 Case::CompositionType::setupHwcSetCallExpectations(test);
293 Case::CompositionType::setupHwcGetCallExpectations(test);
294 }
295
296 template <typename Case>
297 static void setupCommonScreensCaptureCallExpectations(CompositionTest* test) {
Alec Mouri79108df2019-02-04 19:33:44 +0000298 // Called once with a non-null value to set a framebuffer, and then
299 // again with nullptr to clear it.
300 EXPECT_CALL(*test->mReFrameBuffer, setNativeWindowBuffer(NotNull(), false))
301 .WillOnce(Return(true));
302 EXPECT_CALL(*test->mReFrameBuffer, setNativeWindowBuffer(IsNull(), false))
303 .WillOnce(Return(true));
304
305 EXPECT_CALL(*test->mRenderEngine, checkErrors()).WillRepeatedly(Return());
306 EXPECT_CALL(*test->mRenderEngine, createFramebuffer())
307 .WillOnce(Return(
308 ByMove(std::unique_ptr<renderengine::Framebuffer>(test->mReFrameBuffer))));
309 EXPECT_CALL(*test->mRenderEngine, bindFrameBuffer(test->mReFrameBuffer)).Times(1);
310 EXPECT_CALL(*test->mRenderEngine, unbindFrameBuffer(test->mReFrameBuffer)).Times(1);
311 EXPECT_CALL(*test->mRenderEngine, clearWithColor(0, 0, 0, 1)).Times(1);
312 EXPECT_CALL(*test->mRenderEngine, flush()).WillOnce(Return(ByMove(base::unique_fd())));
313 EXPECT_CALL(*test->mRenderEngine, finish()).WillOnce(Return(true));
314
315 EXPECT_CALL(*test->mRenderEngine, setOutputDataSpace(_)).Times(1);
316 EXPECT_CALL(*test->mRenderEngine, setDisplayMaxLuminance(DEFAULT_DISPLAY_MAX_LUMINANCE))
317 .Times(1);
318 // This expectation retires on saturation as setViewportAndProjection is
319 // called an extra time for the code path this setup is for.
320 // TODO: Investigate this extra call
321 EXPECT_CALL(*test->mRenderEngine,
322 setViewportAndProjection(DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT,
323 Rect(DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT),
324 ui::Transform::ROT_0))
325 .Times(1)
326 .RetiresOnSaturation();
327 EXPECT_CALL(*test->mRenderEngine, disableTexturing()).Times(1);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700328 }
329
330 static void setupNonEmptyFrameCompositionCallExpectations(CompositionTest* test) {
331 EXPECT_CALL(*test->mDisplaySurface, beginFrame(true)).Times(1);
332 }
333
334 static void setupEmptyFrameCompositionCallExpectations(CompositionTest* test) {
335 EXPECT_CALL(*test->mDisplaySurface, beginFrame(false)).Times(1);
336 }
337
338 static void setupHwcCompositionCallExpectations(CompositionTest* test) {
Lloyd Pique542307f2018-10-19 13:24:08 -0700339 EXPECT_CALL(*test->mDisplaySurface,
340 prepareFrame(compositionengine::DisplaySurface::COMPOSITION_HWC))
341 .Times(1);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700342 }
343
344 static void setupRECompositionCallExpectations(CompositionTest* test) {
Lloyd Pique542307f2018-10-19 13:24:08 -0700345 EXPECT_CALL(*test->mDisplaySurface,
346 prepareFrame(compositionengine::DisplaySurface::COMPOSITION_GLES))
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700347 .Times(1);
348 EXPECT_CALL(*test->mDisplaySurface, getClientTargetAcquireFence())
349 .WillRepeatedly(ReturnRef(test->mClientTargetAcquireFence));
350
Alec Mouri79108df2019-02-04 19:33:44 +0000351 EXPECT_CALL(*test->mRenderEngine, setOutputDataSpace(ui::Dataspace::UNKNOWN)).Times(1);
352 EXPECT_CALL(*test->mRenderEngine, setDisplayMaxLuminance(DEFAULT_DISPLAY_MAX_LUMINANCE))
353 .Times(1);
354 EXPECT_CALL(*test->mRenderEngine, setColorTransform(_)).Times(2);
355 // These expectations retire on saturation as the code path these
356 // expectations are for appears to make an extra call to them.
357 // TODO: Investigate this extra call
358 EXPECT_CALL(*test->mRenderEngine,
359 setViewportAndProjection(DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT,
360 Rect(DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT),
361 ui::Transform::ROT_0))
362 .Times(1);
363 EXPECT_CALL(*test->mReFrameBuffer, setNativeWindowBuffer(NotNull(), false))
364 .WillOnce(Return(true));
365 EXPECT_CALL(*test->mReFrameBuffer, setNativeWindowBuffer(IsNull(), false))
366 .WillOnce(Return(true));
367 EXPECT_CALL(*test->mRenderEngine, createFramebuffer())
368 .WillOnce(Return(
369 ByMove(std::unique_ptr<renderengine::Framebuffer>(test->mReFrameBuffer))));
370 EXPECT_CALL(*test->mRenderEngine, bindFrameBuffer(test->mReFrameBuffer)).Times(1);
371 EXPECT_CALL(*test->mRenderEngine, unbindFrameBuffer(test->mReFrameBuffer)).Times(1);
Alec Mouri0a9c7b82018-11-16 13:05:25 -0800372 EXPECT_CALL(*test->mNativeWindow, queueBuffer(_, _)).WillOnce(Return(0));
373 EXPECT_CALL(*test->mNativeWindow, dequeueBuffer(_, _))
374 .WillOnce(DoAll(SetArgPointee<0>(test->mNativeWindowBuffer), SetArgPointee<1>(-1),
375 Return(0)));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700376 }
377
378 template <typename Case>
379 static void setupRELayerCompositionCallExpectations(CompositionTest* test) {
380 Case::Layer::setupRECompositionCallExpectations(test);
381 }
382
383 template <typename Case>
384 static void setupRELayerScreenshotCompositionCallExpectations(CompositionTest* test) {
385 Case::Layer::setupREScreenshotCompositionCallExpectations(test);
Alec Mouri79108df2019-02-04 19:33:44 +0000386
387 EXPECT_CALL(*test->mRenderEngine, isCurrent()).WillRepeatedly(Return(true));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700388 }
389};
390
391struct DefaultDisplaySetupVariant : public BaseDisplayVariant<DefaultDisplaySetupVariant> {};
392
393struct InsecureDisplaySetupVariant : public BaseDisplayVariant<InsecureDisplaySetupVariant> {
394 static constexpr bool IS_SECURE = false;
395
396 template <typename Case>
397 static void setupRELayerCompositionCallExpectations(CompositionTest* test) {
398 Case::Layer::setupInsecureRECompositionCallExpectations(test);
Alec Mouri79108df2019-02-04 19:33:44 +0000399
400 // TODO: Investigate this extra call
401 EXPECT_CALL(*test->mRenderEngine, disableScissor()).Times(1);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700402 }
403
404 template <typename Case>
405 static void setupRELayerScreenshotCompositionCallExpectations(CompositionTest* test) {
406 Case::Layer::setupInsecureREScreenshotCompositionCallExpectations(test);
Alec Mouri79108df2019-02-04 19:33:44 +0000407
408 EXPECT_CALL(*test->mRenderEngine, isCurrent()).WillRepeatedly(Return(true));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700409 }
410};
411
412struct PoweredOffDisplaySetupVariant : public BaseDisplayVariant<PoweredOffDisplaySetupVariant> {
413 static constexpr int INIT_POWER_MODE = HWC_POWER_MODE_OFF;
414
415 template <typename Case>
416 static void setupCommonCompositionCallExpectations(CompositionTest* test) {
Lloyd Pique86fa3db2019-02-04 18:46:01 -0800417 EXPECT_CALL(*test->mRenderEngine, useNativeFenceSync()).WillRepeatedly(Return(true));
418
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700419 // TODO: This seems like an unnecessary call if display is powered off.
420 EXPECT_CALL(*test->mComposer,
421 setColorTransform(HWC_DISPLAY, _, Hwc2::ColorTransform::IDENTITY))
422 .Times(1);
423
424 // TODO: This seems like an unnecessary call if display is powered off.
425 Case::CompositionType::setupHwcSetCallExpectations(test);
426 }
427
428 static void setupHwcCompositionCallExpectations(CompositionTest*) {}
429
430 static void setupRECompositionCallExpectations(CompositionTest* test) {
Lloyd Pique86fa3db2019-02-04 18:46:01 -0800431 EXPECT_CALL(*test->mRenderEngine, useNativeFenceSync()).WillRepeatedly(Return(true));
432
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700433 // TODO: This seems like an unnecessary call if display is powered off.
434 EXPECT_CALL(*test->mDisplaySurface, getClientTargetAcquireFence())
435 .WillRepeatedly(ReturnRef(test->mClientTargetAcquireFence));
436 }
437
438 template <typename Case>
439 static void setupRELayerCompositionCallExpectations(CompositionTest*) {}
440};
441
442/* ------------------------------------------------------------------------
443 * Variants for each layer configuration which can be tested
444 */
445
446template <typename LayerProperties>
447struct BaseLayerProperties {
448 static constexpr uint32_t WIDTH = 100;
449 static constexpr uint32_t HEIGHT = 100;
450 static constexpr PixelFormat FORMAT = PIXEL_FORMAT_RGBA_8888;
451 static constexpr uint64_t USAGE =
452 GraphicBuffer::USAGE_SW_READ_NEVER | GraphicBuffer::USAGE_SW_WRITE_NEVER;
453 static constexpr android_dataspace DATASPACE = HAL_DATASPACE_UNKNOWN;
454 static constexpr uint32_t SCALING_MODE = 0;
455 static constexpr uint32_t TRANSFORM = 0;
456 static constexpr uint32_t LAYER_FLAGS = 0;
457 static constexpr float COLOR[] = {1.f, 1.f, 1.f, 1.f};
458 static constexpr IComposerClient::BlendMode BLENDMODE =
459 IComposerClient::BlendMode::PREMULTIPLIED;
460
461 static void enqueueBuffer(CompositionTest*, sp<BufferQueueLayer> layer) {
462 auto producer = layer->getProducer();
463
464 IGraphicBufferProducer::QueueBufferOutput qbo;
465 status_t result = producer->connect(nullptr, NATIVE_WINDOW_API_EGL, false, &qbo);
466 if (result != NO_ERROR) {
467 ALOGE("Failed to connect() (%d)", result);
468 return;
469 }
470
471 int slot;
472 sp<Fence> fence;
473 result = producer->dequeueBuffer(&slot, &fence, LayerProperties::WIDTH,
474 LayerProperties::HEIGHT, LayerProperties::FORMAT,
475 LayerProperties::USAGE, nullptr, nullptr);
476 if (result != IGraphicBufferProducer::BUFFER_NEEDS_REALLOCATION) {
477 ALOGE("Failed to dequeueBuffer() (%d)", result);
478 return;
479 }
480
481 sp<GraphicBuffer> buffer;
482 result = producer->requestBuffer(slot, &buffer);
483 if (result != NO_ERROR) {
484 ALOGE("Failed to requestBuffer() (%d)", result);
485 return;
486 }
487
488 IGraphicBufferProducer::QueueBufferInput qbi(systemTime(), false /* isAutoTimestamp */,
489 LayerProperties::DATASPACE,
490 Rect(LayerProperties::WIDTH,
491 LayerProperties::HEIGHT),
492 LayerProperties::SCALING_MODE,
493 LayerProperties::TRANSFORM, Fence::NO_FENCE);
494 result = producer->queueBuffer(slot, qbi, &qbo);
495 if (result != NO_ERROR) {
496 ALOGE("Failed to queueBuffer (%d)", result);
497 return;
498 }
499 }
500
501 static void setupLatchedBuffer(CompositionTest* test, sp<BufferQueueLayer> layer) {
502 // TODO: Eliminate the complexity of actually creating a buffer
503 EXPECT_CALL(*test->mRenderEngine, getMaxTextureSize()).WillOnce(Return(16384));
504 EXPECT_CALL(*test->mRenderEngine, getMaxViewportDims()).WillOnce(Return(16384));
505 status_t err =
506 layer->setDefaultBufferProperties(LayerProperties::WIDTH, LayerProperties::HEIGHT,
507 LayerProperties::FORMAT);
508 ASSERT_EQ(NO_ERROR, err);
509 Mock::VerifyAndClear(test->mRenderEngine);
510
511 EXPECT_CALL(*test->mMessageQueue, invalidate()).Times(1);
512 enqueueBuffer(test, layer);
513 Mock::VerifyAndClear(test->mMessageQueue);
514
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700515 EXPECT_CALL(*test->mRenderEngine, useNativeFenceSync()).WillRepeatedly(Return(true));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700516 bool ignoredRecomputeVisibleRegions;
Alec Mouri86770e52018-09-24 22:40:58 +0000517 layer->latchBuffer(ignoredRecomputeVisibleRegions, 0, Fence::NO_FENCE);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700518 Mock::VerifyAndClear(test->mRenderEngine);
Alec Mouri79108df2019-02-04 19:33:44 +0000519 Mock::VerifyAndClear(test->mReImage);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700520 }
521
522 static void setupLayerState(CompositionTest* test, sp<BufferQueueLayer> layer) {
523 setupLatchedBuffer(test, layer);
524 }
525
526 static void setupBufferLayerPostFrameCallExpectations(CompositionTest* test) {
527 // BufferLayer::onPostComposition(), when there is no present fence
528 EXPECT_CALL(*test->mComposer, getActiveConfig(HWC_DISPLAY, _))
529 .WillOnce(DoAll(SetArgPointee<1>(DEFAULT_CONFIG_ID), Return(Error::NONE)));
530 }
531
532 static void setupHwcSetGeometryCallExpectations(CompositionTest* test) {
533 // TODO: Coverage of other values
534 EXPECT_CALL(*test->mComposer,
535 setLayerBlendMode(HWC_DISPLAY, HWC_LAYER, LayerProperties::BLENDMODE))
536 .Times(1);
537 // TODO: Coverage of other values for origin
538 EXPECT_CALL(*test->mComposer,
539 setLayerDisplayFrame(HWC_DISPLAY, HWC_LAYER,
540 IComposerClient::Rect({0, 0, LayerProperties::WIDTH,
541 LayerProperties::HEIGHT})))
542 .Times(1);
543 EXPECT_CALL(*test->mComposer,
544 setLayerPlaneAlpha(HWC_DISPLAY, HWC_LAYER, LayerProperties::COLOR[3]))
545 .Times(1);
546 // TODO: Coverage of other values
547 EXPECT_CALL(*test->mComposer, setLayerZOrder(HWC_DISPLAY, HWC_LAYER, 0u)).Times(1);
548 // TODO: Coverage of other values
549 EXPECT_CALL(*test->mComposer, setLayerInfo(HWC_DISPLAY, HWC_LAYER, 0u, 0u)).Times(1);
550
551 // These expectations retire on saturation as the code path these
552 // expectations are for appears to make an extra call to them.
553 // TODO: Investigate this extra call
554 EXPECT_CALL(*test->mComposer, setLayerTransform(HWC_DISPLAY, HWC_LAYER, DEFAULT_TRANSFORM))
David Sodman15094112018-10-11 09:39:37 -0700555 .Times(AtLeast(1))
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700556 .RetiresOnSaturation();
557 }
558
559 static void setupHwcSetSourceCropBufferCallExpectations(CompositionTest* test) {
560 EXPECT_CALL(*test->mComposer,
561 setLayerSourceCrop(HWC_DISPLAY, HWC_LAYER,
562 IComposerClient::FRect({0.f, 0.f, LayerProperties::WIDTH,
563 LayerProperties::HEIGHT})))
564 .Times(1);
565 }
566
567 static void setupHwcSetSourceCropColorCallExpectations(CompositionTest* test) {
568 EXPECT_CALL(*test->mComposer,
569 setLayerSourceCrop(HWC_DISPLAY, HWC_LAYER,
570 IComposerClient::FRect({0.f, 0.f, 0.f, 0.f})))
571 .Times(1);
572 }
573
574 static void setupHwcSetPerFrameCallExpectations(CompositionTest* test) {
575 EXPECT_CALL(*test->mComposer,
576 setLayerVisibleRegion(HWC_DISPLAY, HWC_LAYER,
577 std::vector<IComposerClient::Rect>({IComposerClient::Rect(
578 {0, 0, LayerProperties::WIDTH,
579 LayerProperties::HEIGHT})})))
580 .Times(1);
581 }
582
583 static void setupHwcSetPerFrameColorCallExpectations(CompositionTest* test) {
584 EXPECT_CALL(*test->mComposer, setLayerSurfaceDamage(HWC_DISPLAY, HWC_LAYER, _)).Times(1);
585
586 // TODO: use COLOR
587 EXPECT_CALL(*test->mComposer,
588 setLayerColor(HWC_DISPLAY, HWC_LAYER,
589 IComposerClient::Color({0xff, 0xff, 0xff, 0xff})))
590 .Times(1);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700591 }
592
593 static void setupHwcSetPerFrameBufferCallExpectations(CompositionTest* test) {
594 EXPECT_CALL(*test->mComposer, setLayerSurfaceDamage(HWC_DISPLAY, HWC_LAYER, _)).Times(1);
595 EXPECT_CALL(*test->mComposer, setLayerBuffer(HWC_DISPLAY, HWC_LAYER, _, _, _)).Times(1);
596
597 setupBufferLayerPostFrameCallExpectations(test);
598 }
599
600 static void setupREBufferCompositionCommonCallExpectations(CompositionTest* test) {
Alec Mouri79108df2019-02-04 19:33:44 +0000601 EXPECT_CALL(*test->mRenderEngine,
602 setupLayerBlending(true, false, false,
603 half4(LayerProperties::COLOR[0], LayerProperties::COLOR[1],
604 LayerProperties::COLOR[2], LayerProperties::COLOR[3]),
605 0.0f))
606 .Times(1);
607
608 EXPECT_CALL(*test->mRenderEngine, createImage())
609 .WillOnce(Return(ByMove(std::unique_ptr<renderengine::Image>(test->mReImage))));
610 EXPECT_CALL(*test->mReImage, setNativeWindowBuffer(_, _)).WillOnce(Return(true));
611 EXPECT_CALL(*test->mRenderEngine, bindExternalTextureImage(DEFAULT_TEXTURE_ID, _)).Times(1);
612 EXPECT_CALL(*test->mRenderEngine, setupLayerTexturing(_)).Times(1);
613 EXPECT_CALL(*test->mRenderEngine, setSourceDataSpace(ui::Dataspace::UNKNOWN)).Times(1);
614 EXPECT_CALL(*test->mRenderEngine, drawMesh(_)).Times(1);
615 EXPECT_CALL(*test->mRenderEngine, disableBlending()).Times(1);
616 EXPECT_CALL(*test->mRenderEngine, setSourceY410BT2020(false)).Times(1);
617 // This call retires on saturation as the code that renders a texture disables the state,
618 // along with a top-level disable to ensure it is disabled for non-buffer layers.
619 EXPECT_CALL(*test->mRenderEngine, disableTexturing()).Times(1).RetiresOnSaturation();
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700620 }
621
622 static void setupREBufferCompositionCallExpectations(CompositionTest* test) {
623 LayerProperties::setupREBufferCompositionCommonCallExpectations(test);
Alec Mouri79108df2019-02-04 19:33:44 +0000624
625 // TODO - Investigate and eliminate these differences between display
626 // composition and screenshot composition.
627 EXPECT_CALL(*test->mRenderEngine, disableScissor()).Times(1);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700628 }
629
630 static void setupInsecureREBufferCompositionCallExpectations(CompositionTest* test) {
631 setupREBufferCompositionCallExpectations(test);
632 }
633
634 static void setupREBufferScreenshotCompositionCallExpectations(CompositionTest* test) {
635 LayerProperties::setupREBufferCompositionCommonCallExpectations(test);
636 }
637
638 static void setupInsecureREBufferScreenshotCompositionCallExpectations(CompositionTest* test) {
639 LayerProperties::setupREBufferCompositionCommonCallExpectations(test);
640 }
641
Alec Mouri79108df2019-02-04 19:33:44 +0000642 static void setupREColorCompositionCommonCallExpectations(CompositionTest* test) {
643 EXPECT_CALL(*test->mRenderEngine, disableScissor()).Times(1);
644 }
645
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700646 static void setupREColorCompositionCallExpectations(CompositionTest* test) {
Alec Mouri79108df2019-02-04 19:33:44 +0000647 EXPECT_CALL(*test->mRenderEngine, setSourceDataSpace(ui::Dataspace::UNKNOWN)).Times(1);
648 EXPECT_CALL(*test->mRenderEngine,
649 setupLayerBlending(true, false, true,
650 half4(LayerProperties::COLOR[0], LayerProperties::COLOR[1],
651 LayerProperties::COLOR[2], LayerProperties::COLOR[3]),
652 0.0f))
653 .Times(1);
654 EXPECT_CALL(*test->mRenderEngine, drawMesh(_)).Times(1);
655 EXPECT_CALL(*test->mRenderEngine, disableBlending()).Times(1);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700656 }
657
658 static void setupREColorScreenshotCompositionCallExpectations(CompositionTest* test) {
659 setupREColorCompositionCallExpectations(test);
660 }
661};
662
663struct DefaultLayerProperties : public BaseLayerProperties<DefaultLayerProperties> {};
664
665struct ColorLayerProperties : public BaseLayerProperties<ColorLayerProperties> {};
666
667struct SidebandLayerProperties : public BaseLayerProperties<SidebandLayerProperties> {
668 using Base = BaseLayerProperties<SidebandLayerProperties>;
669 static constexpr IComposerClient::BlendMode BLENDMODE = IComposerClient::BlendMode::NONE;
670
671 static void setupLayerState(CompositionTest* test, sp<BufferQueueLayer> layer) {
672 sp<NativeHandle> stream =
673 NativeHandle::create(reinterpret_cast<native_handle_t*>(DEFAULT_SIDEBAND_STREAM),
674 false);
675 test->mFlinger.setLayerSidebandStream(layer, stream);
676 }
677
678 static void setupHwcSetSourceCropBufferCallExpectations(CompositionTest* test) {
679 EXPECT_CALL(*test->mComposer,
680 setLayerSourceCrop(HWC_DISPLAY, HWC_LAYER,
681 IComposerClient::FRect({0.f, 0.f, -1.f, -1.f})))
682 .Times(1);
683 }
684
685 static void setupHwcSetPerFrameBufferCallExpectations(CompositionTest* test) {
686 EXPECT_CALL(*test->mComposer,
687 setLayerSidebandStream(HWC_DISPLAY, HWC_LAYER,
688 reinterpret_cast<native_handle_t*>(
689 DEFAULT_SIDEBAND_STREAM)))
690 .WillOnce(Return(Error::NONE));
691
692 EXPECT_CALL(*test->mComposer, setLayerSurfaceDamage(HWC_DISPLAY, HWC_LAYER, _)).Times(1);
693 }
694
Alec Mouri79108df2019-02-04 19:33:44 +0000695 static void setupREBufferCompositionCommonCallExpectations(CompositionTest* test) {
696 EXPECT_CALL(*test->mRenderEngine, setupFillWithColor(0, 0, 0, 1)).Times(1);
697 EXPECT_CALL(*test->mRenderEngine, drawMesh(_)).Times(1);
698 }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700699};
700
701struct SecureLayerProperties : public BaseLayerProperties<SecureLayerProperties> {
702 using Base = BaseLayerProperties<SecureLayerProperties>;
703
704 static constexpr uint32_t LAYER_FLAGS = ISurfaceComposerClient::eSecure;
705
706 static void setupInsecureREBufferCompositionCommonCallExpectations(CompositionTest* test) {
Alec Mouri79108df2019-02-04 19:33:44 +0000707 EXPECT_CALL(*test->mRenderEngine, createImage())
708 .WillOnce(Return(ByMove(std::unique_ptr<renderengine::Image>(test->mReImage))));
709 EXPECT_CALL(*test->mReImage, setNativeWindowBuffer(_, _)).WillOnce(Return(true));
710 EXPECT_CALL(*test->mRenderEngine, bindExternalTextureImage(DEFAULT_TEXTURE_ID, _)).Times(1);
711 EXPECT_CALL(*test->mRenderEngine, setupLayerBlackedOut()).Times(1);
712
713 EXPECT_CALL(*test->mRenderEngine,
714 setupLayerBlending(true, false, false,
715 half4(Base::COLOR[0], Base::COLOR[1], Base::COLOR[2],
716 Base::COLOR[3]),
717 0.0f))
718 .Times(1);
719 EXPECT_CALL(*test->mRenderEngine, setSourceDataSpace(ui::Dataspace::UNKNOWN)).Times(1);
720 EXPECT_CALL(*test->mRenderEngine, drawMesh(_)).Times(1);
721 EXPECT_CALL(*test->mRenderEngine, disableBlending()).Times(1);
722 EXPECT_CALL(*test->mRenderEngine, setSourceY410BT2020(false)).Times(1);
723 // This call retires on saturation as the code that renders a texture disables the state,
724 // along with a top-level disable to ensure it is disabled for non-buffer layers.
725 EXPECT_CALL(*test->mRenderEngine, disableTexturing()).Times(1).RetiresOnSaturation();
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700726 }
727
728 static void setupInsecureREBufferCompositionCallExpectations(CompositionTest* test) {
729 setupInsecureREBufferCompositionCommonCallExpectations(test);
730 Base::setupBufferLayerPostFrameCallExpectations(test);
731 }
732
733 static void setupInsecureREBufferScreenshotCompositionCallExpectations(CompositionTest* test) {
734 setupInsecureREBufferCompositionCommonCallExpectations(test);
735 }
736};
737
738struct CursorLayerProperties : public BaseLayerProperties<CursorLayerProperties> {
739 using Base = BaseLayerProperties<CursorLayerProperties>;
740
741 static void setupLayerState(CompositionTest* test, sp<BufferQueueLayer> layer) {
742 Base::setupLayerState(test, layer);
743 test->mFlinger.setLayerPotentialCursor(layer, true);
744 }
745};
746
747struct NoLayerVariant {
748 using FlingerLayerType = sp<BufferQueueLayer>;
749
750 static FlingerLayerType createLayer(CompositionTest*) { return FlingerLayerType(); }
751 static void injectLayer(CompositionTest*, FlingerLayerType) {}
752 static void cleanupInjectedLayers(CompositionTest*) {}
753
754 static void setupCallExpectationsForDirtyGeometry(CompositionTest*) {}
755 static void setupCallExpectationsForDirtyFrame(CompositionTest*) {}
756};
757
758template <typename LayerProperties>
759struct BaseLayerVariant {
760 template <typename L, typename F>
761 static sp<L> createLayerWithFactory(CompositionTest* test, F factory) {
762 EXPECT_CALL(*test->mMessageQueue, postMessage(_, 0)).Times(0);
763
764 sp<L> layer = factory();
765
766 Mock::VerifyAndClear(test->mComposer);
767 Mock::VerifyAndClear(test->mRenderEngine);
768 Mock::VerifyAndClear(test->mMessageQueue);
769
770 auto& layerDrawingState = test->mFlinger.mutableLayerDrawingState(layer);
771 layerDrawingState.layerStack = DEFAULT_LAYER_STACK;
772 layerDrawingState.active.w = 100;
773 layerDrawingState.active.h = 100;
774 layerDrawingState.color = half4(LayerProperties::COLOR[0], LayerProperties::COLOR[1],
775 LayerProperties::COLOR[2], LayerProperties::COLOR[3]);
776
777 layer->setVisibleRegion(Region(Rect(0, 0, 100, 100)));
778
779 return layer;
780 }
781
782 static void injectLayer(CompositionTest* test, sp<Layer> layer) {
783 EXPECT_CALL(*test->mComposer, createLayer(HWC_DISPLAY, _))
784 .WillOnce(DoAll(SetArgPointee<1>(HWC_LAYER), Return(Error::NONE)));
785
Dominik Laskowski075d3172018-05-24 15:50:06 -0700786 const auto displayId = test->mDisplay->getId();
787 ASSERT_TRUE(displayId);
Lloyd Pique441d5042018-10-18 16:49:51 -0700788 layer->createHwcLayer(&test->mFlinger.getHwComposer(), *displayId);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700789
790 Mock::VerifyAndClear(test->mComposer);
791
792 Vector<sp<Layer>> layers;
793 layers.add(layer);
794 test->mDisplay->setVisibleLayersSortedByZ(layers);
795 test->mFlinger.mutableDrawingState().layersSortedByZ.add(layer);
796 }
797
798 static void cleanupInjectedLayers(CompositionTest* test) {
799 EXPECT_CALL(*test->mComposer, destroyLayer(HWC_DISPLAY, HWC_LAYER))
800 .WillOnce(Return(Error::NONE));
Dominik Laskowski075d3172018-05-24 15:50:06 -0700801 const auto displayId = test->mDisplay->getId();
802 ASSERT_TRUE(displayId);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700803 for (auto layer : test->mFlinger.mutableDrawingState().layersSortedByZ) {
Dominik Laskowski075d3172018-05-24 15:50:06 -0700804 layer->destroyHwcLayer(*displayId);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700805 }
806 test->mFlinger.mutableDrawingState().layersSortedByZ.clear();
807 }
808};
809
810template <typename LayerProperties>
811struct ColorLayerVariant : public BaseLayerVariant<LayerProperties> {
812 using Base = BaseLayerVariant<LayerProperties>;
813 using FlingerLayerType = sp<ColorLayer>;
814
815 static FlingerLayerType createLayer(CompositionTest* test) {
816 FlingerLayerType layer = Base::template createLayerWithFactory<ColorLayer>(test, [test]() {
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700817 return new ColorLayer(LayerCreationArgs(test->mFlinger.mFlinger.get(), sp<Client>(),
818 String8("test-layer"), LayerProperties::WIDTH,
819 LayerProperties::HEIGHT,
820 LayerProperties::LAYER_FLAGS));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700821 });
Vishnu Nair60356342018-11-13 13:00:45 -0800822
823 auto& layerDrawingState = test->mFlinger.mutableLayerDrawingState(layer);
824 layerDrawingState.crop_legacy = Rect(0, 0, LayerProperties::HEIGHT, LayerProperties::WIDTH);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700825 return layer;
826 }
827
828 static void setupRECompositionCallExpectations(CompositionTest* test) {
Alec Mouri79108df2019-02-04 19:33:44 +0000829 LayerProperties::setupREColorCompositionCommonCallExpectations(test);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700830 LayerProperties::setupREColorCompositionCallExpectations(test);
831 }
832
833 static void setupREScreenshotCompositionCallExpectations(CompositionTest* test) {
834 LayerProperties::setupREColorScreenshotCompositionCallExpectations(test);
835 }
836
837 static void setupCallExpectationsForDirtyGeometry(CompositionTest* test) {
838 LayerProperties::setupHwcSetGeometryCallExpectations(test);
839 LayerProperties::setupHwcSetSourceCropColorCallExpectations(test);
840 }
841
842 static void setupCallExpectationsForDirtyFrame(CompositionTest* test) {
843 LayerProperties::setupHwcSetPerFrameCallExpectations(test);
844 LayerProperties::setupHwcSetPerFrameColorCallExpectations(test);
845 }
846};
847
848template <typename LayerProperties>
849struct BufferLayerVariant : public BaseLayerVariant<LayerProperties> {
850 using Base = BaseLayerVariant<LayerProperties>;
851 using FlingerLayerType = sp<BufferQueueLayer>;
852
853 static FlingerLayerType createLayer(CompositionTest* test) {
854 test->mFlinger.mutableTexturePool().push_back(DEFAULT_TEXTURE_ID);
855
856 FlingerLayerType layer =
857 Base::template createLayerWithFactory<BufferQueueLayer>(test, [test]() {
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700858 return new BufferQueueLayer(
859 LayerCreationArgs(test->mFlinger.mFlinger.get(), sp<Client>(),
860 String8("test-layer"), LayerProperties::WIDTH,
861 LayerProperties::HEIGHT,
862 LayerProperties::LAYER_FLAGS));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700863 });
864
865 LayerProperties::setupLayerState(test, layer);
866
867 return layer;
868 }
869
870 static void cleanupInjectedLayers(CompositionTest* test) {
871 EXPECT_CALL(*test->mMessageQueue, postMessage(_, 0)).Times(2);
872 Base::cleanupInjectedLayers(test);
873 }
874
875 static void setupCallExpectationsForDirtyGeometry(CompositionTest* test) {
876 LayerProperties::setupHwcSetGeometryCallExpectations(test);
877 LayerProperties::setupHwcSetSourceCropBufferCallExpectations(test);
878 }
879
880 static void setupCallExpectationsForDirtyFrame(CompositionTest* test) {
881 LayerProperties::setupHwcSetPerFrameCallExpectations(test);
882 LayerProperties::setupHwcSetPerFrameBufferCallExpectations(test);
883 }
884
885 static void setupRECompositionCallExpectations(CompositionTest* test) {
886 LayerProperties::setupREBufferCompositionCallExpectations(test);
887 }
888
889 static void setupInsecureRECompositionCallExpectations(CompositionTest* test) {
890 LayerProperties::setupInsecureREBufferCompositionCallExpectations(test);
891 }
892
893 static void setupREScreenshotCompositionCallExpectations(CompositionTest* test) {
894 LayerProperties::setupREBufferScreenshotCompositionCallExpectations(test);
895 }
896
897 static void setupInsecureREScreenshotCompositionCallExpectations(CompositionTest* test) {
898 LayerProperties::setupInsecureREBufferScreenshotCompositionCallExpectations(test);
899 }
900};
901
902/* ------------------------------------------------------------------------
903 * Variants to control how the composition type is changed
904 */
905
906struct NoCompositionTypeVariant {
907 static void setupHwcSetCallExpectations(CompositionTest*) {}
908
909 static void setupHwcGetCallExpectations(CompositionTest* test) {
910 EXPECT_CALL(*test->mComposer, getChangedCompositionTypes(HWC_DISPLAY, _, _)).Times(1);
911 }
912};
913
914template <IComposerClient::Composition CompositionType>
915struct KeepCompositionTypeVariant {
916 static constexpr HWC2::Composition TYPE = static_cast<HWC2::Composition>(CompositionType);
917
918 static void setupHwcSetCallExpectations(CompositionTest* test) {
919 EXPECT_CALL(*test->mComposer,
920 setLayerCompositionType(HWC_DISPLAY, HWC_LAYER, CompositionType))
921 .Times(1);
922 }
923
924 static void setupHwcGetCallExpectations(CompositionTest* test) {
925 EXPECT_CALL(*test->mComposer, getChangedCompositionTypes(HWC_DISPLAY, _, _)).Times(1);
926 }
927};
928
929template <IComposerClient::Composition InitialCompositionType,
930 IComposerClient::Composition FinalCompositionType>
931struct ChangeCompositionTypeVariant {
932 static constexpr HWC2::Composition TYPE = static_cast<HWC2::Composition>(FinalCompositionType);
933
934 static void setupHwcSetCallExpectations(CompositionTest* test) {
935 EXPECT_CALL(*test->mComposer,
936 setLayerCompositionType(HWC_DISPLAY, HWC_LAYER, InitialCompositionType))
937 .Times(1);
938 }
939
940 static void setupHwcGetCallExpectations(CompositionTest* test) {
941 EXPECT_CALL(*test->mComposer, getChangedCompositionTypes(HWC_DISPLAY, _, _))
942 .WillOnce(DoAll(SetArgPointee<1>(std::vector<Hwc2::Layer>{
943 static_cast<Hwc2::Layer>(HWC_LAYER)}),
944 SetArgPointee<2>(std::vector<IComposerClient::Composition>{
945 FinalCompositionType}),
946 Return(Error::NONE)));
947 }
948};
949
950/* ------------------------------------------------------------------------
951 * Variants to select how the composition is expected to be handled
952 */
953
954struct CompositionResultBaseVariant {
955 static void setupLayerState(CompositionTest*, sp<Layer>) {}
956
957 template <typename Case>
958 static void setupCallExpectationsForDirtyGeometry(CompositionTest* test) {
959 Case::Layer::setupCallExpectationsForDirtyGeometry(test);
960 }
961
962 template <typename Case>
963 static void setupCallExpectationsForDirtyFrame(CompositionTest* test) {
964 Case::Layer::setupCallExpectationsForDirtyFrame(test);
965 }
966};
967
968struct NoCompositionResultVariant : public CompositionResultBaseVariant {
969 template <typename Case>
970 static void setupCallExpectations(CompositionTest* test) {
971 Case::Display::setupEmptyFrameCompositionCallExpectations(test);
972 Case::Display::setupHwcCompositionCallExpectations(test);
973 }
974};
975
976struct HwcCompositionResultVariant : public CompositionResultBaseVariant {
977 template <typename Case>
978 static void setupCallExpectations(CompositionTest* test) {
979 Case::Display::setupNonEmptyFrameCompositionCallExpectations(test);
980 Case::Display::setupHwcCompositionCallExpectations(test);
981 }
982};
983
984struct RECompositionResultVariant : public CompositionResultBaseVariant {
985 template <typename Case>
986 static void setupCallExpectations(CompositionTest* test) {
987 Case::Display::setupNonEmptyFrameCompositionCallExpectations(test);
988 Case::Display::setupRECompositionCallExpectations(test);
989 Case::Display::template setupRELayerCompositionCallExpectations<Case>(test);
990 }
991};
992
993struct ForcedClientCompositionResultVariant : public RECompositionResultVariant {
994 static void setupLayerState(CompositionTest*, sp<Layer> layer) {
Dominik Laskowski075d3172018-05-24 15:50:06 -0700995 layer->forceClientComposition(DEFAULT_DISPLAY_ID);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700996 }
997
998 template <typename Case>
999 static void setupCallExpectationsForDirtyGeometry(CompositionTest*) {}
1000
1001 template <typename Case>
1002 static void setupCallExpectationsForDirtyFrame(CompositionTest*) {}
1003};
1004
1005struct EmptyScreenshotResultVariant {
1006 static void setupLayerState(CompositionTest*, sp<Layer>) {}
1007
1008 template <typename Case>
1009 static void setupCallExpectations(CompositionTest*) {}
1010};
1011
1012struct REScreenshotResultVariant : public EmptyScreenshotResultVariant {
1013 using Base = EmptyScreenshotResultVariant;
1014
1015 template <typename Case>
1016 static void setupCallExpectations(CompositionTest* test) {
1017 Base::template setupCallExpectations<Case>(test);
1018 Case::Display::template setupRELayerScreenshotCompositionCallExpectations<Case>(test);
1019 }
1020};
1021
1022/* ------------------------------------------------------------------------
1023 * Composition test case, containing all the variants being tested
1024 */
1025
1026template <typename DisplayCase, typename LayerCase, typename CompositionTypeCase,
1027 typename CompositionResultCase>
1028struct CompositionCase {
1029 using ThisCase =
1030 CompositionCase<DisplayCase, LayerCase, CompositionTypeCase, CompositionResultCase>;
1031 using Display = DisplayCase;
1032 using Layer = LayerCase;
1033 using CompositionType = CompositionTypeCase;
1034 using CompositionResult = CompositionResultCase;
1035
1036 static void setupCommon(CompositionTest* test) {
1037 Display::setupPreconditions(test);
1038
1039 auto layer = Layer::createLayer(test);
1040 Layer::injectLayer(test, layer);
1041 CompositionResult::setupLayerState(test, layer);
1042 }
1043
1044 static void setupForDirtyGeometry(CompositionTest* test) {
1045 setupCommon(test);
1046
1047 Display::template setupCommonCompositionCallExpectations<ThisCase>(test);
1048 CompositionResult::template setupCallExpectationsForDirtyGeometry<ThisCase>(test);
1049 CompositionResult::template setupCallExpectationsForDirtyFrame<ThisCase>(test);
1050 CompositionResult::template setupCallExpectations<ThisCase>(test);
1051 }
1052
1053 static void setupForDirtyFrame(CompositionTest* test) {
1054 setupCommon(test);
1055
1056 Display::template setupCommonCompositionCallExpectations<ThisCase>(test);
1057 CompositionResult::template setupCallExpectationsForDirtyFrame<ThisCase>(test);
1058 CompositionResult::template setupCallExpectations<ThisCase>(test);
1059 }
1060
1061 static void setupForScreenCapture(CompositionTest* test) {
1062 setupCommon(test);
1063
1064 Display::template setupCommonScreensCaptureCallExpectations<ThisCase>(test);
1065 CompositionResult::template setupCallExpectations<ThisCase>(test);
1066 }
1067
1068 static void cleanup(CompositionTest* test) {
1069 Layer::cleanupInjectedLayers(test);
1070
1071 for (auto& hwcDisplay : test->mFlinger.mFakeHwcDisplays) {
1072 hwcDisplay->mutableLayers().clear();
1073 }
1074
1075 test->mDisplay->setVisibleLayersSortedByZ(Vector<sp<android::Layer>>());
1076 }
1077};
1078
1079/* ------------------------------------------------------------------------
1080 * Composition cases to test
1081 */
1082
1083TEST_F(CompositionTest, noLayersDoesMinimalWorkWithDirtyGeometry) {
1084 displayRefreshCompositionDirtyGeometry<
1085 CompositionCase<DefaultDisplaySetupVariant, NoLayerVariant, NoCompositionTypeVariant,
1086 NoCompositionResultVariant>>();
1087}
1088
1089TEST_F(CompositionTest, noLayersDoesMinimalWorkWithDirtyFrame) {
1090 displayRefreshCompositionDirtyFrame<
1091 CompositionCase<DefaultDisplaySetupVariant, NoLayerVariant, NoCompositionTypeVariant,
1092 NoCompositionResultVariant>>();
1093}
1094
1095TEST_F(CompositionTest, noLayersDoesMinimalWorkToCaptureScreen) {
1096 captureScreenComposition<
1097 CompositionCase<DefaultDisplaySetupVariant, NoLayerVariant, NoCompositionTypeVariant,
1098 EmptyScreenshotResultVariant>>();
1099}
1100
1101/* ------------------------------------------------------------------------
1102 * Simple buffer layers
1103 */
1104
1105TEST_F(CompositionTest, HWCComposedNormalBufferLayerWithDirtyGeometry) {
1106 displayRefreshCompositionDirtyGeometry<
1107 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1108 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1109 HwcCompositionResultVariant>>();
1110}
1111
1112TEST_F(CompositionTest, HWCComposedNormalBufferLayerWithDirtyFrame) {
1113 displayRefreshCompositionDirtyFrame<
1114 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1115 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1116 HwcCompositionResultVariant>>();
1117}
1118
1119TEST_F(CompositionTest, REComposedNormalBufferLayer) {
1120 displayRefreshCompositionDirtyFrame<
1121 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1122 ChangeCompositionTypeVariant<IComposerClient::Composition::DEVICE,
1123 IComposerClient::Composition::CLIENT>,
1124 RECompositionResultVariant>>();
1125}
1126
1127TEST_F(CompositionTest, captureScreenNormalBufferLayer) {
1128 captureScreenComposition<
1129 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1130 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1131}
1132
1133/* ------------------------------------------------------------------------
1134 * Single-color layers
1135 */
1136
1137TEST_F(CompositionTest, HWCComposedColorLayerWithDirtyGeometry) {
1138 displayRefreshCompositionDirtyGeometry<
1139 CompositionCase<DefaultDisplaySetupVariant, ColorLayerVariant<ColorLayerProperties>,
1140 KeepCompositionTypeVariant<IComposerClient::Composition::SOLID_COLOR>,
1141 HwcCompositionResultVariant>>();
1142}
1143
1144TEST_F(CompositionTest, HWCComposedColorLayerWithDirtyFrame) {
1145 displayRefreshCompositionDirtyFrame<
1146 CompositionCase<DefaultDisplaySetupVariant, ColorLayerVariant<ColorLayerProperties>,
1147 KeepCompositionTypeVariant<IComposerClient::Composition::SOLID_COLOR>,
1148 HwcCompositionResultVariant>>();
1149}
1150
1151TEST_F(CompositionTest, REComposedColorLayer) {
1152 displayRefreshCompositionDirtyFrame<
1153 CompositionCase<DefaultDisplaySetupVariant, ColorLayerVariant<ColorLayerProperties>,
1154 ChangeCompositionTypeVariant<IComposerClient::Composition::SOLID_COLOR,
1155 IComposerClient::Composition::CLIENT>,
1156 RECompositionResultVariant>>();
1157}
1158
1159TEST_F(CompositionTest, captureScreenColorLayer) {
1160 captureScreenComposition<
1161 CompositionCase<DefaultDisplaySetupVariant, ColorLayerVariant<ColorLayerProperties>,
1162 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1163}
1164
1165/* ------------------------------------------------------------------------
1166 * Layers with sideband buffers
1167 */
1168
1169TEST_F(CompositionTest, HWCComposedSidebandBufferLayerWithDirtyGeometry) {
1170 displayRefreshCompositionDirtyGeometry<
1171 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SidebandLayerProperties>,
1172 KeepCompositionTypeVariant<IComposerClient::Composition::SIDEBAND>,
1173 HwcCompositionResultVariant>>();
1174}
1175
1176TEST_F(CompositionTest, HWCComposedSidebandBufferLayerWithDirtyFrame) {
1177 displayRefreshCompositionDirtyFrame<
1178 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SidebandLayerProperties>,
1179 KeepCompositionTypeVariant<IComposerClient::Composition::SIDEBAND>,
1180 HwcCompositionResultVariant>>();
1181}
1182
1183TEST_F(CompositionTest, REComposedSidebandBufferLayer) {
1184 displayRefreshCompositionDirtyFrame<
1185 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SidebandLayerProperties>,
1186 ChangeCompositionTypeVariant<IComposerClient::Composition::SIDEBAND,
1187 IComposerClient::Composition::CLIENT>,
1188 RECompositionResultVariant>>();
1189}
1190
1191TEST_F(CompositionTest, captureScreenSidebandBufferLayer) {
1192 captureScreenComposition<
1193 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SidebandLayerProperties>,
1194 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1195}
1196
1197/* ------------------------------------------------------------------------
1198 * Layers with ISurfaceComposerClient::eSecure, on a secure display
1199 */
1200
1201TEST_F(CompositionTest, HWCComposedSecureBufferLayerWithDirtyGeometry) {
1202 displayRefreshCompositionDirtyGeometry<
1203 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1204 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1205 HwcCompositionResultVariant>>();
1206}
1207
1208TEST_F(CompositionTest, HWCComposedSecureBufferLayerWithDirtyFrame) {
1209 displayRefreshCompositionDirtyFrame<
1210 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1211 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1212 HwcCompositionResultVariant>>();
1213}
1214
1215TEST_F(CompositionTest, REComposedSecureBufferLayer) {
1216 displayRefreshCompositionDirtyFrame<
1217 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1218 ChangeCompositionTypeVariant<IComposerClient::Composition::DEVICE,
1219 IComposerClient::Composition::CLIENT>,
1220 RECompositionResultVariant>>();
1221}
1222
1223TEST_F(CompositionTest, captureScreenSecureBufferLayerOnSecureDisplay) {
1224 captureScreenComposition<
1225 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1226 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1227}
1228
1229/* ------------------------------------------------------------------------
1230 * Layers with ISurfaceComposerClient::eSecure, on a non-secure display
1231 */
1232
1233TEST_F(CompositionTest, HWCComposedSecureBufferLayerOnInsecureDisplayWithDirtyGeometry) {
1234 displayRefreshCompositionDirtyGeometry<
1235 CompositionCase<InsecureDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1236 KeepCompositionTypeVariant<IComposerClient::Composition::CLIENT>,
1237 ForcedClientCompositionResultVariant>>();
1238}
1239
1240TEST_F(CompositionTest, HWCComposedSecureBufferLayerOnInsecureDisplayWithDirtyFrame) {
1241 displayRefreshCompositionDirtyFrame<
1242 CompositionCase<InsecureDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1243 KeepCompositionTypeVariant<IComposerClient::Composition::CLIENT>,
1244 ForcedClientCompositionResultVariant>>();
1245}
1246
1247TEST_F(CompositionTest, captureScreenSecureBufferLayerOnInsecureDisplay) {
1248 captureScreenComposition<
1249 CompositionCase<InsecureDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1250 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1251}
1252
1253/* ------------------------------------------------------------------------
1254 * Cursor layers
1255 */
1256
1257TEST_F(CompositionTest, HWCComposedCursorLayerWithDirtyGeometry) {
1258 displayRefreshCompositionDirtyGeometry<
1259 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<CursorLayerProperties>,
1260 KeepCompositionTypeVariant<IComposerClient::Composition::CURSOR>,
1261 HwcCompositionResultVariant>>();
1262}
1263
1264TEST_F(CompositionTest, HWCComposedCursorLayerWithDirtyFrame) {
1265 displayRefreshCompositionDirtyFrame<
1266 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<CursorLayerProperties>,
1267 KeepCompositionTypeVariant<IComposerClient::Composition::CURSOR>,
1268 HwcCompositionResultVariant>>();
1269}
1270
1271TEST_F(CompositionTest, REComposedCursorLayer) {
1272 displayRefreshCompositionDirtyFrame<
1273 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<CursorLayerProperties>,
1274 ChangeCompositionTypeVariant<IComposerClient::Composition::CURSOR,
1275 IComposerClient::Composition::CLIENT>,
1276 RECompositionResultVariant>>();
1277}
1278
1279TEST_F(CompositionTest, captureScreenCursorLayer) {
1280 captureScreenComposition<
1281 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<CursorLayerProperties>,
1282 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1283}
1284
1285/* ------------------------------------------------------------------------
1286 * Simple buffer layer on a display which is powered off.
1287 */
1288
1289TEST_F(CompositionTest, displayOffHWCComposedNormalBufferLayerWithDirtyGeometry) {
1290 displayRefreshCompositionDirtyGeometry<CompositionCase<
1291 PoweredOffDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1292 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1293 HwcCompositionResultVariant>>();
1294}
1295
1296TEST_F(CompositionTest, displayOffHWCComposedNormalBufferLayerWithDirtyFrame) {
1297 displayRefreshCompositionDirtyFrame<CompositionCase<
1298 PoweredOffDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1299 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1300 HwcCompositionResultVariant>>();
1301}
1302
1303TEST_F(CompositionTest, displayOffREComposedNormalBufferLayer) {
1304 displayRefreshCompositionDirtyFrame<CompositionCase<
1305 PoweredOffDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1306 ChangeCompositionTypeVariant<IComposerClient::Composition::DEVICE,
1307 IComposerClient::Composition::CLIENT>,
1308 RECompositionResultVariant>>();
1309}
1310
1311TEST_F(CompositionTest, captureScreenNormalBufferLayerOnPoweredOffDisplay) {
1312 captureScreenComposition<CompositionCase<
1313 PoweredOffDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1314 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1315}
1316
1317} // namespace
1318} // namespace android