blob: 495237b3f25bb4f9cc57fc5e3ab883d990d2f353 [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 Pique70d91362018-10-18 16:02:55 -070019#include <compositionengine/impl/CompositionEngine.h>
20
Lloyd Pique90c115d2018-09-18 21:39:42 -070021#include "BufferQueueLayer.h"
22#include "BufferStateLayer.h"
23#include "ColorLayer.h"
24#include "ContainerLayer.h"
Lloyd Piquef58625d2017-12-19 13:22:33 -080025#include "DisplayDevice.h"
Ana Krulec757f63a2019-01-25 10:46:18 -080026#include "FakePhaseOffsets.h"
Lloyd Piqued6b579f2018-04-06 15:29:10 -070027#include "Layer.h"
Lloyd Pique90c115d2018-09-18 21:39:42 -070028#include "NativeWindowSurface.h"
29#include "StartPropertySetThread.h"
Lloyd Piquef58625d2017-12-19 13:22:33 -080030#include "SurfaceFlinger.h"
Lloyd Pique90c115d2018-09-18 21:39:42 -070031#include "SurfaceFlingerFactory.h"
32#include "SurfaceInterceptor.h"
Lloyd Piquef58625d2017-12-19 13:22:33 -080033
Yiwei Zhang7e666a52018-11-15 13:33:42 -080034#include "TimeStats/TimeStats.h"
35
Lloyd Piquef58625d2017-12-19 13:22:33 -080036namespace android {
37
Lloyd Piquee39cad22017-12-20 17:01:29 -080038class EventThread;
39
Peiyong Lin833074a2018-08-28 11:53:54 -070040namespace renderengine {
Lloyd Pique90c115d2018-09-18 21:39:42 -070041
Lloyd Piquee39cad22017-12-20 17:01:29 -080042class RenderEngine;
Lloyd Pique90c115d2018-09-18 21:39:42 -070043
44} // namespace renderengine
Lloyd Piquee39cad22017-12-20 17:01:29 -080045
46namespace Hwc2 {
Lloyd Pique90c115d2018-09-18 21:39:42 -070047
Lloyd Piquee39cad22017-12-20 17:01:29 -080048class Composer;
Lloyd Pique90c115d2018-09-18 21:39:42 -070049
50} // namespace Hwc2
51
52namespace surfaceflinger::test {
53
54class Factory final : public surfaceflinger::Factory {
55public:
56 ~Factory() = default;
57
58 std::unique_ptr<DispSync> createDispSync(const char*, bool, int64_t) override {
59 // TODO: Use test-fixture controlled factory
60 return nullptr;
61 }
62
63 std::unique_ptr<EventControlThread> createEventControlThread(
64 std::function<void(bool)>) override {
65 // TODO: Use test-fixture controlled factory
66 return nullptr;
67 }
68
69 std::unique_ptr<HWComposer> createHWComposer(const std::string&) override {
70 // TODO: Use test-fixture controlled factory
71 return nullptr;
72 }
73
74 std::unique_ptr<MessageQueue> createMessageQueue() override {
75 // TODO: Use test-fixture controlled factory
76 return std::make_unique<android::impl::MessageQueue>();
77 }
78
Ana Krulec757f63a2019-01-25 10:46:18 -080079 std::unique_ptr<scheduler::PhaseOffsets> createPhaseOffsets() override {
80 return std::make_unique<scheduler::FakePhaseOffsets>();
81 }
82
Lloyd Pique90c115d2018-09-18 21:39:42 -070083 std::unique_ptr<Scheduler> createScheduler(std::function<void(bool)>) override {
84 // TODO: Use test-fixture controlled factory
85 return nullptr;
86 }
87
88 std::unique_ptr<SurfaceInterceptor> createSurfaceInterceptor(SurfaceFlinger* flinger) override {
89 // TODO: Use test-fixture controlled factory
90 return std::make_unique<android::impl::SurfaceInterceptor>(flinger);
91 }
92
93 sp<StartPropertySetThread> createStartPropertySetThread(bool timestampPropertyValue) override {
94 // TODO: Use test-fixture controlled factory
95 return new StartPropertySetThread(timestampPropertyValue);
96 }
97
98 sp<DisplayDevice> createDisplayDevice(DisplayDeviceCreationArgs&& creationArgs) override {
99 // TODO: Use test-fixture controlled factory
100 return new DisplayDevice(std::move(creationArgs));
101 }
102
103 sp<GraphicBuffer> createGraphicBuffer(uint32_t width, uint32_t height, PixelFormat format,
104 uint32_t layerCount, uint64_t usage,
105 std::string requestorName) override {
106 // TODO: Use test-fixture controlled factory
107 return new GraphicBuffer(width, height, format, layerCount, usage, requestorName);
108 }
109
110 void createBufferQueue(sp<IGraphicBufferProducer>* outProducer,
111 sp<IGraphicBufferConsumer>* outConsumer,
112 bool consumerIsSurfaceFlinger) override {
113 if (!mCreateBufferQueue) return;
114 mCreateBufferQueue(outProducer, outConsumer, consumerIsSurfaceFlinger);
115 }
116
117 std::unique_ptr<surfaceflinger::NativeWindowSurface> createNativeWindowSurface(
118 const sp<IGraphicBufferProducer>& producer) override {
119 if (!mCreateNativeWindowSurface) return nullptr;
120 return mCreateNativeWindowSurface(producer);
121 }
122
Lloyd Pique70d91362018-10-18 16:02:55 -0700123 std::unique_ptr<compositionengine::CompositionEngine> createCompositionEngine() override {
124 return compositionengine::impl::createCompositionEngine();
125 }
126
Lloyd Pique90c115d2018-09-18 21:39:42 -0700127 sp<BufferQueueLayer> createBufferQueueLayer(const LayerCreationArgs&) override {
128 // TODO: Use test-fixture controlled factory
129 return nullptr;
130 }
131
132 sp<BufferStateLayer> createBufferStateLayer(const LayerCreationArgs&) override {
133 // TODO: Use test-fixture controlled factory
134 return nullptr;
135 }
136
137 sp<ColorLayer> createColorLayer(const LayerCreationArgs&) override {
138 // TODO: Use test-fixture controlled factory
139 return nullptr;
140 }
141
142 sp<ContainerLayer> createContainerLayer(const LayerCreationArgs&) override {
143 // TODO: Use test-fixture controlled factory
144 return nullptr;
145 }
146
Alec Mourifb571ea2019-01-24 18:42:10 -0800147 std::shared_ptr<TimeStats> createTimeStats() override {
Yiwei Zhang7e666a52018-11-15 13:33:42 -0800148 // TODO: Use test-fixture controlled factory
Alec Mourifb571ea2019-01-24 18:42:10 -0800149 return std::make_shared<android::impl::TimeStats>();
Yiwei Zhang7e666a52018-11-15 13:33:42 -0800150 }
151
Lloyd Pique90c115d2018-09-18 21:39:42 -0700152 using CreateBufferQueueFunction =
153 std::function<void(sp<IGraphicBufferProducer>* /* outProducer */,
154 sp<IGraphicBufferConsumer>* /* outConsumer */,
155 bool /* consumerIsSurfaceFlinger */)>;
156 CreateBufferQueueFunction mCreateBufferQueue;
157
158 using CreateNativeWindowSurfaceFunction =
159 std::function<std::unique_ptr<surfaceflinger::NativeWindowSurface>(
160 const sp<IGraphicBufferProducer>&)>;
161 CreateNativeWindowSurfaceFunction mCreateNativeWindowSurface;
Lloyd Pique70d91362018-10-18 16:02:55 -0700162
163 using CreateCompositionEngineFunction =
164 std::function<std::unique_ptr<compositionengine::CompositionEngine>()>;
165 CreateCompositionEngineFunction mCreateCompositionEngine;
Lloyd Pique90c115d2018-09-18 21:39:42 -0700166};
167
168} // namespace surfaceflinger::test
Lloyd Piquee39cad22017-12-20 17:01:29 -0800169
Lloyd Piquef58625d2017-12-19 13:22:33 -0800170class TestableSurfaceFlinger {
171public:
172 // Extend this as needed for accessing SurfaceFlinger private (and public)
173 // functions.
174
Peiyong Lin833074a2018-08-28 11:53:54 -0700175 void setupRenderEngine(std::unique_ptr<renderengine::RenderEngine> renderEngine) {
Lloyd Piqueb97e04f2018-10-18 17:07:05 -0700176 mFlinger->mCompositionEngine->setRenderEngine(std::move(renderEngine));
Lloyd Piquee39cad22017-12-20 17:01:29 -0800177 }
178
179 void setupComposer(std::unique_ptr<Hwc2::Composer> composer) {
Lloyd Pique441d5042018-10-18 16:49:51 -0700180 mFlinger->mCompositionEngine->setHwComposer(
181 std::make_unique<impl::HWComposer>(std::move(composer)));
Lloyd Piquee39cad22017-12-20 17:01:29 -0800182 }
183
Lloyd Pique90c115d2018-09-18 21:39:42 -0700184 using CreateBufferQueueFunction = surfaceflinger::test::Factory::CreateBufferQueueFunction;
Lloyd Pique5b36f3f2018-01-17 11:57:07 -0800185 void setCreateBufferQueueFunction(CreateBufferQueueFunction f) {
Lloyd Pique90c115d2018-09-18 21:39:42 -0700186 mFactory.mCreateBufferQueue = f;
Lloyd Pique5b36f3f2018-01-17 11:57:07 -0800187 }
188
Lloyd Pique90c115d2018-09-18 21:39:42 -0700189 using CreateNativeWindowSurfaceFunction =
190 surfaceflinger::test::Factory::CreateNativeWindowSurfaceFunction;
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800191 void setCreateNativeWindowSurface(CreateNativeWindowSurfaceFunction f) {
Lloyd Pique90c115d2018-09-18 21:39:42 -0700192 mFactory.mCreateNativeWindowSurface = f;
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800193 }
194
Daniel Solomon42d04562019-01-20 21:03:19 -0800195 void setInternalDisplayPrimaries(const ui::DisplayPrimaries& primaries) {
196 memcpy(&mFlinger->mInternalDisplayPrimaries, &primaries, sizeof(ui::DisplayPrimaries));
197 }
198
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800199 using HotplugEvent = SurfaceFlinger::HotplugEvent;
200
Lloyd Pique0449b0f2018-12-20 16:23:45 -0800201 auto& mutableLayerCurrentState(sp<Layer> layer) { return layer->mCurrentState; }
202 auto& mutableLayerDrawingState(sp<Layer> layer) { return layer->mDrawingState; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700203
204 void setLayerSidebandStream(sp<Layer> layer, sp<NativeHandle> sidebandStream) {
Lloyd Pique0449b0f2018-12-20 16:23:45 -0800205 layer->mDrawingState.sidebandStream = sidebandStream;
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700206 layer->getBE().compositionInfo.hwc.sidebandStream = sidebandStream;
207 }
208
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700209 void setLayerPotentialCursor(sp<Layer> layer, bool potentialCursor) {
210 layer->mPotentialCursor = potentialCursor;
211 }
212
Lloyd Piquef58625d2017-12-19 13:22:33 -0800213 /* ------------------------------------------------------------------------
214 * Forwarding for functions being tested
215 */
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800216
Lloyd Piquea482f992018-01-22 19:00:34 -0800217 auto createDisplay(const String8& displayName, bool secure) {
218 return mFlinger->createDisplay(displayName, secure);
219 }
220
Dominik Laskowskieecd6592018-05-29 10:25:41 -0700221 auto destroyDisplay(const sp<IBinder>& displayToken) {
222 return mFlinger->destroyDisplay(displayToken);
223 }
Lloyd Piquea482f992018-01-22 19:00:34 -0800224
Lloyd Piqued6fbb8a2018-01-22 19:08:36 -0800225 auto resetDisplayState() { return mFlinger->resetDisplayState(); }
226
Dominik Laskowski075d3172018-05-24 15:50:06 -0700227 auto setupNewDisplayDeviceInternal(const wp<IBinder>& displayToken,
228 const std::optional<DisplayId>& displayId,
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800229 const DisplayDeviceState& state,
Lloyd Pique542307f2018-10-19 13:24:08 -0700230 const sp<compositionengine::DisplaySurface>& dispSurface,
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800231 const sp<IGraphicBufferProducer>& producer) {
Dominik Laskowski7e045462018-05-30 13:02:02 -0700232 return mFlinger->setupNewDisplayDeviceInternal(displayToken, displayId, state, dispSurface,
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800233 producer);
234 }
235
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800236 auto handleTransactionLocked(uint32_t transactionFlags) {
Vishnu Nairfa5f8df2019-02-13 17:02:51 -0800237 Mutex::Autolock _l(mFlinger->mStateLock);
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800238 return mFlinger->handleTransactionLocked(transactionFlags);
239 }
Lloyd Piquef58625d2017-12-19 13:22:33 -0800240
Lloyd Pique6cf11032018-01-22 18:57:44 -0800241 auto onHotplugReceived(int32_t sequenceId, hwc2_display_t display,
242 HWC2::Connection connection) {
243 return mFlinger->onHotplugReceived(sequenceId, display, connection);
244 }
245
Lloyd Pique9d9cf402018-02-16 17:47:13 -0800246 auto setDisplayStateLocked(const DisplayState& s) { return mFlinger->setDisplayStateLocked(s); }
247
Dominik Laskowski83b88212018-12-11 13:34:06 -0800248 // Allow reading display state without locking, as if called on the SF main thread.
249 auto onInitializeDisplays() NO_THREAD_SAFETY_ANALYSIS {
250 return mFlinger->onInitializeDisplays();
251 }
Lloyd Pique86016da2018-03-01 16:09:38 -0800252
Dominik Laskowski83b88212018-12-11 13:34:06 -0800253 // Allow reading display state without locking, as if called on the SF main thread.
254 auto setPowerModeInternal(const sp<DisplayDevice>& display,
255 int mode) NO_THREAD_SAFETY_ANALYSIS {
Dominik Laskowskie9774092018-12-11 10:04:24 -0800256 return mFlinger->setPowerModeInternal(display, mode);
Lloyd Pique7d4aa6c2018-03-01 16:36:35 -0800257 }
258
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700259 auto onMessageReceived(int32_t what) { return mFlinger->onMessageReceived(what); }
260
261 auto captureScreenImplLocked(const RenderArea& renderArea,
262 TraverseLayersFunction traverseLayers, ANativeWindowBuffer* buffer,
263 bool useIdentityTransform, bool forSystem, int* outSyncFd) {
264 return mFlinger->captureScreenImplLocked(renderArea, traverseLayers, buffer,
265 useIdentityTransform, forSystem, outSyncFd);
266 }
267
chaviw0e3479f2018-09-10 16:49:30 -0700268 auto traverseLayersInDisplay(const sp<const DisplayDevice>& display,
269 const LayerVector::Visitor& visitor) {
270 return mFlinger->SurfaceFlinger::traverseLayersInDisplay(display, visitor);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700271 }
272
Daniel Solomon42d04562019-01-20 21:03:19 -0800273 auto getDisplayNativePrimaries(const sp<IBinder>& displayToken,
274 ui::DisplayPrimaries &primaries) {
275 return mFlinger->SurfaceFlinger::getDisplayNativePrimaries(displayToken, primaries);
276 }
277
278 void initDefaultDisplayNativePrimaries() {
279 mFlinger->SurfaceFlinger::initDefaultDisplayNativePrimaries();
280 }
281
Lloyd Pique86016da2018-03-01 16:09:38 -0800282 /* ------------------------------------------------------------------------
283 * Read-only access to private data to assert post-conditions.
284 */
285
286 const auto& getAnimFrameTracker() const { return mFlinger->mAnimFrameTracker; }
Lloyd Pique7d4aa6c2018-03-01 16:36:35 -0800287 const auto& getHasPoweredOff() const { return mFlinger->mHasPoweredOff; }
288 const auto& getHWVsyncAvailable() const { return mFlinger->mHWVsyncAvailable; }
289 const auto& getVisibleRegionsDirty() const { return mFlinger->mVisibleRegionsDirty; }
Lloyd Pique441d5042018-10-18 16:49:51 -0700290 auto& getHwComposer() const {
291 return static_cast<impl::HWComposer&>(mFlinger->getHwComposer());
292 }
Lloyd Pique7d4aa6c2018-03-01 16:36:35 -0800293
Lloyd Pique86016da2018-03-01 16:09:38 -0800294 const auto& getCompositorTiming() const { return mFlinger->getBE().mCompositorTiming; }
295
Lloyd Piquef58625d2017-12-19 13:22:33 -0800296 /* ------------------------------------------------------------------------
297 * Read-write access to private data to set up preconditions and assert
298 * post-conditions.
299 */
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800300
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800301 auto& mutableHasWideColorDisplay() { return SurfaceFlinger::hasWideColorDisplay; }
Chia-I Wu304d9cd2018-08-27 14:38:14 -0700302 auto& mutablePrimaryDisplayOrientation() { return SurfaceFlinger::primaryDisplayOrientation; }
Peiyong Lin13effd12018-07-24 17:01:47 -0700303 auto& mutableUseColorManagement() { return SurfaceFlinger::useColorManagement; }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800304
Lloyd Piquee39cad22017-12-20 17:01:29 -0800305 auto& mutableCurrentState() { return mFlinger->mCurrentState; }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800306 auto& mutableDisplayColorSetting() { return mFlinger->mDisplayColorSetting; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700307 auto& mutableDisplays() { return mFlinger->mDisplays; }
Lloyd Piquee39cad22017-12-20 17:01:29 -0800308 auto& mutableDrawingState() { return mFlinger->mDrawingState; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800309 auto& mutableEventControlThread() { return mFlinger->mEventControlThread; }
Lloyd Piquee39cad22017-12-20 17:01:29 -0800310 auto& mutableEventQueue() { return mFlinger->mEventQueue; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800311 auto& mutableEventThread() { return mFlinger->mEventThread; }
Dominik Laskowski1eba0202019-01-24 09:14:40 -0800312 auto& mutableSFEventThread() { return mFlinger->mSFEventThread; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700313 auto& mutableGeometryInvalid() { return mFlinger->mGeometryInvalid; }
Lloyd Piqued6fbb8a2018-01-22 19:08:36 -0800314 auto& mutableHWVsyncAvailable() { return mFlinger->mHWVsyncAvailable; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800315 auto& mutableInterceptor() { return mFlinger->mInterceptor; }
Lloyd Pique6cf11032018-01-22 18:57:44 -0800316 auto& mutableMainThreadId() { return mFlinger->mMainThreadId; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800317 auto& mutablePendingHotplugEvents() { return mFlinger->mPendingHotplugEvents; }
Dominik Laskowski075d3172018-05-24 15:50:06 -0700318 auto& mutablePhysicalDisplayTokens() { return mFlinger->mPhysicalDisplayTokens; }
Lloyd Pique41be5d22018-06-21 13:11:48 -0700319 auto& mutablePrimaryDispSync() { return mFlinger->mPrimaryDispSync; }
Lloyd Piqued6fbb8a2018-01-22 19:08:36 -0800320 auto& mutablePrimaryHWVsyncEnabled() { return mFlinger->mPrimaryHWVsyncEnabled; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700321 auto& mutableTexturePool() { return mFlinger->mTexturePool; }
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800322 auto& mutableTransactionFlags() { return mFlinger->mTransactionFlags; }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800323 auto& mutableUseHwcVirtualDisplays() { return mFlinger->mUseHwcVirtualDisplays; }
Lloyd Piquee39cad22017-12-20 17:01:29 -0800324
Lloyd Pique6cf11032018-01-22 18:57:44 -0800325 auto& mutableComposerSequenceId() { return mFlinger->getBE().mComposerSequenceId; }
Lloyd Pique441d5042018-10-18 16:49:51 -0700326 auto& mutableHwcDisplayData() { return getHwComposer().mDisplayData; }
327 auto& mutableHwcPhysicalDisplayIdMap() { return getHwComposer().mPhysicalDisplayIdMap; }
328 auto& mutableInternalHwcDisplayId() { return getHwComposer().mInternalHwcDisplayId; }
329 auto& mutableExternalHwcDisplayId() { return getHwComposer().mExternalHwcDisplayId; }
Lloyd Piquea618d852018-01-17 11:52:30 -0800330
Lloyd Piquee39cad22017-12-20 17:01:29 -0800331 ~TestableSurfaceFlinger() {
332 // All these pointer and container clears help ensure that GMock does
333 // not report a leaked object, since the SurfaceFlinger instance may
334 // still be referenced by something despite our best efforts to destroy
335 // it after each test is done.
336 mutableDisplays().clear();
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800337 mutableEventControlThread().reset();
338 mutableEventQueue().reset();
Lloyd Piquee39cad22017-12-20 17:01:29 -0800339 mutableEventThread().reset();
Dominik Laskowski1eba0202019-01-24 09:14:40 -0800340 mutableSFEventThread().reset();
Lloyd Pique0b1fe702018-01-22 18:03:16 -0800341 mutableInterceptor().reset();
Lloyd Pique41be5d22018-06-21 13:11:48 -0700342 mutablePrimaryDispSync().reset();
Lloyd Pique441d5042018-10-18 16:49:51 -0700343 mFlinger->mCompositionEngine->setHwComposer(std::unique_ptr<HWComposer>());
Lloyd Piqueb97e04f2018-10-18 17:07:05 -0700344 mFlinger->mCompositionEngine->setRenderEngine(
345 std::unique_ptr<renderengine::RenderEngine>());
Lloyd Piquee39cad22017-12-20 17:01:29 -0800346 }
Lloyd Piquef58625d2017-12-19 13:22:33 -0800347
Lloyd Piquea618d852018-01-17 11:52:30 -0800348 /* ------------------------------------------------------------------------
349 * Wrapper classes for Read-write access to private data to set up
350 * preconditions and assert post-conditions.
351 */
Michael Wright5d22d4f2018-06-21 02:50:34 +0100352 class FakePowerAdvisor : public Hwc2::PowerAdvisor {
353 public:
354 FakePowerAdvisor() = default;
355 ~FakePowerAdvisor() override = default;
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700356 void setExpensiveRenderingExpected(hwc2_display_t, bool) override {}
Michael Wright5d22d4f2018-06-21 02:50:34 +0100357 };
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800358
Ana Krulec4593b692019-01-11 22:07:25 -0800359 struct HWC2Display : public HWC2::impl::Display {
Michael Wright5d22d4f2018-06-21 02:50:34 +0100360 HWC2Display(Hwc2::Composer& composer, Hwc2::PowerAdvisor& advisor,
Lloyd Piquea618d852018-01-17 11:52:30 -0800361 const std::unordered_set<HWC2::Capability>& capabilities, hwc2_display_t id,
362 HWC2::DisplayType type)
Ana Krulec4593b692019-01-11 22:07:25 -0800363 : HWC2::impl::Display(composer, advisor, capabilities, id, type) {}
Lloyd Piquea618d852018-01-17 11:52:30 -0800364 ~HWC2Display() {
365 // Prevents a call to disable vsyncs.
366 mType = HWC2::DisplayType::Invalid;
367 }
368
369 auto& mutableIsConnected() { return this->mIsConnected; }
370 auto& mutableConfigs() { return this->mConfigs; }
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700371 auto& mutableLayers() { return this->mLayers; }
Lloyd Piquea618d852018-01-17 11:52:30 -0800372 };
373
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800374 class FakeHwcDisplayInjector {
375 public:
376 static constexpr hwc2_display_t DEFAULT_HWC_DISPLAY_ID = 1000;
377 static constexpr int32_t DEFAULT_WIDTH = 1920;
378 static constexpr int32_t DEFAULT_HEIGHT = 1280;
379 static constexpr int32_t DEFAULT_REFRESH_RATE = 16'666'666;
380 static constexpr int32_t DEFAULT_DPI = 320;
381 static constexpr int32_t DEFAULT_ACTIVE_CONFIG = 0;
382
Dominik Laskowski075d3172018-05-24 15:50:06 -0700383 FakeHwcDisplayInjector(DisplayId displayId, HWC2::DisplayType hwcDisplayType,
384 bool isPrimary)
385 : mDisplayId(displayId), mHwcDisplayType(hwcDisplayType), mIsPrimary(isPrimary) {}
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800386
387 auto& setHwcDisplayId(hwc2_display_t displayId) {
388 mHwcDisplayId = displayId;
389 return *this;
390 }
391
392 auto& setWidth(int32_t width) {
393 mWidth = width;
394 return *this;
395 }
396
397 auto& setHeight(int32_t height) {
398 mHeight = height;
399 return *this;
400 }
401
402 auto& setRefreshRate(int32_t refreshRate) {
403 mRefreshRate = refreshRate;
404 return *this;
405 }
406
407 auto& setDpiX(int32_t dpi) {
408 mDpiX = dpi;
409 return *this;
410 }
411
412 auto& setDpiY(int32_t dpi) {
413 mDpiY = dpi;
414 return *this;
415 }
416
417 auto& setActiveConfig(int32_t config) {
418 mActiveConfig = config;
419 return *this;
420 }
421
Lloyd Piquee22f0332018-07-16 16:35:56 -0700422 auto& setCapabilities(const std::unordered_set<HWC2::Capability>* capabilities) {
423 mCapabilities = capabilities;
424 return *this;
425 }
426
427 auto& setPowerAdvisor(Hwc2::PowerAdvisor* powerAdvisor) {
428 mPowerAdvisor = powerAdvisor;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800429 return *this;
430 }
431
432 void inject(TestableSurfaceFlinger* flinger, Hwc2::Composer* composer) {
Lloyd Piquee22f0332018-07-16 16:35:56 -0700433 static FakePowerAdvisor defaultPowerAdvisor;
434 if (mPowerAdvisor == nullptr) mPowerAdvisor = &defaultPowerAdvisor;
435 static const std::unordered_set<HWC2::Capability> defaultCapabilities;
436 if (mCapabilities == nullptr) mCapabilities = &defaultCapabilities;
437
438 // Caution - Make sure that any values passed by reference here do
439 // not refer to an instance owned by FakeHwcDisplayInjector. This
440 // class has temporary lifetime, while the constructed HWC2::Display
441 // is much longer lived.
442 auto display = std::make_unique<HWC2Display>(*composer, *mPowerAdvisor, *mCapabilities,
Michael Wright5d22d4f2018-06-21 02:50:34 +0100443 mHwcDisplayId, mHwcDisplayType);
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800444
445 auto config = HWC2::Display::Config::Builder(*display, mActiveConfig);
446 config.setWidth(mWidth);
447 config.setHeight(mHeight);
448 config.setVsyncPeriod(mRefreshRate);
449 config.setDpiX(mDpiX);
450 config.setDpiY(mDpiY);
451 display->mutableConfigs().emplace(mActiveConfig, config.build());
452 display->mutableIsConnected() = true;
453
Dominik Laskowski075d3172018-05-24 15:50:06 -0700454 flinger->mutableHwcDisplayData()[mDisplayId].hwcDisplay = display.get();
455
456 if (mHwcDisplayType == HWC2::DisplayType::Physical) {
457 flinger->mutableHwcPhysicalDisplayIdMap().emplace(mHwcDisplayId, mDisplayId);
458 (mIsPrimary ? flinger->mutableInternalHwcDisplayId()
459 : flinger->mutableExternalHwcDisplayId()) = mHwcDisplayId;
460 }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800461
462 flinger->mFakeHwcDisplays.push_back(std::move(display));
463 }
464
465 private:
Dominik Laskowski075d3172018-05-24 15:50:06 -0700466 const DisplayId mDisplayId;
467 const HWC2::DisplayType mHwcDisplayType;
468 const bool mIsPrimary;
469
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800470 hwc2_display_t mHwcDisplayId = DEFAULT_HWC_DISPLAY_ID;
471 int32_t mWidth = DEFAULT_WIDTH;
472 int32_t mHeight = DEFAULT_HEIGHT;
473 int32_t mRefreshRate = DEFAULT_REFRESH_RATE;
474 int32_t mDpiX = DEFAULT_DPI;
475 int32_t mDpiY = DEFAULT_DPI;
476 int32_t mActiveConfig = DEFAULT_ACTIVE_CONFIG;
Lloyd Piquee22f0332018-07-16 16:35:56 -0700477 const std::unordered_set<HWC2::Capability>* mCapabilities = nullptr;
478 Hwc2::PowerAdvisor* mPowerAdvisor = nullptr;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800479 };
480
481 class FakeDisplayDeviceInjector {
482 public:
Dominik Laskowski075d3172018-05-24 15:50:06 -0700483 FakeDisplayDeviceInjector(TestableSurfaceFlinger& flinger,
484 const std::optional<DisplayId>& displayId, bool isVirtual,
485 bool isPrimary)
486 : mFlinger(flinger), mCreationArgs(flinger.mFlinger.get(), mDisplayToken, displayId) {
487 mCreationArgs.isVirtual = isVirtual;
488 mCreationArgs.isPrimary = isPrimary;
489 }
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800490
491 sp<IBinder> token() const { return mDisplayToken; }
492
493 DisplayDeviceState& mutableDrawingDisplayState() {
494 return mFlinger.mutableDrawingState().displays.editValueFor(mDisplayToken);
495 }
496
497 DisplayDeviceState& mutableCurrentDisplayState() {
498 return mFlinger.mutableCurrentState().displays.editValueFor(mDisplayToken);
499 }
500
Lloyd Pique9d9cf402018-02-16 17:47:13 -0800501 const auto& getDrawingDisplayState() {
502 return mFlinger.mutableDrawingState().displays.valueFor(mDisplayToken);
503 }
504
505 const auto& getCurrentDisplayState() {
506 return mFlinger.mutableCurrentState().displays.valueFor(mDisplayToken);
507 }
508
Dominik Laskowski9fae1022018-05-29 13:17:40 -0700509 auto& mutableDisplayDevice() { return mFlinger.mutableDisplays()[mDisplayToken]; }
Lloyd Pique9d9cf402018-02-16 17:47:13 -0800510
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800511 auto& setNativeWindow(const sp<ANativeWindow>& nativeWindow) {
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700512 mCreationArgs.nativeWindow = nativeWindow;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800513 return *this;
514 }
515
Lloyd Pique542307f2018-10-19 13:24:08 -0700516 auto& setDisplaySurface(const sp<compositionengine::DisplaySurface>& displaySurface) {
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700517 mCreationArgs.displaySurface = displaySurface;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800518 return *this;
519 }
520
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800521 auto& setSecure(bool secure) {
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700522 mCreationArgs.isSecure = secure;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800523 return *this;
524 }
525
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700526 auto& setPowerMode(int mode) {
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700527 mCreationArgs.initialPowerMode = mode;
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700528 return *this;
529 }
530
Valerie Hau9758ae02018-10-09 16:05:09 -0700531 auto& setHwcColorModes(
532 const std::unordered_map<ui::ColorMode, std::vector<ui::RenderIntent>>
533 hwcColorModes) {
534 mCreationArgs.hwcColorModes = hwcColorModes;
535 return *this;
536 }
537
538 auto& setHasWideColorGamut(bool hasWideColorGamut) {
539 mCreationArgs.hasWideColorGamut = hasWideColorGamut;
540 return *this;
541 }
542
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800543 sp<DisplayDevice> inject() {
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800544 DisplayDeviceState state;
Dominik Laskowski075d3172018-05-24 15:50:06 -0700545 state.displayId = mCreationArgs.isVirtual ? std::nullopt : mCreationArgs.displayId;
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700546 state.isSecure = mCreationArgs.isSecure;
547
548 sp<DisplayDevice> device = new DisplayDevice(std::move(mCreationArgs));
549 mFlinger.mutableDisplays().emplace(mDisplayToken, device);
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800550 mFlinger.mutableCurrentState().displays.add(mDisplayToken, state);
551 mFlinger.mutableDrawingState().displays.add(mDisplayToken, state);
552
Dominik Laskowski075d3172018-05-24 15:50:06 -0700553 if (!mCreationArgs.isVirtual) {
554 LOG_ALWAYS_FATAL_IF(!state.displayId);
555 mFlinger.mutablePhysicalDisplayTokens()[*state.displayId] = mDisplayToken;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800556 }
557
558 return device;
559 }
560
561 private:
562 TestableSurfaceFlinger& mFlinger;
563 sp<BBinder> mDisplayToken = new BBinder();
Lloyd Pique2eef1d22018-09-18 21:30:04 -0700564 DisplayDeviceCreationArgs mCreationArgs;
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800565 };
566
Lloyd Pique90c115d2018-09-18 21:39:42 -0700567 surfaceflinger::test::Factory mFactory;
568 sp<SurfaceFlinger> mFlinger = new SurfaceFlinger(mFactory, SurfaceFlinger::SkipInitialization);
Lloyd Piquec11e0d32018-01-22 18:44:59 -0800569
570 // We need to keep a reference to these so they are properly destroyed.
571 std::vector<std::unique_ptr<HWC2Display>> mFakeHwcDisplays;
Lloyd Piquef58625d2017-12-19 13:22:33 -0800572};
573
574} // namespace android