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