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