blob: 54111de7ceb0c490aec2eb3cc8f565c852923346 [file] [log] [blame]
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2007 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
Dan Stoza9e56aa02015-11-02 13:00:03 -080017// #define LOG_NDEBUG 0
18#undef LOG_TAG
19#define LOG_TAG "DisplayDevice"
20
Dominik Laskowski9b17b2c22018-11-01 14:49:03 -070021#include <android-base/stringprintf.h>
Lloyd Pique45a165a2018-10-19 11:54:47 -070022#include <compositionengine/CompositionEngine.h>
23#include <compositionengine/Display.h>
Lloyd Pique3d0c02e2018-10-19 18:38:12 -070024#include <compositionengine/DisplayColorProfile.h>
25#include <compositionengine/DisplayColorProfileCreationArgs.h>
Lloyd Pique45a165a2018-10-19 11:54:47 -070026#include <compositionengine/DisplayCreationArgs.h>
Lloyd Pique542307f2018-10-19 13:24:08 -070027#include <compositionengine/DisplaySurface.h>
Lloyd Pique31cb2942018-10-19 17:23:03 -070028#include <compositionengine/RenderSurface.h>
29#include <compositionengine/RenderSurfaceCreationArgs.h>
Lloyd Pique32cbe282018-10-19 13:09:22 -070030#include <compositionengine/impl/OutputCompositionState.h>
Peiyong Lincbc184f2018-08-22 13:24:10 -070031#include <configstore/Utils.h>
Lloyd Pique3d0c02e2018-10-19 18:38:12 -070032#include <log/log.h>
Alec Mouri0a9c7b82018-11-16 13:05:25 -080033#include <system/window.h>
Lloyd Pique3d0c02e2018-10-19 18:38:12 -070034#include <ui/GraphicTypes.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080035
Lloyd Pique3d0c02e2018-10-19 18:38:12 -070036#include "DisplayDevice.h"
Mathias Agopian13127d82013-03-05 17:47:11 -080037#include "Layer.h"
Lloyd Pique3d0c02e2018-10-19 18:38:12 -070038#include "SurfaceFlinger.h"
Mathias Agopian1f7bec62010-06-25 18:02:21 -070039
Peiyong Linfd997e02018-03-28 15:29:00 -070040namespace android {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080041
Yiwei Zhang5434a782018-12-05 18:06:32 -080042using android::base::StringAppendF;
Jaesoo Lee720a7242017-01-31 15:26:18 +090043
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080044/*
45 * Initialize the display to the specified values.
46 *
47 */
48
Pablo Ceballos021623b2016-04-15 17:31:51 -070049uint32_t DisplayDevice::sPrimaryDisplayOrientation = 0;
50
Lloyd Pique2eef1d22018-09-18 21:30:04 -070051DisplayDeviceCreationArgs::DisplayDeviceCreationArgs(const sp<SurfaceFlinger>& flinger,
52 const wp<IBinder>& displayToken,
Dominik Laskowski075d3172018-05-24 15:50:06 -070053 const std::optional<DisplayId>& displayId)
54 : flinger(flinger), displayToken(displayToken), displayId(displayId) {}
Chia-I Wube02ec02018-05-18 10:59:36 -070055
Lloyd Pique2eef1d22018-09-18 21:30:04 -070056DisplayDevice::DisplayDevice(DisplayDeviceCreationArgs&& args)
Lloyd Pique32cbe282018-10-19 13:09:22 -070057 : mFlinger(args.flinger),
Lloyd Pique2eef1d22018-09-18 21:30:04 -070058 mDisplayToken(args.displayToken),
Dominik Laskowskie9774092018-12-11 10:04:24 -080059 mSequenceId(args.sequenceId),
Lloyd Pique45a165a2018-10-19 11:54:47 -070060 mDisplayInstallOrientation(args.displayInstallOrientation),
61 mCompositionDisplay{mFlinger->getCompositionEngine().createDisplay(
62 compositionengine::DisplayCreationArgs{args.isSecure, args.isVirtual,
63 args.displayId})},
Dominik Laskowski075d3172018-05-24 15:50:06 -070064 mIsVirtual(args.isVirtual),
Lloyd Pique2eef1d22018-09-18 21:30:04 -070065 mOrientation(),
Lloyd Pique2eef1d22018-09-18 21:30:04 -070066 mActiveConfig(0),
Dominik Laskowski075d3172018-05-24 15:50:06 -070067 mIsPrimary(args.isPrimary) {
Lloyd Pique31cb2942018-10-19 17:23:03 -070068 mCompositionDisplay->createRenderSurface(
69 compositionengine::RenderSurfaceCreationArgs{ANativeWindow_getWidth(
70 args.nativeWindow.get()),
71 ANativeWindow_getHeight(
72 args.nativeWindow.get()),
73 args.nativeWindow, args.displaySurface});
74
Lloyd Pique3d0c02e2018-10-19 18:38:12 -070075 mCompositionDisplay->createDisplayColorProfile(
76 compositionengine::DisplayColorProfileCreationArgs{args.hasWideColorGamut,
77 std::move(args.hdrCapabilities),
78 args.supportedPerFrameMetadata,
79 args.hwcColorModes});
80
Lloyd Pique32cbe282018-10-19 13:09:22 -070081 if (!mCompositionDisplay->isValid()) {
82 ALOGE("Composition Display did not validate!");
83 }
84
Lloyd Pique31cb2942018-10-19 17:23:03 -070085 mCompositionDisplay->getRenderSurface()->initialize();
Lloyd Pique2eef1d22018-09-18 21:30:04 -070086
Lloyd Pique32cbe282018-10-19 13:09:22 -070087 setPowerMode(args.initialPowerMode);
Alec Mouriba013fa2018-10-16 12:43:11 -070088
Jesse Hallffe1f192013-03-22 15:13:48 -070089 // initialize the display orientation transform.
Lloyd Pique32cbe282018-10-19 13:09:22 -070090 setProjection(DisplayState::eOrientationDefault, Rect::INVALID_RECT, Rect::INVALID_RECT);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080091}
92
Lloyd Pique09594832018-01-22 17:48:03 -080093DisplayDevice::~DisplayDevice() = default;
Mathias Agopian92a979a2012-08-02 18:32:23 -070094
Lloyd Pique45a165a2018-10-19 11:54:47 -070095void DisplayDevice::disconnect() {
96 mCompositionDisplay->disconnect();
Jesse Hall02d86562013-03-25 14:43:23 -070097}
98
Mathias Agopian0f2f5ff2012-07-31 23:09:07 -070099int DisplayDevice::getWidth() const {
Lloyd Pique32cbe282018-10-19 13:09:22 -0700100 return mCompositionDisplay->getState().bounds.getWidth();
Mathias Agopiana4912602012-07-12 14:25:33 -0700101}
102
Mathias Agopian0f2f5ff2012-07-31 23:09:07 -0700103int DisplayDevice::getHeight() const {
Lloyd Pique32cbe282018-10-19 13:09:22 -0700104 return mCompositionDisplay->getState().bounds.getHeight();
Mathias Agopiana4912602012-07-12 14:25:33 -0700105}
106
Dominik Laskowskibf170d92018-04-19 15:08:05 -0700107void DisplayDevice::setDisplayName(const std::string& displayName) {
108 if (!displayName.empty()) {
Mathias Agopian9e2463e2012-09-21 18:26:16 -0700109 // never override the name with an empty name
110 mDisplayName = displayName;
Lloyd Pique32cbe282018-10-19 13:09:22 -0700111 mCompositionDisplay->setName(displayName);
Mathias Agopian9e2463e2012-09-21 18:26:16 -0700112 }
113}
114
Mathias Agopian0f2f5ff2012-07-31 23:09:07 -0700115uint32_t DisplayDevice::getPageFlipCount() const {
Lloyd Pique31cb2942018-10-19 17:23:03 -0700116 return mCompositionDisplay->getRenderSurface()->getPageFlipCount();
Dan Stoza9e56aa02015-11-02 13:00:03 -0800117}
Dan Stoza9e56aa02015-11-02 13:00:03 -0800118
Mathias Agopian1b031492012-06-20 17:51:20 -0700119// ----------------------------------------------------------------------------
120
Mathias Agopian13127d82013-03-05 17:47:11 -0800121void DisplayDevice::setVisibleLayersSortedByZ(const Vector< sp<Layer> >& layers) {
Mathias Agopian3b1d2b62012-07-11 13:48:17 -0700122 mVisibleLayersSortedByZ = layers;
Mathias Agopian3b1d2b62012-07-11 13:48:17 -0700123}
124
Mathias Agopian13127d82013-03-05 17:47:11 -0800125const Vector< sp<Layer> >& DisplayDevice::getVisibleLayersSortedByZ() const {
Mathias Agopian3b1d2b62012-07-11 13:48:17 -0700126 return mVisibleLayersSortedByZ;
127}
128
Chia-I Wu83806892017-11-16 10:50:20 -0800129void DisplayDevice::setLayersNeedingFences(const Vector< sp<Layer> >& layers) {
130 mLayersNeedingFences = layers;
131}
132
133const Vector< sp<Layer> >& DisplayDevice::getLayersNeedingFences() const {
134 return mLayersNeedingFences;
135}
136
Mathias Agopian3b1d2b62012-07-11 13:48:17 -0700137// ----------------------------------------------------------------------------
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700138void DisplayDevice::setPowerMode(int mode) {
139 mPowerMode = mode;
Lloyd Pique32cbe282018-10-19 13:09:22 -0700140 getCompositionDisplay()->setCompositionEnabled(mPowerMode != HWC_POWER_MODE_OFF);
Mathias Agopiand3ee2312012-08-02 14:01:42 -0700141}
142
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700143int DisplayDevice::getPowerMode() const {
144 return mPowerMode;
Mathias Agopiand3ee2312012-08-02 14:01:42 -0700145}
146
Dominik Laskowskieecd6592018-05-29 10:25:41 -0700147bool DisplayDevice::isPoweredOn() const {
148 return mPowerMode != HWC_POWER_MODE_OFF;
Mathias Agopiand3ee2312012-08-02 14:01:42 -0700149}
150
151// ----------------------------------------------------------------------------
Michael Lentine6c9e34a2014-07-14 13:48:55 -0700152void DisplayDevice::setActiveConfig(int mode) {
153 mActiveConfig = mode;
154}
155
156int DisplayDevice::getActiveConfig() const {
157 return mActiveConfig;
158}
159
160// ----------------------------------------------------------------------------
Yiwei Zhang7c64f172018-03-07 14:52:28 -0800161
Peiyong Lindd9b2ae2018-03-01 16:22:45 -0800162ui::Dataspace DisplayDevice::getCompositionDataSpace() const {
Lloyd Pique32cbe282018-10-19 13:09:22 -0700163 return mCompositionDisplay->getState().dataspace;
Peiyong Lindd9b2ae2018-03-01 16:22:45 -0800164}
165
Michael Wright28f24d02016-07-12 13:30:53 -0700166// ----------------------------------------------------------------------------
Mathias Agopiand3ee2312012-08-02 14:01:42 -0700167
Mathias Agopian28947d72012-08-08 18:51:15 -0700168void DisplayDevice::setLayerStack(uint32_t stack) {
Lloyd Pique32cbe282018-10-19 13:09:22 -0700169 mCompositionDisplay->setLayerStackFilter(!isPrimary(), stack);
Mathias Agopian28947d72012-08-08 18:51:15 -0700170}
171
172// ----------------------------------------------------------------------------
173
Lloyd Pique32cbe282018-10-19 13:09:22 -0700174uint32_t DisplayDevice::displayStateOrientationToTransformOrientation(int orientation) {
Mathias Agopian1b031492012-06-20 17:51:20 -0700175 switch (orientation) {
Mathias Agopian3165cc22012-08-08 19:42:09 -0700176 case DisplayState::eOrientationDefault:
Lloyd Pique32cbe282018-10-19 13:09:22 -0700177 return ui::Transform::ROT_0;
Mathias Agopian3165cc22012-08-08 19:42:09 -0700178 case DisplayState::eOrientation90:
Lloyd Pique32cbe282018-10-19 13:09:22 -0700179 return ui::Transform::ROT_90;
Mathias Agopian3165cc22012-08-08 19:42:09 -0700180 case DisplayState::eOrientation180:
Lloyd Pique32cbe282018-10-19 13:09:22 -0700181 return ui::Transform::ROT_180;
Mathias Agopian3165cc22012-08-08 19:42:09 -0700182 case DisplayState::eOrientation270:
Lloyd Pique32cbe282018-10-19 13:09:22 -0700183 return ui::Transform::ROT_270;
Mathias Agopian1b031492012-06-20 17:51:20 -0700184 default:
Lloyd Pique32cbe282018-10-19 13:09:22 -0700185 return ui::Transform::ROT_INVALID;
186 }
187}
188
189status_t DisplayDevice::orientationToTransfrom(int orientation, int w, int h, ui::Transform* tr) {
190 uint32_t flags = displayStateOrientationToTransformOrientation(orientation);
191 if (flags == ui::Transform::ROT_INVALID) {
Mathias Agopian1b031492012-06-20 17:51:20 -0700192 return BAD_VALUE;
193 }
194 tr->set(flags, w, h);
195 return NO_ERROR;
196}
197
Michael Lentine47e45402014-07-18 15:34:25 -0700198void DisplayDevice::setDisplaySize(const int newWidth, const int newHeight) {
Lloyd Pique31cb2942018-10-19 17:23:03 -0700199 mCompositionDisplay->setBounds(ui::Size(newWidth, newHeight));
Michael Lentine47e45402014-07-18 15:34:25 -0700200}
201
Mathias Agopian00e8c7a2012-09-04 19:30:46 -0700202void DisplayDevice::setProjection(int orientation,
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800203 const Rect& newViewport, const Rect& newFrame) {
204 Rect viewport(newViewport);
205 Rect frame(newFrame);
206
Lloyd Pique32cbe282018-10-19 13:09:22 -0700207 mOrientation = orientation;
208
209 const Rect& displayBounds = getCompositionDisplay()->getState().bounds;
210 const int w = displayBounds.width();
211 const int h = displayBounds.height();
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800212
Peiyong Linefefaac2018-08-17 12:27:51 -0700213 ui::Transform R;
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800214 DisplayDevice::orientationToTransfrom(orientation, w, h, &R);
215
216 if (!frame.isValid()) {
217 // the destination frame can be invalid if it has never been set,
218 // in that case we assume the whole display frame.
219 frame = Rect(w, h);
220 }
221
222 if (viewport.isEmpty()) {
223 // viewport can be invalid if it has never been set, in that case
224 // we assume the whole display size.
225 // it's also invalid to have an empty viewport, so we handle that
226 // case in the same way.
227 viewport = Rect(w, h);
Peiyong Linefefaac2018-08-17 12:27:51 -0700228 if (R.getOrientation() & ui::Transform::ROT_90) {
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800229 // viewport is always specified in the logical orientation
230 // of the display (ie: post-rotation).
Peiyong Lin3db42342018-08-16 09:15:59 -0700231 std::swap(viewport.right, viewport.bottom);
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800232 }
233 }
234
Peiyong Linefefaac2018-08-17 12:27:51 -0700235 ui::Transform TL, TP, S;
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800236 float src_width = viewport.width();
237 float src_height = viewport.height();
238 float dst_width = frame.width();
239 float dst_height = frame.height();
240 if (src_width != dst_width || src_height != dst_height) {
241 float sx = dst_width / src_width;
242 float sy = dst_height / src_height;
243 S.set(sx, 0, 0, sy);
244 }
245
246 float src_x = viewport.left;
247 float src_y = viewport.top;
248 float dst_x = frame.left;
249 float dst_y = frame.top;
250 TL.set(-src_x, -src_y);
251 TP.set(dst_x, dst_y);
252
Lloyd Pique32cbe282018-10-19 13:09:22 -0700253 // need to take care of primary display rotation for globalTransform
Iris Chang7501ed62018-04-30 14:45:42 +0800254 // for case if the panel is not installed aligned with device orientation
Dominik Laskowski075d3172018-05-24 15:50:06 -0700255 if (isPrimary()) {
Iris Chang7501ed62018-04-30 14:45:42 +0800256 DisplayDevice::orientationToTransfrom(
Chia-I Wua02871c2018-08-27 14:38:23 -0700257 (orientation + mDisplayInstallOrientation) % (DisplayState::eOrientation270 + 1),
Iris Chang7501ed62018-04-30 14:45:42 +0800258 w, h, &R);
259 }
260
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800261 // The viewport and frame are both in the logical orientation.
262 // Apply the logical translation, scale to physical size, apply the
263 // physical translation and finally rotate to the physical orientation.
Lloyd Pique32cbe282018-10-19 13:09:22 -0700264 ui::Transform globalTransform = R * TP * S * TL;
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800265
Lloyd Pique32cbe282018-10-19 13:09:22 -0700266 const uint8_t type = globalTransform.getType();
267 const bool needsFiltering =
268 (!globalTransform.preserveRects() || (type >= ui::Transform::SCALE));
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800269
Lloyd Pique32cbe282018-10-19 13:09:22 -0700270 Rect scissor = globalTransform.transform(viewport);
271 if (scissor.isEmpty()) {
272 scissor = displayBounds;
Mathias Agopianf5f714a2013-02-26 16:54:05 -0800273 }
274
Dominik Laskowski281644e2018-04-19 15:47:35 -0700275 if (isPrimary()) {
Lloyd Pique32cbe282018-10-19 13:09:22 -0700276 sPrimaryDisplayOrientation = displayStateOrientationToTransformOrientation(orientation);
Pablo Ceballos021623b2016-04-15 17:31:51 -0700277 }
Lloyd Pique32cbe282018-10-19 13:09:22 -0700278
279 getCompositionDisplay()->setProjection(globalTransform,
280 displayStateOrientationToTransformOrientation(
281 orientation),
282 frame, viewport, scissor, needsFiltering);
Mathias Agopian1b031492012-06-20 17:51:20 -0700283}
Mathias Agopian1d12d8a2012-09-18 01:38:00 -0700284
Pablo Ceballos021623b2016-04-15 17:31:51 -0700285uint32_t DisplayDevice::getPrimaryDisplayOrientationTransform() {
286 return sPrimaryDisplayOrientation;
287}
288
Dominik Laskowski9b17b2c22018-11-01 14:49:03 -0700289std::string DisplayDevice::getDebugName() const {
Lloyd Pique45a165a2018-10-19 11:54:47 -0700290 const auto id = getId() ? to_string(*getId()) + ", " : std::string();
Dominik Laskowski9b17b2c22018-11-01 14:49:03 -0700291 return base::StringPrintf("DisplayDevice{%s%s%s\"%s\"}", id.c_str(),
292 isPrimary() ? "primary, " : "", isVirtual() ? "virtual, " : "",
293 mDisplayName.c_str());
294}
295
Yiwei Zhang5434a782018-12-05 18:06:32 -0800296void DisplayDevice::dump(std::string& result) const {
Yiwei Zhang5434a782018-12-05 18:06:32 -0800297 StringAppendF(&result, "+ %s\n", getDebugName().c_str());
Lloyd Pique32cbe282018-10-19 13:09:22 -0700298
299 result.append(" ");
Lloyd Pique32cbe282018-10-19 13:09:22 -0700300 StringAppendF(&result, "powerMode=%d, ", mPowerMode);
301 StringAppendF(&result, "activeConfig=%d, ", mActiveConfig);
302 StringAppendF(&result, "numLayers=%zu\n", mVisibleLayersSortedByZ.size());
303 getCompositionDisplay()->dump(result);
Mathias Agopian1d12d8a2012-09-18 01:38:00 -0700304}
Irvelffc9efc2016-07-27 15:16:37 -0700305
Lloyd Pique3d0c02e2018-10-19 18:38:12 -0700306bool DisplayDevice::hasRenderIntent(ui::RenderIntent intent) const {
307 return mCompositionDisplay->getDisplayColorProfile()->hasRenderIntent(intent);
Peiyong Lin136fbbc2018-04-17 15:09:44 -0700308}
309
Lloyd Pique45a165a2018-10-19 11:54:47 -0700310// ----------------------------------------------------------------------------
311
312const std::optional<DisplayId>& DisplayDevice::getId() const {
313 return mCompositionDisplay->getId();
314}
315
316bool DisplayDevice::isSecure() const {
317 return mCompositionDisplay->isSecure();
318}
319
Lloyd Pique32cbe282018-10-19 13:09:22 -0700320const Rect& DisplayDevice::getBounds() const {
321 return mCompositionDisplay->getState().bounds;
322}
323
324const Region& DisplayDevice::getUndefinedRegion() const {
325 return mCompositionDisplay->getState().undefinedRegion;
326}
327
328bool DisplayDevice::needsFiltering() const {
329 return mCompositionDisplay->getState().needsFiltering;
330}
331
332uint32_t DisplayDevice::getLayerStack() const {
333 return mCompositionDisplay->getState().singleLayerStackId;
334}
335
336const ui::Transform& DisplayDevice::getTransform() const {
337 return mCompositionDisplay->getState().transform;
338}
339
340const Rect& DisplayDevice::getViewport() const {
341 return mCompositionDisplay->getState().viewport;
342}
343
344const Rect& DisplayDevice::getFrame() const {
345 return mCompositionDisplay->getState().frame;
346}
347
348const Rect& DisplayDevice::getScissor() const {
349 return mCompositionDisplay->getState().scissor;
350}
351
Lloyd Pique3d0c02e2018-10-19 18:38:12 -0700352bool DisplayDevice::hasWideColorGamut() const {
353 return mCompositionDisplay->getDisplayColorProfile()->hasWideColorGamut();
354}
355
356bool DisplayDevice::hasHDR10PlusSupport() const {
357 return mCompositionDisplay->getDisplayColorProfile()->hasHDR10PlusSupport();
358}
359
360bool DisplayDevice::hasHDR10Support() const {
361 return mCompositionDisplay->getDisplayColorProfile()->hasHDR10Support();
362}
363
364bool DisplayDevice::hasHLGSupport() const {
365 return mCompositionDisplay->getDisplayColorProfile()->hasHLGSupport();
366}
367
368bool DisplayDevice::hasDolbyVisionSupport() const {
369 return mCompositionDisplay->getDisplayColorProfile()->hasDolbyVisionSupport();
370}
371
372int DisplayDevice::getSupportedPerFrameMetadata() const {
373 return mCompositionDisplay->getDisplayColorProfile()->getSupportedPerFrameMetadata();
374}
375
376const HdrCapabilities& DisplayDevice::getHdrCapabilities() const {
377 return mCompositionDisplay->getDisplayColorProfile()->getHdrCapabilities();
378}
379
Dominik Laskowski663bd282018-04-19 15:26:54 -0700380std::atomic<int32_t> DisplayDeviceState::sNextSequenceId(1);
Peiyong Linfd997e02018-03-28 15:29:00 -0700381
382} // namespace android