blob: bfdd20b784c47ef08ca0ac9e5d98079b81d7e6e6 [file] [log] [blame]
Lloyd Piquef58625d2017-12-19 13:22:33 -08001/*
2 * Copyright (C) 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#pragma once
18
Lloyd Pique37c2c9b2018-12-04 17:25:10 -080019#include <compositionengine/Display.h>
20#include <compositionengine/OutputLayer.h>
Lloyd Pique70d91362018-10-18 16:02:55 -070021#include <compositionengine/impl/CompositionEngine.h>
Lloyd Pique37c2c9b2018-12-04 17:25:10 -080022#include <compositionengine/impl/OutputLayerCompositionState.h>
Lloyd Pique70d91362018-10-18 16:02:55 -070023
Lloyd Pique90c115d2018-09-18 21:39:42 -070024#include "BufferQueueLayer.h"
25#include "BufferStateLayer.h"
26#include "ColorLayer.h"
27#include "ContainerLayer.h"
Lloyd Piquef58625d2017-12-19 13:22:33 -080028#include "DisplayDevice.h"
Ana Krulec757f63a2019-01-25 10:46:18 -080029#include "FakePhaseOffsets.h"
Lloyd Piqued6b579f2018-04-06 15:29:10 -070030#include "Layer.h"
Lloyd Pique90c115d2018-09-18 21:39:42 -070031#include "NativeWindowSurface.h"
32#include "StartPropertySetThread.h"
Lloyd Piquef58625d2017-12-19 13:22:33 -080033#include "SurfaceFlinger.h"
Lloyd Pique90c115d2018-09-18 21:39:42 -070034#include "SurfaceFlingerFactory.h"
35#include "SurfaceInterceptor.h"
Lloyd Piquef58625d2017-12-19 13:22:33 -080036
Yiwei Zhang7e666a52018-11-15 13:33:42 -080037#include "TimeStats/TimeStats.h"
38
Lloyd Piquef58625d2017-12-19 13:22:33 -080039namespace android {
40
Lloyd Piquee39cad22017-12-20 17:01:29 -080041class EventThread;
42
Peiyong Lin833074a2018-08-28 11:53:54 -070043namespace renderengine {
Lloyd Pique90c115d2018-09-18 21:39:42 -070044
Lloyd Piquee39cad22017-12-20 17:01:29 -080045class RenderEngine;
Lloyd Pique90c115d2018-09-18 21:39:42 -070046
47} // namespace renderengine
Lloyd Piquee39cad22017-12-20 17:01:29 -080048
49namespace Hwc2 {
Lloyd Pique90c115d2018-09-18 21:39:42 -070050
Lloyd Piquee39cad22017-12-20 17:01:29 -080051class Composer;
Lloyd Pique90c115d2018-09-18 21:39:42 -070052
53} // namespace Hwc2
54
55namespace surfaceflinger::test {
56
57class Factory final : public surfaceflinger::Factory {
58public:
59 ~Factory() = default;
60
61 std::unique_ptr<DispSync> createDispSync(const char*, bool, int64_t) override {
62 // TODO: Use test-fixture controlled factory
63 return nullptr;
64 }
65
66 std::unique_ptr<EventControlThread> createEventControlThread(
67 std::function<void(bool)>) override {
68 // TODO: Use test-fixture controlled factory
69 return nullptr;
70 }
71
72 std::unique_ptr<HWComposer> createHWComposer(const std::string&) override {
73 // TODO: Use test-fixture controlled factory
74 return nullptr;
75 }
76
77 std::unique_ptr<MessageQueue> createMessageQueue() override {
78 // TODO: Use test-fixture controlled factory
79 return std::make_unique<android::impl::MessageQueue>();
80 }
81
Ana Krulec757f63a2019-01-25 10:46:18 -080082 std::unique_ptr<scheduler::PhaseOffsets> createPhaseOffsets() override {
83 return std::make_unique<scheduler::FakePhaseOffsets>();
84 }
85
Lloyd Pique90c115d2018-09-18 21:39:42 -070086 std::unique_ptr<Scheduler> createScheduler(std::function<void(bool)>) override {
87 // TODO: Use test-fixture controlled factory
88 return nullptr;
89 }
90
91 std::unique_ptr<SurfaceInterceptor> createSurfaceInterceptor(SurfaceFlinger* flinger) override {
92 // TODO: Use test-fixture controlled factory
93 return std::make_unique<android::impl::SurfaceInterceptor>(flinger);
94 }
95
96 sp<StartPropertySetThread> createStartPropertySetThread(bool timestampPropertyValue) override {
97 // TODO: Use test-fixture controlled factory
98 return new StartPropertySetThread(timestampPropertyValue);
99 }
100
101 sp<DisplayDevice> createDisplayDevice(DisplayDeviceCreationArgs&& creationArgs) override {
102 // TODO: Use test-fixture controlled factory
103 return new DisplayDevice(std::move(creationArgs));
104 }
105
106 sp<GraphicBuffer> createGraphicBuffer(uint32_t width, uint32_t height, PixelFormat format,
107 uint32_t layerCount, uint64_t usage,
108 std::string requestorName) override {
109 // TODO: Use test-fixture controlled factory
110 return new GraphicBuffer(width, height, format, layerCount, usage, requestorName);
111 }
112
113 void createBufferQueue(sp<IGraphicBufferProducer>* outProducer,
114 sp<IGraphicBufferConsumer>* outConsumer,
115 bool consumerIsSurfaceFlinger) override {
116 if (!mCreateBufferQueue) return;
117 mCreateBufferQueue(outProducer, outConsumer, consumerIsSurfaceFlinger);
118 }
119
120 std::unique_ptr<surfaceflinger::NativeWindowSurface> createNativeWindowSurface(
121 const sp<IGraphicBufferProducer>& producer) override {
122 if (!mCreateNativeWindowSurface) return nullptr;
123 return mCreateNativeWindowSurface(producer);
124 }
125
Lloyd Pique70d91362018-10-18 16:02:55 -0700126 std::unique_ptr<compositionengine::CompositionEngine> createCompositionEngine() override {
127 return compositionengine::impl::createCompositionEngine();
128 }
129
Lloyd Pique90c115d2018-09-18 21:39:42 -0700130 sp<BufferQueueLayer> createBufferQueueLayer(const LayerCreationArgs&) override {
131 // TODO: Use test-fixture controlled factory
132 return nullptr;
133 }
134
135 sp<BufferStateLayer> createBufferStateLayer(const LayerCreationArgs&) override {
136 // TODO: Use test-fixture controlled factory
137 return nullptr;
138 }
139
140 sp<ColorLayer> createColorLayer(const LayerCreationArgs&) override {
141 // TODO: Use test-fixture controlled factory
142 return nullptr;
143 }
144
145 sp<ContainerLayer> createContainerLayer(const LayerCreationArgs&) override {
146 // TODO: Use test-fixture controlled factory
147 return nullptr;
148 }
149
Alec Mourifb571ea2019-01-24 18:42:10 -0800150 std::shared_ptr<TimeStats> createTimeStats() override {
Yiwei Zhang7e666a52018-11-15 13:33:42 -0800151 // TODO: Use test-fixture controlled factory
Alec Mourifb571ea2019-01-24 18:42:10 -0800152 return std::make_shared<android::impl::TimeStats>();
Yiwei Zhang7e666a52018-11-15 13:33:42 -0800153 }
154
Lloyd Pique90c115d2018-09-18 21:39:42 -0700155 using CreateBufferQueueFunction =
156 std::function<void(sp<IGraphicBufferProducer>* /* outProducer */,
157 sp<IGraphicBufferConsumer>* /* outConsumer */,
158 bool /* consumerIsSurfaceFlinger */)>;
159 CreateBufferQueueFunction mCreateBufferQueue;
160
161 using CreateNativeWindowSurfaceFunction =
162 std::function<std::unique_ptr<surfaceflinger::NativeWindowSurface>(
163 const sp<IGraphicBufferProducer>&)>;
164 CreateNativeWindowSurfaceFunction mCreateNativeWindowSurface;
Lloyd Pique70d91362018-10-18 16:02:55 -0700165
166 using CreateCompositionEngineFunction =
167 std::function<std::unique_ptr<compositionengine::CompositionEngine>()>;
168 CreateCompositionEngineFunction mCreateCompositionEngine;
Lloyd Pique90c115d2018-09-18 21:39:42 -0700169};
170
171} // namespace surfaceflinger::test
Lloyd Piquee39cad22017-12-20 17:01:29 -0800172
Lloyd Piquef58625d2017-12-19 13:22:33 -0800173class TestableSurfaceFlinger {
174public:
175 // Extend this as needed for accessing SurfaceFlinger private (and public)
176 // functions.
177
Peiyong Lin833074a2018-08-28 11:53:54 -0700178 void setupRenderEngine(std::unique_ptr<renderengine::RenderEngine> renderEngine) {
Lloyd Piqueb97e04f2018-10-18 17:07:05 -0700179 mFlinger->mCompositionEngine->setRenderEngine(std::move(renderEngine));
Lloyd Piquee39cad22017-12-20 17:01:29 -0800180 }
181
182 void setupComposer(std::unique_ptr<Hwc2::Composer> composer) {
Lloyd Pique441d5042018-10-18 16:49:51 -0700183 mFlinger->mCompositionEngine->setHwComposer(
184 std::make_unique<impl::HWComposer>(std::move(composer)));
Lloyd Piquee39cad22017-12-20 17:01:29 -0800185 }
186
Lloyd Pique90c115d2018-09-18 21:39:42 -0700187 using CreateBufferQueueFunction = surfaceflinger::test::Factory::CreateBufferQueueFunction;
Lloyd Pique5b36f3f2018-01-17 11:57:07 -0800188 void setCreateBufferQueueFunction(CreateBufferQueueFunction f) {
Lloyd Pique90c115d2018-09-18 21:39:42 -0700189 mFactory.mCreateBufferQueue = f;
Lloyd Pique5b36f3f2018-01-17 11:57:07 -0800190 }
191
Lloyd Pique90c115d2018-09-18 21:39:42 -0700192 using CreateNativeWindowSurfaceFunction =
193 surfaceflinger::test::Factory::CreateNativeWindowSurfaceFunction;
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800194 void setCreateNativeWindowSurface(CreateNativeWindowSurfaceFunction f) {
Lloyd Pique90c115d2018-09-18 21:39:42 -0700195 mFactory.mCreateNativeWindowSurface = f;
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800196 }
197
Daniel Solomon42d04562019-01-20 21:03:19 -0800198 void setInternalDisplayPrimaries(const ui::DisplayPrimaries& primaries) {
199 memcpy(&mFlinger->mInternalDisplayPrimaries, &primaries, sizeof(ui::DisplayPrimaries));
200 }
201
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800202 using HotplugEvent = SurfaceFlinger::HotplugEvent;
203
Lloyd Pique0449b0f2018-12-20 16:23:45 -0800204 auto& mutableLayerCurrentState(sp<Layer> layer) { return layer->mCurrentState; }
205 auto& mutableLayerDrawingState(sp<Layer> layer) { return layer->mDrawingState; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700206
207 void setLayerSidebandStream(sp<Layer> layer, sp<NativeHandle> sidebandStream) {
Lloyd Pique0449b0f2018-12-20 16:23:45 -0800208 layer->mDrawingState.sidebandStream = sidebandStream;
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700209 layer->getBE().compositionInfo.hwc.sidebandStream = sidebandStream;
210 }
211
Lloyd Pique37c2c9b2018-12-04 17:25:10 -0800212 void setLayerCompositionType(sp<Layer> layer, HWC2::Composition type) {
213 auto outputLayer = layer->findOutputLayerForDisplay(mFlinger->getDefaultDisplayDevice());
214 LOG_ALWAYS_FATAL_IF(!outputLayer);
215 auto& state = outputLayer->editState();
216 LOG_ALWAYS_FATAL_IF(!outputLayer->getState().hwc);
217 (*state.hwc).hwcCompositionType = static_cast<Hwc2::IComposerClient::Composition>(type);
218 };
219
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700220 void setLayerPotentialCursor(sp<Layer> layer, bool potentialCursor) {
221 layer->mPotentialCursor = potentialCursor;
222 }
223
Lloyd Piquef58625d2017-12-19 13:22:33 -0800224 /* ------------------------------------------------------------------------
225 * Forwarding for functions being tested
226 */
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800227
Lloyd Piquea482f992018-01-22 19:00:34 -0800228 auto createDisplay(const String8& displayName, bool secure) {
229 return mFlinger->createDisplay(displayName, secure);
230 }
231
Dominik Laskowskieecd6592018-05-29 10:25:41 -0700232 auto destroyDisplay(const sp<IBinder>& displayToken) {
233 return mFlinger->destroyDisplay(displayToken);
234 }
Lloyd Piquea482f992018-01-22 19:00:34 -0800235
Lloyd Piqued6fbb8a2018-01-22 19:08:36 -0800236 auto resetDisplayState() { return mFlinger->resetDisplayState(); }
237
Dominik Laskowski075d3172018-05-24 15:50:06 -0700238 auto setupNewDisplayDeviceInternal(const wp<IBinder>& displayToken,
239 const std::optional<DisplayId>& displayId,
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800240 const DisplayDeviceState& state,
Lloyd Pique542307f2018-10-19 13:24:08 -0700241 const sp<compositionengine::DisplaySurface>& dispSurface,
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800242 const sp<IGraphicBufferProducer>& producer) {
Dominik Laskowski7e045462018-05-30 13:02:02 -0700243 return mFlinger->setupNewDisplayDeviceInternal(displayToken, displayId, state, dispSurface,
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800244 producer);
245 }
246
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800247 auto handleTransactionLocked(uint32_t transactionFlags) {
248 return mFlinger->handleTransactionLocked(transactionFlags);
249 }
Lloyd Piquef58625d2017-12-19 13:22:33 -0800250
Lloyd Pique6cf11032018-01-22 18:57:44 -0800251 auto onHotplugReceived(int32_t sequenceId, hwc2_display_t display,
252 HWC2::Connection connection) {
253 return mFlinger->onHotplugReceived(sequenceId, display, connection);
254 }
255
Lloyd Pique9d9cf402018-02-16 17:47:13 -0800256 auto setDisplayStateLocked(const DisplayState& s) { return mFlinger->setDisplayStateLocked(s); }
257
Dominik Laskowski83b88212018-12-11 13:34:06 -0800258 // Allow reading display state without locking, as if called on the SF main thread.
259 auto onInitializeDisplays() NO_THREAD_SAFETY_ANALYSIS {
260 return mFlinger->onInitializeDisplays();
261 }
Lloyd Pique86016da2018-03-01 16:09:38 -0800262
Dominik Laskowski83b88212018-12-11 13:34:06 -0800263 // Allow reading display state without locking, as if called on the SF main thread.
264 auto setPowerModeInternal(const sp<DisplayDevice>& display,
265 int mode) NO_THREAD_SAFETY_ANALYSIS {
Dominik Laskowskie9774092018-12-11 10:04:24 -0800266 return mFlinger->setPowerModeInternal(display, mode);
Lloyd Pique7d4aa6c2018-03-01 16:36:35 -0800267 }
268
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700269 auto onMessageReceived(int32_t what) { return mFlinger->onMessageReceived(what); }
270
271 auto captureScreenImplLocked(const RenderArea& renderArea,
272 TraverseLayersFunction traverseLayers, ANativeWindowBuffer* buffer,
273 bool useIdentityTransform, bool forSystem, int* outSyncFd) {
274 return mFlinger->captureScreenImplLocked(renderArea, traverseLayers, buffer,
275 useIdentityTransform, forSystem, outSyncFd);
276 }
277
chaviw0e3479f2018-09-10 16:49:30 -0700278 auto traverseLayersInDisplay(const sp<const DisplayDevice>& display,
279 const LayerVector::Visitor& visitor) {
280 return mFlinger->SurfaceFlinger::traverseLayersInDisplay(display, visitor);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700281 }
282
Daniel Solomon42d04562019-01-20 21:03:19 -0800283 auto getDisplayNativePrimaries(const sp<IBinder>& displayToken,
284 ui::DisplayPrimaries &primaries) {
285 return mFlinger->SurfaceFlinger::getDisplayNativePrimaries(displayToken, primaries);
286 }
287
288 void initDefaultDisplayNativePrimaries() {
289 mFlinger->SurfaceFlinger::initDefaultDisplayNativePrimaries();
290 }
291
Lloyd Pique86016da2018-03-01 16:09:38 -0800292 /* ------------------------------------------------------------------------
293 * Read-only access to private data to assert post-conditions.
294 */
295
296 const auto& getAnimFrameTracker() const { return mFlinger->mAnimFrameTracker; }
Lloyd Pique7d4aa6c2018-03-01 16:36:35 -0800297 const auto& getHasPoweredOff() const { return mFlinger->mHasPoweredOff; }
298 const auto& getHWVsyncAvailable() const { return mFlinger->mHWVsyncAvailable; }
299 const auto& getVisibleRegionsDirty() const { return mFlinger->mVisibleRegionsDirty; }
Lloyd Pique441d5042018-10-18 16:49:51 -0700300 auto& getHwComposer() const {
301 return static_cast<impl::HWComposer&>(mFlinger->getHwComposer());
302 }
Lloyd Pique7d4aa6c2018-03-01 16:36:35 -0800303
Lloyd Pique86016da2018-03-01 16:09:38 -0800304 const auto& getCompositorTiming() const { return mFlinger->getBE().mCompositorTiming; }
305
Lloyd Piquef58625d2017-12-19 13:22:33 -0800306 /* ------------------------------------------------------------------------
307 * Read-write access to private data to set up preconditions and assert
308 * post-conditions.
309 */
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800310
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800311 auto& mutableHasWideColorDisplay() { return SurfaceFlinger::hasWideColorDisplay; }
Chia-I Wu304d9cd2018-08-27 14:38:14 -0700312 auto& mutablePrimaryDisplayOrientation() { return SurfaceFlinger::primaryDisplayOrientation; }
Peiyong Lin13effd12018-07-24 17:01:47 -0700313 auto& mutableUseColorManagement() { return SurfaceFlinger::useColorManagement; }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800314
Lloyd Piquee39cad22017-12-20 17:01:29 -0800315 auto& mutableCurrentState() { return mFlinger->mCurrentState; }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800316 auto& mutableDisplayColorSetting() { return mFlinger->mDisplayColorSetting; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700317 auto& mutableDisplays() { return mFlinger->mDisplays; }
Lloyd Piquee39cad22017-12-20 17:01:29 -0800318 auto& mutableDrawingState() { return mFlinger->mDrawingState; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800319 auto& mutableEventControlThread() { return mFlinger->mEventControlThread; }
Lloyd Piquee39cad22017-12-20 17:01:29 -0800320 auto& mutableEventQueue() { return mFlinger->mEventQueue; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800321 auto& mutableEventThread() { return mFlinger->mEventThread; }
Dominik Laskowski1eba0202019-01-24 09:14:40 -0800322 auto& mutableSFEventThread() { return mFlinger->mSFEventThread; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700323 auto& mutableGeometryInvalid() { return mFlinger->mGeometryInvalid; }
Lloyd Piqued6fbb8a2018-01-22 19:08:36 -0800324 auto& mutableHWVsyncAvailable() { return mFlinger->mHWVsyncAvailable; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800325 auto& mutableInterceptor() { return mFlinger->mInterceptor; }
Lloyd Pique6cf11032018-01-22 18:57:44 -0800326 auto& mutableMainThreadId() { return mFlinger->mMainThreadId; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800327 auto& mutablePendingHotplugEvents() { return mFlinger->mPendingHotplugEvents; }
Dominik Laskowski075d3172018-05-24 15:50:06 -0700328 auto& mutablePhysicalDisplayTokens() { return mFlinger->mPhysicalDisplayTokens; }
Lloyd Pique41be5d22018-06-21 13:11:48 -0700329 auto& mutablePrimaryDispSync() { return mFlinger->mPrimaryDispSync; }
Lloyd Piqued6fbb8a2018-01-22 19:08:36 -0800330 auto& mutablePrimaryHWVsyncEnabled() { return mFlinger->mPrimaryHWVsyncEnabled; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700331 auto& mutableTexturePool() { return mFlinger->mTexturePool; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800332 auto& mutableTransactionFlags() { return mFlinger->mTransactionFlags; }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800333 auto& mutableUseHwcVirtualDisplays() { return mFlinger->mUseHwcVirtualDisplays; }
Lloyd Piquee39cad22017-12-20 17:01:29 -0800334
Lloyd Pique6cf11032018-01-22 18:57:44 -0800335 auto& mutableComposerSequenceId() { return mFlinger->getBE().mComposerSequenceId; }
Lloyd Pique441d5042018-10-18 16:49:51 -0700336 auto& mutableHwcDisplayData() { return getHwComposer().mDisplayData; }
337 auto& mutableHwcPhysicalDisplayIdMap() { return getHwComposer().mPhysicalDisplayIdMap; }
338 auto& mutableInternalHwcDisplayId() { return getHwComposer().mInternalHwcDisplayId; }
339 auto& mutableExternalHwcDisplayId() { return getHwComposer().mExternalHwcDisplayId; }
Lloyd Piquea618d852018-01-17 11:52:30 -0800340
Lloyd Piquee39cad22017-12-20 17:01:29 -0800341 ~TestableSurfaceFlinger() {
342 // All these pointer and container clears help ensure that GMock does
343 // not report a leaked object, since the SurfaceFlinger instance may
344 // still be referenced by something despite our best efforts to destroy
345 // it after each test is done.
346 mutableDisplays().clear();
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800347 mutableEventControlThread().reset();
348 mutableEventQueue().reset();
Lloyd Piquee39cad22017-12-20 17:01:29 -0800349 mutableEventThread().reset();
Dominik Laskowski1eba0202019-01-24 09:14:40 -0800350 mutableSFEventThread().reset();
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800351 mutableInterceptor().reset();
Lloyd Pique41be5d22018-06-21 13:11:48 -0700352 mutablePrimaryDispSync().reset();
Lloyd Pique441d5042018-10-18 16:49:51 -0700353 mFlinger->mCompositionEngine->setHwComposer(std::unique_ptr<HWComposer>());
Lloyd Piqueb97e04f2018-10-18 17:07:05 -0700354 mFlinger->mCompositionEngine->setRenderEngine(
355 std::unique_ptr<renderengine::RenderEngine>());
Lloyd Piquee39cad22017-12-20 17:01:29 -0800356 }
Lloyd Piquef58625d2017-12-19 13:22:33 -0800357
Lloyd Piquea618d852018-01-17 11:52:30 -0800358 /* ------------------------------------------------------------------------
359 * Wrapper classes for Read-write access to private data to set up
360 * preconditions and assert post-conditions.
361 */
Michael Wright5d22d4f2018-06-21 02:50:34 +0100362 class FakePowerAdvisor : public Hwc2::PowerAdvisor {
363 public:
364 FakePowerAdvisor() = default;
365 ~FakePowerAdvisor() override = default;
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700366 void setExpensiveRenderingExpected(hwc2_display_t, bool) override {}
Michael Wright5d22d4f2018-06-21 02:50:34 +0100367 };
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800368
Ana Krulec4593b692019-01-11 22:07:25 -0800369 struct HWC2Display : public HWC2::impl::Display {
Michael Wright5d22d4f2018-06-21 02:50:34 +0100370 HWC2Display(Hwc2::Composer& composer, Hwc2::PowerAdvisor& advisor,
Lloyd Piquea618d852018-01-17 11:52:30 -0800371 const std::unordered_set<HWC2::Capability>& capabilities, hwc2_display_t id,
372 HWC2::DisplayType type)
Ana Krulec4593b692019-01-11 22:07:25 -0800373 : HWC2::impl::Display(composer, advisor, capabilities, id, type) {}
Lloyd Piquea618d852018-01-17 11:52:30 -0800374 ~HWC2Display() {
375 // Prevents a call to disable vsyncs.
376 mType = HWC2::DisplayType::Invalid;
377 }
378
379 auto& mutableIsConnected() { return this->mIsConnected; }
380 auto& mutableConfigs() { return this->mConfigs; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700381 auto& mutableLayers() { return this->mLayers; }
Lloyd Piquea618d852018-01-17 11:52:30 -0800382 };
383
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800384 class FakeHwcDisplayInjector {
385 public:
386 static constexpr hwc2_display_t DEFAULT_HWC_DISPLAY_ID = 1000;
387 static constexpr int32_t DEFAULT_WIDTH = 1920;
388 static constexpr int32_t DEFAULT_HEIGHT = 1280;
389 static constexpr int32_t DEFAULT_REFRESH_RATE = 16'666'666;
390 static constexpr int32_t DEFAULT_DPI = 320;
391 static constexpr int32_t DEFAULT_ACTIVE_CONFIG = 0;
392
Dominik Laskowski075d3172018-05-24 15:50:06 -0700393 FakeHwcDisplayInjector(DisplayId displayId, HWC2::DisplayType hwcDisplayType,
394 bool isPrimary)
395 : mDisplayId(displayId), mHwcDisplayType(hwcDisplayType), mIsPrimary(isPrimary) {}
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800396
397 auto& setHwcDisplayId(hwc2_display_t displayId) {
398 mHwcDisplayId = displayId;
399 return *this;
400 }
401
402 auto& setWidth(int32_t width) {
403 mWidth = width;
404 return *this;
405 }
406
407 auto& setHeight(int32_t height) {
408 mHeight = height;
409 return *this;
410 }
411
412 auto& setRefreshRate(int32_t refreshRate) {
413 mRefreshRate = refreshRate;
414 return *this;
415 }
416
417 auto& setDpiX(int32_t dpi) {
418 mDpiX = dpi;
419 return *this;
420 }
421
422 auto& setDpiY(int32_t dpi) {
423 mDpiY = dpi;
424 return *this;
425 }
426
427 auto& setActiveConfig(int32_t config) {
428 mActiveConfig = config;
429 return *this;
430 }
431
Lloyd Piquee22f0332018-07-16 16:35:56 -0700432 auto& setCapabilities(const std::unordered_set<HWC2::Capability>* capabilities) {
433 mCapabilities = capabilities;
434 return *this;
435 }
436
437 auto& setPowerAdvisor(Hwc2::PowerAdvisor* powerAdvisor) {
438 mPowerAdvisor = powerAdvisor;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800439 return *this;
440 }
441
442 void inject(TestableSurfaceFlinger* flinger, Hwc2::Composer* composer) {
Lloyd Piquee22f0332018-07-16 16:35:56 -0700443 static FakePowerAdvisor defaultPowerAdvisor;
444 if (mPowerAdvisor == nullptr) mPowerAdvisor = &defaultPowerAdvisor;
445 static const std::unordered_set<HWC2::Capability> defaultCapabilities;
446 if (mCapabilities == nullptr) mCapabilities = &defaultCapabilities;
447
448 // Caution - Make sure that any values passed by reference here do
449 // not refer to an instance owned by FakeHwcDisplayInjector. This
450 // class has temporary lifetime, while the constructed HWC2::Display
451 // is much longer lived.
452 auto display = std::make_unique<HWC2Display>(*composer, *mPowerAdvisor, *mCapabilities,
Michael Wright5d22d4f2018-06-21 02:50:34 +0100453 mHwcDisplayId, mHwcDisplayType);
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800454
455 auto config = HWC2::Display::Config::Builder(*display, mActiveConfig);
456 config.setWidth(mWidth);
457 config.setHeight(mHeight);
458 config.setVsyncPeriod(mRefreshRate);
459 config.setDpiX(mDpiX);
460 config.setDpiY(mDpiY);
461 display->mutableConfigs().emplace(mActiveConfig, config.build());
462 display->mutableIsConnected() = true;
463
Dominik Laskowski075d3172018-05-24 15:50:06 -0700464 flinger->mutableHwcDisplayData()[mDisplayId].hwcDisplay = display.get();
465
466 if (mHwcDisplayType == HWC2::DisplayType::Physical) {
467 flinger->mutableHwcPhysicalDisplayIdMap().emplace(mHwcDisplayId, mDisplayId);
468 (mIsPrimary ? flinger->mutableInternalHwcDisplayId()
469 : flinger->mutableExternalHwcDisplayId()) = mHwcDisplayId;
470 }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800471
472 flinger->mFakeHwcDisplays.push_back(std::move(display));
473 }
474
475 private:
Dominik Laskowski075d3172018-05-24 15:50:06 -0700476 const DisplayId mDisplayId;
477 const HWC2::DisplayType mHwcDisplayType;
478 const bool mIsPrimary;
479
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800480 hwc2_display_t mHwcDisplayId = DEFAULT_HWC_DISPLAY_ID;
481 int32_t mWidth = DEFAULT_WIDTH;
482 int32_t mHeight = DEFAULT_HEIGHT;
483 int32_t mRefreshRate = DEFAULT_REFRESH_RATE;
484 int32_t mDpiX = DEFAULT_DPI;
485 int32_t mDpiY = DEFAULT_DPI;
486 int32_t mActiveConfig = DEFAULT_ACTIVE_CONFIG;
Lloyd Piquee22f0332018-07-16 16:35:56 -0700487 const std::unordered_set<HWC2::Capability>* mCapabilities = nullptr;
488 Hwc2::PowerAdvisor* mPowerAdvisor = nullptr;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800489 };
490
491 class FakeDisplayDeviceInjector {
492 public:
Dominik Laskowski075d3172018-05-24 15:50:06 -0700493 FakeDisplayDeviceInjector(TestableSurfaceFlinger& flinger,
494 const std::optional<DisplayId>& displayId, bool isVirtual,
495 bool isPrimary)
496 : mFlinger(flinger), mCreationArgs(flinger.mFlinger.get(), mDisplayToken, displayId) {
497 mCreationArgs.isVirtual = isVirtual;
498 mCreationArgs.isPrimary = isPrimary;
499 }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800500
501 sp<IBinder> token() const { return mDisplayToken; }
502
503 DisplayDeviceState& mutableDrawingDisplayState() {
504 return mFlinger.mutableDrawingState().displays.editValueFor(mDisplayToken);
505 }
506
507 DisplayDeviceState& mutableCurrentDisplayState() {
508 return mFlinger.mutableCurrentState().displays.editValueFor(mDisplayToken);
509 }
510
Lloyd Pique9d9cf402018-02-16 17:47:13 -0800511 const auto& getDrawingDisplayState() {
512 return mFlinger.mutableDrawingState().displays.valueFor(mDisplayToken);
513 }
514
515 const auto& getCurrentDisplayState() {
516 return mFlinger.mutableCurrentState().displays.valueFor(mDisplayToken);
517 }
518
Dominik Laskowski9fae1022018-05-29 13:17:40 -0700519 auto& mutableDisplayDevice() { return mFlinger.mutableDisplays()[mDisplayToken]; }
Lloyd Pique9d9cf402018-02-16 17:47:13 -0800520
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800521 auto& setNativeWindow(const sp<ANativeWindow>& nativeWindow) {
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700522 mCreationArgs.nativeWindow = nativeWindow;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800523 return *this;
524 }
525
Lloyd Pique542307f2018-10-19 13:24:08 -0700526 auto& setDisplaySurface(const sp<compositionengine::DisplaySurface>& displaySurface) {
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700527 mCreationArgs.displaySurface = displaySurface;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800528 return *this;
529 }
530
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800531 auto& setSecure(bool secure) {
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700532 mCreationArgs.isSecure = secure;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800533 return *this;
534 }
535
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700536 auto& setPowerMode(int mode) {
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700537 mCreationArgs.initialPowerMode = mode;
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700538 return *this;
539 }
540
Valerie Hau9758ae02018-10-09 16:05:09 -0700541 auto& setHwcColorModes(
542 const std::unordered_map<ui::ColorMode, std::vector<ui::RenderIntent>>
543 hwcColorModes) {
544 mCreationArgs.hwcColorModes = hwcColorModes;
545 return *this;
546 }
547
548 auto& setHasWideColorGamut(bool hasWideColorGamut) {
549 mCreationArgs.hasWideColorGamut = hasWideColorGamut;
550 return *this;
551 }
552
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800553 sp<DisplayDevice> inject() {
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800554 DisplayDeviceState state;
Dominik Laskowski075d3172018-05-24 15:50:06 -0700555 state.displayId = mCreationArgs.isVirtual ? std::nullopt : mCreationArgs.displayId;
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700556 state.isSecure = mCreationArgs.isSecure;
557
558 sp<DisplayDevice> device = new DisplayDevice(std::move(mCreationArgs));
559 mFlinger.mutableDisplays().emplace(mDisplayToken, device);
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800560 mFlinger.mutableCurrentState().displays.add(mDisplayToken, state);
561 mFlinger.mutableDrawingState().displays.add(mDisplayToken, state);
562
Dominik Laskowski075d3172018-05-24 15:50:06 -0700563 if (!mCreationArgs.isVirtual) {
564 LOG_ALWAYS_FATAL_IF(!state.displayId);
565 mFlinger.mutablePhysicalDisplayTokens()[*state.displayId] = mDisplayToken;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800566 }
567
568 return device;
569 }
570
571 private:
572 TestableSurfaceFlinger& mFlinger;
573 sp<BBinder> mDisplayToken = new BBinder();
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700574 DisplayDeviceCreationArgs mCreationArgs;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800575 };
576
Lloyd Pique90c115d2018-09-18 21:39:42 -0700577 surfaceflinger::test::Factory mFactory;
578 sp<SurfaceFlinger> mFlinger = new SurfaceFlinger(mFactory, SurfaceFlinger::SkipInitialization);
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800579
580 // We need to keep a reference to these so they are properly destroyed.
581 std::vector<std::unique_ptr<HWC2Display>> mFakeHwcDisplays;
Lloyd Piquef58625d2017-12-19 13:22:33 -0800582};
583
584} // namespace android