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