| Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 1 |  | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 2 | /* | 
 | 3 |  * Copyright (C) 2007 The Android Open Source Project | 
 | 4 |  * | 
 | 5 |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
 | 6 |  * you may not use this file except in compliance with the License. | 
 | 7 |  * You may obtain a copy of the License at | 
 | 8 |  * | 
 | 9 |  *      http://www.apache.org/licenses/LICENSE-2.0 | 
 | 10 |  * | 
 | 11 |  * Unless required by applicable law or agreed to in writing, software | 
 | 12 |  * distributed under the License is distributed on an "AS IS" BASIS, | 
 | 13 |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
 | 14 |  * See the License for the specific language governing permissions and | 
 | 15 |  * limitations under the License. | 
 | 16 |  */ | 
 | 17 |  | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 18 | #pragma once | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 19 |  | 
| Lloyd Pique | feb73d7 | 2018-12-04 17:23:44 -0800 | [diff] [blame] | 20 | #include <compositionengine/LayerFE.h> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 21 | #include <gui/BufferQueue.h> | 
 | 22 | #include <gui/ISurfaceComposerClient.h> | 
 | 23 | #include <gui/LayerState.h> | 
| chaviw | 3277faf | 2021-05-19 16:45:23 -0500 | [diff] [blame] | 24 | #include <gui/WindowInfo.h> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 25 | #include <layerproto/LayerProtoHeader.h> | 
 | 26 | #include <math/vec4.h> | 
 | 27 | #include <renderengine/Mesh.h> | 
 | 28 | #include <renderengine/Texture.h> | 
| Alec Mouri | 1c8d720 | 2019-06-01 18:51:35 -0700 | [diff] [blame] | 29 | #include <sys/types.h> | 
| Lucas Dupin | c3800b8 | 2020-10-02 16:24:48 -0700 | [diff] [blame] | 30 | #include <ui/BlurRegion.h> | 
| Dan Stoza | 80d6116 | 2017-12-20 15:57:52 -0800 | [diff] [blame] | 31 | #include <ui/FloatRect.h> | 
| Svetoslav | d85084b | 2014-03-20 10:28:31 -0700 | [diff] [blame] | 32 | #include <ui/FrameStats.h> | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 33 | #include <ui/GraphicBuffer.h> | 
 | 34 | #include <ui/PixelFormat.h> | 
 | 35 | #include <ui/Region.h> | 
| John Reck | cdb4ed7 | 2021-02-04 13:39:33 -0500 | [diff] [blame] | 36 | #include <ui/StretchEffect.h> | 
| Peiyong Lin | efefaac | 2018-08-17 12:27:51 -0700 | [diff] [blame] | 37 | #include <ui/Transform.h> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 38 | #include <utils/RefBase.h> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 39 | #include <utils/Timers.h> | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 40 |  | 
| KaiChieh Chuang | 948c642 | 2020-10-13 10:38:48 +0800 | [diff] [blame] | 41 | #include <chrono> | 
| Robert Carr | cdf8320 | 2018-03-07 12:48:34 -0800 | [diff] [blame] | 42 | #include <cstdint> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 43 | #include <list> | 
| Dominik Laskowski | 075d317 | 2018-05-24 15:50:06 -0700 | [diff] [blame] | 44 | #include <optional> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 45 | #include <vector> | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 46 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 47 | #include "Client.h" | 
| Alec Mouri | 1c8d720 | 2019-06-01 18:51:35 -0700 | [diff] [blame] | 48 | #include "ClientCache.h" | 
 | 49 | #include "DisplayHardware/ComposerHal.h" | 
 | 50 | #include "DisplayHardware/HWComposer.h" | 
| Marin Shalamanov | e8a663d | 2020-11-24 17:48:00 +0100 | [diff] [blame] | 51 | #include "Fps.h" | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 52 | #include "FrameTracker.h" | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 53 | #include "LayerVector.h" | 
| Dan Stoza | b9b0883 | 2014-03-13 11:55:57 -0700 | [diff] [blame] | 54 | #include "MonitoredProducer.h" | 
| Alec Mouri | 1c8d720 | 2019-06-01 18:51:35 -0700 | [diff] [blame] | 55 | #include "RenderArea.h" | 
| Ady Abraham | bdda8f0 | 2021-04-01 16:06:11 -0700 | [diff] [blame] | 56 | #include "Scheduler/LayerInfo.h" | 
| Marin Shalamanov | 53fc11d | 2020-11-20 14:00:13 +0100 | [diff] [blame] | 57 | #include "Scheduler/Seamlessness.h" | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 58 | #include "SurfaceFlinger.h" | 
| Marin Shalamanov | 53fc11d | 2020-11-20 14:00:13 +0100 | [diff] [blame] | 59 | #include "SurfaceTracing.h" | 
| Robert Carr | 9a803c3 | 2021-01-14 16:57:58 -0800 | [diff] [blame] | 60 | #include "TransactionCallbackInvoker.h" | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 61 |  | 
| chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 62 | using namespace android::surfaceflinger; | 
 | 63 |  | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 64 | namespace android { | 
 | 65 |  | 
| Mathias Agopian | 1f7bec6 | 2010-06-25 18:02:21 -0700 | [diff] [blame] | 66 | class Client; | 
| Mathias Agopian | 3e25fd8 | 2013-04-22 17:52:16 +0200 | [diff] [blame] | 67 | class Colorizer; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 68 | class DisplayDevice; | 
 | 69 | class GraphicBuffer; | 
 | 70 | class SurfaceFlinger; | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 71 | class LayerDebugInfo; | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 72 |  | 
| Lloyd Pique | feb73d7 | 2018-12-04 17:23:44 -0800 | [diff] [blame] | 73 | namespace compositionengine { | 
| Lloyd Pique | 37c2c9b | 2018-12-04 17:25:10 -0800 | [diff] [blame] | 74 | class OutputLayer; | 
| Lloyd Pique | a83776c | 2019-01-29 18:42:32 -0800 | [diff] [blame] | 75 | struct LayerFECompositionState; | 
| Lloyd Pique | feb73d7 | 2018-12-04 17:23:44 -0800 | [diff] [blame] | 76 | } | 
 | 77 |  | 
| Lloyd Pique | 4dccc41 | 2018-01-22 17:21:36 -0800 | [diff] [blame] | 78 | namespace impl { | 
 | 79 | class SurfaceInterceptor; | 
 | 80 | } | 
 | 81 |  | 
| Ady Abraham | 22c7b5c | 2020-09-22 19:33:40 -0700 | [diff] [blame] | 82 | namespace frametimeline { | 
 | 83 | class SurfaceFrame; | 
 | 84 | } // namespace frametimeline | 
 | 85 |  | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 86 | struct LayerCreationArgs { | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 87 |     LayerCreationArgs(SurfaceFlinger*, sp<Client>, std::string name, uint32_t w, uint32_t h, | 
 | 88 |                       uint32_t flags, LayerMetadata); | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 89 |  | 
 | 90 |     SurfaceFlinger* flinger; | 
| chaviw | de94d0f | 2020-01-22 13:11:25 -0800 | [diff] [blame] | 91 |     const sp<Client> client; | 
| Dominik Laskowski | 87a07e4 | 2019-10-10 20:38:02 -0700 | [diff] [blame] | 92 |     std::string name; | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 93 |     uint32_t w; | 
 | 94 |     uint32_t h; | 
 | 95 |     uint32_t flags; | 
| Evan Rosky | a1f1e15 | 2019-01-24 16:17:46 -0800 | [diff] [blame] | 96 |     LayerMetadata metadata; | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 97 |  | 
| Vishnu Nair | 0f085c6 | 2019-08-30 08:49:12 -0700 | [diff] [blame] | 98 |     pid_t callingPid; | 
 | 99 |     uid_t callingUid; | 
| chaviw | b4c6e58 | 2019-08-16 14:35:07 -0700 | [diff] [blame] | 100 |     uint32_t textureName; | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 101 | }; | 
 | 102 |  | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 103 | class Layer : public virtual RefBase, compositionengine::LayerFE { | 
| Lloyd Pique | f1c675b | 2018-09-12 20:45:39 -0700 | [diff] [blame] | 104 |     static std::atomic<int32_t> sSequence; | 
| Ady Abraham | aae5ed5 | 2020-06-26 09:32:43 -0700 | [diff] [blame] | 105 |     // The following constants represent priority of the window. SF uses this information when | 
 | 106 |     // deciding which window has a priority when deciding about the refresh rate of the screen. | 
 | 107 |     // Priority 0 is considered the highest priority. -1 means that the priority is unset. | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 108 |     static constexpr int32_t PRIORITY_UNSET = -1; | 
| Ady Abraham | aae5ed5 | 2020-06-26 09:32:43 -0700 | [diff] [blame] | 109 |     // Windows that are in focus and voted for the preferred mode ID | 
 | 110 |     static constexpr int32_t PRIORITY_FOCUSED_WITH_MODE = 0; | 
 | 111 |     // // Windows that are in focus, but have not requested a specific mode ID. | 
 | 112 |     static constexpr int32_t PRIORITY_FOCUSED_WITHOUT_MODE = 1; | 
 | 113 |     // Windows that are not in focus, but voted for a specific mode ID. | 
 | 114 |     static constexpr int32_t PRIORITY_NOT_FOCUSED_WITH_MODE = 2; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 115 |  | 
| Mathias Agopian | d606de6 | 2010-05-10 20:06:11 -0700 | [diff] [blame] | 116 | public: | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 117 |     enum { // flags for doTransaction() | 
 | 118 |         eDontUpdateGeometryState = 0x00000001, | 
 | 119 |         eVisibleRegion = 0x00000002, | 
| Robert Carr | 720e506 | 2018-07-30 17:45:14 -0700 | [diff] [blame] | 120 |         eInputInfoChanged = 0x00000004 | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 121 |     }; | 
 | 122 |  | 
 | 123 |     struct Geometry { | 
 | 124 |         uint32_t w; | 
 | 125 |         uint32_t h; | 
| Peiyong Lin | efefaac | 2018-08-17 12:27:51 -0700 | [diff] [blame] | 126 |         ui::Transform transform; | 
| Robert Carr | 3dcabfa | 2016-03-01 18:36:58 -0800 | [diff] [blame] | 127 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 128 |         inline bool operator==(const Geometry& rhs) const { | 
 | 129 |             return (w == rhs.w && h == rhs.h) && (transform.tx() == rhs.transform.tx()) && | 
| Robert Carr | 99e27f0 | 2016-06-16 15:18:02 -0700 | [diff] [blame] | 130 |                     (transform.ty() == rhs.transform.ty()); | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 131 |         } | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 132 |         inline bool operator!=(const Geometry& rhs) const { return !operator==(rhs); } | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 133 |     }; | 
 | 134 |  | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 135 |     struct RoundedCornerState { | 
 | 136 |         RoundedCornerState() = default; | 
 | 137 |         RoundedCornerState(FloatRect cropRect, float radius) | 
 | 138 |               : cropRect(cropRect), radius(radius) {} | 
 | 139 |  | 
 | 140 |         // Rounded rectangle in local layer coordinate space. | 
 | 141 |         FloatRect cropRect = FloatRect(); | 
 | 142 |         // Radius of the rounded rectangle. | 
 | 143 |         float radius = 0.0f; | 
 | 144 |     }; | 
 | 145 |  | 
| Ady Abraham | bdda8f0 | 2021-04-01 16:06:11 -0700 | [diff] [blame] | 146 |     using FrameRate = scheduler::LayerInfo::FrameRate; | 
 | 147 |     using FrameRateCompatibility = scheduler::LayerInfo::FrameRateCompatibility; | 
| Ady Abraham | 71c437d | 2020-01-31 15:56:57 -0800 | [diff] [blame] | 148 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 149 |     struct State { | 
| Marissa Wall | f58c14b | 2018-07-24 10:50:43 -0700 | [diff] [blame] | 150 |         Geometry active_legacy; | 
 | 151 |         Geometry requested_legacy; | 
| Robert Carr | ae06083 | 2016-11-28 10:51:00 -0800 | [diff] [blame] | 152 |         int32_t z; | 
| Fabien Sanglard | f0c53d6 | 2017-03-03 18:58:50 -0800 | [diff] [blame] | 153 |  | 
 | 154 |         // The identifier of the layer stack this layer belongs to. A layer can | 
 | 155 |         // only be associated to a single layer stack. A layer stack is a | 
 | 156 |         // z-ordered group of layers which can be associated to one or more | 
 | 157 |         // displays. Using the same layer stack on different displays is a way | 
 | 158 |         // to achieve mirroring. | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 159 |         uint32_t layerStack; | 
| Fabien Sanglard | f0c53d6 | 2017-03-03 18:58:50 -0800 | [diff] [blame] | 160 |  | 
| Vishnu Nair | f6eddb6 | 2021-01-27 22:02:11 -0800 | [diff] [blame] | 161 |         uint32_t flags; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 162 |         uint8_t reserved[2]; | 
 | 163 |         int32_t sequence; // changes when visible regions can change | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 164 |         bool modified; | 
 | 165 |  | 
| Fabien Sanglard | 4ed383c | 2016-12-13 14:02:41 -0800 | [diff] [blame] | 166 |         // Crop is expressed in layer space coordinate. | 
| chaviw | 2571450 | 2021-02-11 10:01:08 -0800 | [diff] [blame] | 167 |         Rect crop; | 
 | 168 |         Rect requestedCrop; | 
| Robert Carr | 99e27f0 | 2016-06-16 15:18:02 -0700 | [diff] [blame] | 169 |  | 
| Mathias Agopian | 2ca7939 | 2013-04-02 18:30:32 -0700 | [diff] [blame] | 170 |         // the transparentRegion hint is a bit special, it's latched only | 
 | 171 |         // when we receive a buffer -- this is because it's "content" | 
 | 172 |         // dependent. | 
| Marissa Wall | f58c14b | 2018-07-24 10:50:43 -0700 | [diff] [blame] | 173 |         Region activeTransparentRegion_legacy; | 
 | 174 |         Region requestedTransparentRegion_legacy; | 
| Daniel Nicoara | 2f5f8a5 | 2016-12-20 16:11:58 -0500 | [diff] [blame] | 175 |  | 
| Evan Rosky | 1f6d6d5 | 2018-12-06 10:47:26 -0800 | [diff] [blame] | 176 |         LayerMetadata metadata; | 
| Robert Carr | db66e62 | 2017-04-10 16:55:57 -0700 | [diff] [blame] | 177 |  | 
 | 178 |         // If non-null, a Surface this Surface's Z-order is interpreted relative to. | 
 | 179 |         wp<Layer> zOrderRelativeOf; | 
| chaviw | e5ac40f | 2019-09-24 16:36:55 -0700 | [diff] [blame] | 180 |         bool isRelativeOf{false}; | 
| Robert Carr | db66e62 | 2017-04-10 16:55:57 -0700 | [diff] [blame] | 181 |  | 
 | 182 |         // A list of surfaces whose Z-order is interpreted relative to ours. | 
 | 183 |         SortedVector<wp<Layer>> zOrderRelatives; | 
| chaviw | 13fdc49 | 2017-06-27 12:40:18 -0700 | [diff] [blame] | 184 |  | 
 | 185 |         half4 color; | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 186 |         float cornerRadius; | 
| Lucas Dupin | 19c8f0e | 2019-11-25 17:55:44 -0800 | [diff] [blame] | 187 |         int backgroundBlurRadius; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 188 |  | 
| chaviw | 3277faf | 2021-05-19 16:45:23 -0500 | [diff] [blame] | 189 |         gui::WindowInfo inputInfo; | 
| Vishnu Nair | 6fabeec | 2019-03-12 13:42:49 -0700 | [diff] [blame] | 190 |         wp<Layer> touchableRegionCrop; | 
| Robert Carr | 720e506 | 2018-07-30 17:45:14 -0700 | [diff] [blame] | 191 |  | 
| Vishnu Nair | fa247b1 | 2020-02-11 08:58:26 -0800 | [diff] [blame] | 192 |         // dataspace is only used by BufferStateLayer and EffectLayer | 
| Valerie Hau | b153bab | 2019-03-05 10:47:28 -0800 | [diff] [blame] | 193 |         ui::Dataspace dataspace; | 
 | 194 |  | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 195 |         // The fields below this point are only used by BufferStateLayer | 
| Valerie Hau | 134651a | 2020-01-28 16:21:22 -0800 | [diff] [blame] | 196 |         uint64_t frameNumber; | 
| chaviw | 766c9c5 | 2021-02-10 17:36:47 -0800 | [diff] [blame] | 197 |         uint32_t width; | 
 | 198 |         uint32_t height; | 
 | 199 |         ui::Transform transform; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 200 |  | 
| chaviw | 766c9c5 | 2021-02-10 17:36:47 -0800 | [diff] [blame] | 201 |         uint32_t bufferTransform; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 202 |         bool transformToDisplayInverse; | 
 | 203 |  | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 204 |         Region transparentRegionHint; | 
 | 205 |  | 
| Alec Mouri | a90a570 | 2021-04-16 16:36:21 +0000 | [diff] [blame] | 206 |         std::shared_ptr<renderengine::ExternalTexture> buffer; | 
| Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 207 |         client_cache_t clientCacheId; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 208 |         sp<Fence> acquireFence; | 
| Ady Abraham | 6c1b7ac | 2021-03-31 16:56:03 -0700 | [diff] [blame] | 209 |         std::shared_ptr<FenceTime> acquireFenceTime; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 210 |         HdrMetadata hdrMetadata; | 
 | 211 |         Region surfaceDamageRegion; | 
 | 212 |         int32_t api; | 
 | 213 |  | 
 | 214 |         sp<NativeHandle> sidebandStream; | 
| Peiyong Lin | d378863 | 2018-09-18 16:01:31 -0700 | [diff] [blame] | 215 |         mat4 colorTransform; | 
| Peiyong Lin | 747321c | 2018-10-01 10:03:11 -0700 | [diff] [blame] | 216 |         bool hasColorTransform; | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 217 |  | 
| Valerie Hau | a72e281 | 2019-01-23 13:40:39 -0800 | [diff] [blame] | 218 |         // pointer to background color layer that, if set, appears below the buffer state layer | 
 | 219 |         // and the buffer state layer's children.  Z order will be set to | 
 | 220 |         // INT_MIN | 
 | 221 |         sp<Layer> bgColorLayer; | 
| Valerie Hau | ed54efa | 2019-01-11 20:03:14 -0800 | [diff] [blame] | 222 |  | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 223 |         // The deque of callback handles for this frame. The back of the deque contains the most | 
 | 224 |         // recent callback handle. | 
 | 225 |         std::deque<sp<CallbackHandle>> callbackHandles; | 
| Peiyong Lin | c502cb7 | 2019-03-01 15:00:23 -0800 | [diff] [blame] | 226 |         bool colorSpaceAgnostic; | 
| Ady Abraham | f0c5649 | 2020-12-17 18:04:15 -0800 | [diff] [blame] | 227 |         nsecs_t desiredPresentTime = 0; | 
 | 228 |         bool isAutoTimestamp = true; | 
| Vishnu Nair | 08f6eae | 2019-11-26 14:01:39 -0800 | [diff] [blame] | 229 |  | 
 | 230 |         // Length of the cast shadow. If the radius is > 0, a shadow of length shadowRadius will | 
 | 231 |         // be rendered around the layer. | 
| Vishnu Nair | c97b8db | 2019-10-29 18:19:35 -0700 | [diff] [blame] | 232 |         float shadowRadius; | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 233 |  | 
| Lucas Dupin | c3800b8 | 2020-10-02 16:24:48 -0700 | [diff] [blame] | 234 |         // Layer regions that are made of custom materials, like frosted glass | 
 | 235 |         std::vector<BlurRegion> blurRegions; | 
 | 236 |  | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 237 |         // Priority of the layer assigned by Window Manager. | 
 | 238 |         int32_t frameRateSelectionPriority; | 
| Steven Thomas | 3172e20 | 2020-01-06 19:25:30 -0800 | [diff] [blame] | 239 |  | 
| Ady Abraham | 71c437d | 2020-01-31 15:56:57 -0800 | [diff] [blame] | 240 |         FrameRate frameRate; | 
| Ady Abraham | 60e42ea | 2020-03-09 19:17:31 -0700 | [diff] [blame] | 241 |  | 
| Ady Abraham | 59fd8ff | 2021-04-15 20:13:30 -0700 | [diff] [blame] | 242 |         // The combined frame rate of parents / children of this layer | 
 | 243 |         FrameRate frameRateForLayerTree; | 
| Vishnu Nair | 6213bd9 | 2020-05-08 17:42:25 -0700 | [diff] [blame] | 244 |  | 
 | 245 |         // Set by window manager indicating the layer and all its children are | 
 | 246 |         // in a different orientation than the display. The hint suggests that | 
 | 247 |         // the graphic producers should receive a transform hint as if the | 
 | 248 |         // display was in this orientation. When the display changes to match | 
 | 249 |         // the layer orientation, the graphic producer may not need to allocate | 
 | 250 |         // a buffer of a different size. ui::Transform::ROT_INVALID means the | 
 | 251 |         // a fixed transform hint is not set. | 
 | 252 |         ui::Transform::RotationFlags fixedTransformHint; | 
| Ady Abraham | 22c7b5c | 2020-09-22 19:33:40 -0700 | [diff] [blame] | 253 |  | 
| Siarhei Vishniakou | fc434ac | 2021-01-13 10:28:00 -1000 | [diff] [blame] | 254 |         // The vsync info that was used to start the transaction | 
 | 255 |         FrameTimelineInfo frameTimelineInfo; | 
| Ady Abraham | 22c7b5c | 2020-09-22 19:33:40 -0700 | [diff] [blame] | 256 |  | 
 | 257 |         // When the transaction was posted | 
 | 258 |         nsecs_t postTime; | 
| Adithya Srinivasan | b9a7dab | 2021-01-14 23:49:46 +0000 | [diff] [blame] | 259 |  | 
| Vishnu Nair | 1506b18 | 2021-02-22 14:35:15 -0800 | [diff] [blame] | 260 |         sp<ITransactionCompletedListener> releaseBufferListener; | 
| Adithya Srinivasan | b9a7dab | 2021-01-14 23:49:46 +0000 | [diff] [blame] | 261 |         // SurfaceFrame that tracks the timeline of Transactions that contain a Buffer. Only one | 
 | 262 |         // such SurfaceFrame exists because only one buffer can be presented on the layer per vsync. | 
 | 263 |         // If multiple buffers are queued, the prior ones will be dropped, along with the | 
 | 264 |         // SurfaceFrame that's tracking them. | 
 | 265 |         std::shared_ptr<frametimeline::SurfaceFrame> bufferSurfaceFrameTX; | 
 | 266 |         // A map of token(frametimelineVsyncId) to the SurfaceFrame that's tracking a transaction | 
 | 267 |         // that contains the token. Only one SurfaceFrame exisits for transactions that share the | 
 | 268 |         // same token, unless they are presented in different vsyncs. | 
 | 269 |         std::unordered_map<int64_t, std::shared_ptr<frametimeline::SurfaceFrame>> | 
 | 270 |                 bufferlessSurfaceFramesTX; | 
 | 271 |         // An arbitrary threshold for the number of BufferlessSurfaceFrames in the state. Used to | 
 | 272 |         // trigger a warning if the number of SurfaceFrames crosses the threshold. | 
 | 273 |         static constexpr uint32_t kStateSurfaceFramesThreshold = 25; | 
| John Reck | cdb4ed7 | 2021-02-04 13:39:33 -0500 | [diff] [blame] | 274 |  | 
 | 275 |         // Stretch effect to apply to this layer | 
 | 276 |         StretchEffect stretchEffect; | 
| chaviw | f3f40fe | 2021-04-27 15:54:02 -0500 | [diff] [blame] | 277 |  | 
| Winson Chung | a30f7c9 | 2021-06-29 15:42:56 -0700 | [diff] [blame] | 278 |         // Whether or not this layer is a trusted overlay for input | 
 | 279 |         bool isTrustedOverlay; | 
 | 280 |  | 
| chaviw | f3f40fe | 2021-04-27 15:54:02 -0500 | [diff] [blame] | 281 |         Rect bufferCrop; | 
| Vishnu Nair | 6bdec7d | 2021-05-10 15:01:13 -0700 | [diff] [blame] | 282 |         Rect destinationFrame; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 283 |     }; | 
 | 284 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 285 |     /* | 
 | 286 |      * Trivial class, used to ensure that mFlinger->onLayerDestroyed(mLayer) | 
 | 287 |      * is called. | 
 | 288 |      */ | 
 | 289 |     class LayerCleaner { | 
 | 290 |         sp<SurfaceFlinger> mFlinger; | 
 | 291 |         sp<Layer> mLayer; | 
 | 292 |  | 
 | 293 |     protected: | 
 | 294 |         ~LayerCleaner() { | 
 | 295 |             // destroy client resources | 
 | 296 |             mFlinger->onHandleDestroyed(mLayer); | 
 | 297 |         } | 
 | 298 |  | 
 | 299 |     public: | 
 | 300 |         LayerCleaner(const sp<SurfaceFlinger>& flinger, const sp<Layer>& layer) | 
 | 301 |               : mFlinger(flinger), mLayer(layer) {} | 
 | 302 |     }; | 
 | 303 |  | 
 | 304 |     /* | 
 | 305 |      * The layer handle is just a BBinder object passed to the client | 
 | 306 |      * (remote process) -- we don't keep any reference on our side such that | 
 | 307 |      * the dtor is called when the remote side let go of its reference. | 
 | 308 |      * | 
 | 309 |      * LayerCleaner ensures that mFlinger->onLayerDestroyed() is called for | 
 | 310 |      * this layer when the handle is destroyed. | 
 | 311 |      */ | 
 | 312 |     class Handle : public BBinder, public LayerCleaner { | 
 | 313 |     public: | 
 | 314 |         Handle(const sp<SurfaceFlinger>& flinger, const sp<Layer>& layer) | 
 | 315 |               : LayerCleaner(flinger, layer), owner(layer) {} | 
 | 316 |  | 
 | 317 |         wp<Layer> owner; | 
 | 318 |     }; | 
 | 319 |  | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 320 |     explicit Layer(const LayerCreationArgs& args); | 
| Mathias Agopian | b7e930d | 2010-06-01 15:12:58 -0700 | [diff] [blame] | 321 |     virtual ~Layer(); | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 322 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 323 |     static bool isLayerFocusedBasedOnPriority(int32_t priority); | 
 | 324 |     static void miniDumpHeader(std::string& result); | 
 | 325 |     static std::string frameRateCompatibilityString(FrameRateCompatibility compatibility); | 
| Dominik Laskowski | 7584836 | 2019-11-11 17:57:20 -0800 | [diff] [blame] | 326 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 327 |     // Provide unique string for each class type in the Layer hierarchy | 
 | 328 |     virtual const char* getType() const = 0; | 
| Dominik Laskowski | f7a09ed | 2019-10-07 13:54:18 -0700 | [diff] [blame] | 329 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 330 |     // true if this layer is visible, false otherwise | 
 | 331 |     virtual bool isVisible() const = 0; | 
| Chia-I Wu | ab0c319 | 2017-08-01 11:29:00 -0700 | [diff] [blame] | 332 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 333 |     virtual sp<Layer> createClone() = 0; | 
 | 334 |  | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 335 |     // Geometry setting functions. | 
 | 336 |     // | 
 | 337 |     // The following group of functions are used to specify the layers | 
 | 338 |     // bounds, and the mapping of the texture on to those bounds. According | 
 | 339 |     // to various settings changes to them may apply immediately, or be delayed until | 
 | 340 |     // a pending resize is completed by the producer submitting a buffer. For example | 
 | 341 |     // if we were to change the buffer size, and update the matrix ahead of the | 
 | 342 |     // new buffer arriving, then we would be stretching the buffer to a different | 
 | 343 |     // aspect before and after the buffer arriving, which probably isn't what we wanted. | 
 | 344 |     // | 
 | 345 |     // The first set of geometry functions are controlled by the scaling mode, described | 
 | 346 |     // in window.h. The scaling mode may be set by the client, as it submits buffers. | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 347 |     // | 
 | 348 |     // Put simply, if our scaling mode is SCALING_MODE_FREEZE, then | 
 | 349 |     // matrix updates will not be applied while a resize is pending | 
 | 350 |     // and the size and transform will remain in their previous state | 
 | 351 |     // until a new buffer is submitted. If the scaling mode is another value | 
 | 352 |     // then the old-buffer will immediately be scaled to the pending size | 
 | 353 |     // and the new matrix will be immediately applied following this scaling | 
 | 354 |     // transformation. | 
| Robert Carr | 8d5227b | 2017-03-16 15:41:03 -0700 | [diff] [blame] | 355 |  | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 356 |     // Set the default buffer size for the assosciated Producer, in pixels. This is | 
 | 357 |     // also the rendered size of the layer prior to any transformations. Parent | 
 | 358 |     // or local matrix transformations will not affect the size of the buffer, | 
 | 359 |     // but may affect it's on-screen size or clipping. | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 360 |     virtual bool setSize(uint32_t w, uint32_t h); | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 361 |     // Set a 2x2 transformation matrix on the layer. This transform | 
 | 362 |     // will be applied after parent transforms, but before any final | 
 | 363 |     // producer specified transform. | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 364 |     virtual bool setMatrix(const layer_state_t::matrix22_t& matrix, | 
 | 365 |                            bool allowNonRectPreservingTransforms); | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 366 |  | 
 | 367 |     // This second set of geometry attributes are controlled by | 
 | 368 |     // setGeometryAppliesWithResize, and their default mode is to be | 
 | 369 |     // immediate. If setGeometryAppliesWithResize is specified | 
 | 370 |     // while a resize is pending, then update of these attributes will | 
 | 371 |     // be delayed until the resize completes. | 
 | 372 |  | 
 | 373 |     // setPosition operates in parent buffer space (pre parent-transform) or display | 
 | 374 |     // space for top-level layers. | 
| chaviw | 214c89d | 2019-09-04 16:03:53 -0700 | [diff] [blame] | 375 |     virtual bool setPosition(float x, float y); | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 376 |     // Buffer space | 
| chaviw | 2571450 | 2021-02-11 10:01:08 -0800 | [diff] [blame] | 377 |     virtual bool setCrop(const Rect& crop); | 
| Robert Carr | 8d5227b | 2017-03-16 15:41:03 -0700 | [diff] [blame] | 378 |  | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 379 |     // TODO(b/38182121): Could we eliminate the various latching modes by | 
 | 380 |     // using the layer hierarchy? | 
 | 381 |     // ----------------------------------------------------------------------- | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 382 |     virtual bool setLayer(int32_t z); | 
 | 383 |     virtual bool setRelativeLayer(const sp<IBinder>& relativeToHandle, int32_t relativeZ); | 
| Robert Carr | db66e62 | 2017-04-10 16:55:57 -0700 | [diff] [blame] | 384 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 385 |     virtual bool setAlpha(float alpha); | 
| Valerie Hau | dd0b757 | 2019-01-29 14:59:27 -0800 | [diff] [blame] | 386 |     virtual bool setColor(const half3& /*color*/) { return false; }; | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 387 |  | 
 | 388 |     // Set rounded corner radius for this layer and its children. | 
 | 389 |     // | 
 | 390 |     // We only support 1 radius per layer in the hierarchy, where parent layers have precedence. | 
 | 391 |     // The shape of the rounded corner rectangle is specified by the crop rectangle of the layer | 
 | 392 |     // from which we inferred the rounded corner radius. | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 393 |     virtual bool setCornerRadius(float cornerRadius); | 
| Lucas Dupin | 19c8f0e | 2019-11-25 17:55:44 -0800 | [diff] [blame] | 394 |     // When non-zero, everything below this layer will be blurred by backgroundBlurRadius, which | 
 | 395 |     // is specified in pixels. | 
 | 396 |     virtual bool setBackgroundBlurRadius(int backgroundBlurRadius); | 
| Lucas Dupin | c3800b8 | 2020-10-02 16:24:48 -0700 | [diff] [blame] | 397 |     virtual bool setBlurRegions(const std::vector<BlurRegion>& effectRegions); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 398 |     virtual bool setTransparentRegionHint(const Region& transparent); | 
| Winson Chung | a30f7c9 | 2021-06-29 15:42:56 -0700 | [diff] [blame] | 399 |     virtual bool setTrustedOverlay(bool); | 
| Vishnu Nair | f6eddb6 | 2021-01-27 22:02:11 -0800 | [diff] [blame] | 400 |     virtual bool setFlags(uint32_t flags, uint32_t mask); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 401 |     virtual bool setLayerStack(uint32_t layerStack); | 
 | 402 |     virtual uint32_t getLayerStack() const; | 
| Evan Rosky | ef876c9 | 2019-01-25 17:46:06 -0800 | [diff] [blame] | 403 |     virtual bool setMetadata(const LayerMetadata& data); | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 404 |     virtual void setChildrenDrawingParent(const sp<Layer>&); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 405 |     virtual bool reparent(const sp<IBinder>& newParentHandle); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 406 |     virtual bool setColorTransform(const mat4& matrix); | 
 | 407 |     virtual mat4 getColorTransform() const; | 
 | 408 |     virtual bool hasColorTransform() const; | 
| Peiyong Lin | c502cb7 | 2019-03-01 15:00:23 -0800 | [diff] [blame] | 409 |     virtual bool isColorSpaceAgnostic() const { return mDrawingState.colorSpaceAgnostic; } | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 410 |  | 
 | 411 |     // Used only to set BufferStateLayer state | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 412 |     virtual bool setTransform(uint32_t /*transform*/) { return false; }; | 
 | 413 |     virtual bool setTransformToDisplayInverse(bool /*transformToDisplayInverse*/) { return false; }; | 
| Alec Mouri | a90a570 | 2021-04-16 16:36:21 +0000 | [diff] [blame] | 414 |     virtual bool setBuffer(const std::shared_ptr<renderengine::ExternalTexture>& /*buffer*/, | 
 | 415 |                            const sp<Fence>& /*acquireFence*/, nsecs_t /*postTime*/, | 
 | 416 |                            nsecs_t /*desiredPresentTime*/, bool /*isAutoTimestamp*/, | 
 | 417 |                            const client_cache_t& /*clientCacheId*/, uint64_t /* frameNumber */, | 
 | 418 |                            std::optional<nsecs_t> /* dequeueTime */, | 
| Vishnu Nair | 1506b18 | 2021-02-22 14:35:15 -0800 | [diff] [blame] | 419 |                            const FrameTimelineInfo& /*info*/, | 
 | 420 |                            const sp<ITransactionCompletedListener>& /* releaseBufferListener */) { | 
| Ady Abraham | 09bd392 | 2019-04-08 10:44:56 -0700 | [diff] [blame] | 421 |         return false; | 
| Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 422 |     }; | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 423 |     virtual bool setAcquireFence(const sp<Fence>& /*fence*/) { return false; }; | 
 | 424 |     virtual bool setDataspace(ui::Dataspace /*dataspace*/) { return false; }; | 
 | 425 |     virtual bool setHdrMetadata(const HdrMetadata& /*hdrMetadata*/) { return false; }; | 
 | 426 |     virtual bool setSurfaceDamageRegion(const Region& /*surfaceDamage*/) { return false; }; | 
 | 427 |     virtual bool setApi(int32_t /*api*/) { return false; }; | 
 | 428 |     virtual bool setSidebandStream(const sp<NativeHandle>& /*sidebandStream*/) { return false; }; | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 429 |     virtual bool setTransactionCompletedListeners( | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 430 |             const std::vector<sp<CallbackHandle>>& /*handles*/) { | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 431 |         return false; | 
 | 432 |     }; | 
| Valerie Hau | 871d635 | 2020-01-29 08:44:02 -0800 | [diff] [blame] | 433 |     virtual bool addFrameEvent(const sp<Fence>& /*acquireFence*/, nsecs_t /*postedTime*/, | 
 | 434 |                                nsecs_t /*requestedPresentTime*/) { | 
 | 435 |         return false; | 
 | 436 |     } | 
| Valerie Hau | dd0b757 | 2019-01-29 14:59:27 -0800 | [diff] [blame] | 437 |     virtual bool setBackgroundColor(const half3& color, float alpha, ui::Dataspace dataspace); | 
| Peiyong Lin | c502cb7 | 2019-03-01 15:00:23 -0800 | [diff] [blame] | 438 |     virtual bool setColorSpaceAgnostic(const bool agnostic); | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 439 |     virtual bool setFrameRateSelectionPriority(int32_t priority); | 
| Vishnu Nair | 6213bd9 | 2020-05-08 17:42:25 -0700 | [diff] [blame] | 440 |     virtual bool setFixedTransformHint(ui::Transform::RotationFlags fixedTransformHint); | 
| Vishnu Nair | cf26a0a | 2020-11-13 12:56:20 -0800 | [diff] [blame] | 441 |     virtual void setAutoRefresh(bool /* autoRefresh */) {} | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 442 |     //  If the variable is not set on the layer, it traverses up the tree to inherit the frame | 
 | 443 |     //  rate priority from its parent. | 
 | 444 |     virtual int32_t getFrameRateSelectionPriority() const; | 
| chaviw | 4244e03 | 2019-09-04 11:27:49 -0700 | [diff] [blame] | 445 |     virtual ui::Dataspace getDataSpace() const { return ui::Dataspace::UNKNOWN; } | 
| Chia-I Wu | 01591c9 | 2018-05-22 12:03:00 -0700 | [diff] [blame] | 446 |  | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 447 |     virtual sp<compositionengine::LayerFE> getCompositionEngineLayerFE() const; | 
 | 448 |     virtual compositionengine::LayerFECompositionState* editCompositionState(); | 
| Lloyd Pique | feb73d7 | 2018-12-04 17:23:44 -0800 | [diff] [blame] | 449 |  | 
| Dan Stoza | ee44edd | 2015-03-23 15:50:23 -0700 | [diff] [blame] | 450 |     // If we have received a new buffer this frame, we will pass its surface | 
 | 451 |     // damage down to hardware composer. Otherwise, we must send a region with | 
 | 452 |     // one empty rect. | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 453 |     virtual void useSurfaceDamage() {} | 
 | 454 |     virtual void useEmptyDamage() {} | 
| Alec Mouri | adebf5c | 2021-01-05 12:57:36 -0800 | [diff] [blame] | 455 |     Region getVisibleRegion(const DisplayDevice*) const; | 
| Dan Stoza | ee44edd | 2015-03-23 15:50:23 -0700 | [diff] [blame] | 456 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 457 |     /* | 
 | 458 |      * isOpaque - true if this surface is opaque | 
 | 459 |      * | 
 | 460 |      * This takes into account the buffer format (i.e. whether or not the | 
 | 461 |      * pixel format includes an alpha channel) and the "opaque" flag set | 
 | 462 |      * on the layer.  It does not examine the current plane alpha value. | 
 | 463 |      */ | 
 | 464 |     virtual bool isOpaque(const Layer::State&) const { return false; } | 
 | 465 |  | 
 | 466 |     /* | 
 | 467 |      * Returns whether this layer can receive input. | 
 | 468 |      */ | 
 | 469 |     virtual bool canReceiveInput() const; | 
 | 470 |  | 
 | 471 |     /* | 
| Peiyong Lin | 05cc011 | 2020-10-14 16:16:37 -0700 | [diff] [blame] | 472 |      * isProtected - true if the layer may contain protected contents in the | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 473 |      * GRALLOC_USAGE_PROTECTED sense. | 
 | 474 |      */ | 
 | 475 |     virtual bool isProtected() const { return false; } | 
 | 476 |  | 
 | 477 |     /* | 
 | 478 |      * isFixedSize - true if content has a fixed size | 
 | 479 |      */ | 
 | 480 |     virtual bool isFixedSize() const { return true; } | 
 | 481 |  | 
 | 482 |     /* | 
 | 483 |      * usesSourceCrop - true if content should use a source crop | 
 | 484 |      */ | 
 | 485 |     virtual bool usesSourceCrop() const { return false; } | 
 | 486 |  | 
 | 487 |     // Most layers aren't created from the main thread, and therefore need to | 
 | 488 |     // grab the SF state lock to access HWC, but ContainerLayer does, so we need | 
 | 489 |     // to avoid grabbing the lock again to avoid deadlock | 
 | 490 |     virtual bool isCreatedFromMainThread() const { return false; } | 
 | 491 |  | 
| chaviw | 4e76553 | 2021-04-30 12:11:39 -0500 | [diff] [blame] | 492 |     uint32_t getActiveWidth(const Layer::State& s) const { return s.width; } | 
 | 493 |     uint32_t getActiveHeight(const Layer::State& s) const { return s.height; } | 
 | 494 |     ui::Transform getActiveTransform(const Layer::State& s) const { return s.transform; } | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 495 |     virtual Region getActiveTransparentRegion(const Layer::State& s) const { | 
 | 496 |         return s.activeTransparentRegion_legacy; | 
 | 497 |     } | 
| chaviw | 2571450 | 2021-02-11 10:01:08 -0800 | [diff] [blame] | 498 |     virtual Rect getCrop(const Layer::State& s) const { return s.crop; } | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 499 |     virtual bool needsFiltering(const DisplayDevice*) const { return false; } | 
 | 500 |  | 
 | 501 |     // True if this layer requires filtering | 
 | 502 |     // This method is distinct from needsFiltering() in how the filter | 
 | 503 |     // requirement is computed. needsFiltering() compares displayFrame and crop, | 
 | 504 |     // where as this method transforms the displayFrame to layer-stack space | 
 | 505 |     // first. This method should be used if there is no physical display to | 
 | 506 |     // project onto when taking screenshots, as the filtering requirements are | 
 | 507 |     // different. | 
 | 508 |     // If the parent transform needs to be undone when capturing the layer, then | 
 | 509 |     // the inverse parent transform is also required. | 
 | 510 |     virtual bool needsFilteringForScreenshots(const DisplayDevice*, const ui::Transform&) const { | 
 | 511 |         return false; | 
 | 512 |     } | 
 | 513 |  | 
 | 514 |     virtual void updateCloneBufferInfo(){}; | 
 | 515 |  | 
 | 516 |     virtual void setDefaultBufferSize(uint32_t /*w*/, uint32_t /*h*/) {} | 
 | 517 |  | 
 | 518 |     virtual bool isHdrY410() const { return false; } | 
 | 519 |  | 
 | 520 |     virtual bool shouldPresentNow(nsecs_t /*expectedPresentTime*/) const { return false; } | 
 | 521 |  | 
| Vishnu Nair | 6b7c5c9 | 2020-09-29 17:27:05 -0700 | [diff] [blame] | 522 |     virtual uint64_t getHeadFrameNumber(nsecs_t /* expectedPresentTime */) const { return 0; } | 
 | 523 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 524 |     /* | 
 | 525 |      * called after composition. | 
 | 526 |      * returns true if the layer latched a new buffer this frame. | 
 | 527 |      */ | 
 | 528 |     virtual bool onPostComposition(const DisplayDevice*, | 
 | 529 |                                    const std::shared_ptr<FenceTime>& /*glDoneFence*/, | 
 | 530 |                                    const std::shared_ptr<FenceTime>& /*presentFence*/, | 
 | 531 |                                    const CompositorTiming&) { | 
 | 532 |         return false; | 
 | 533 |     } | 
 | 534 |  | 
 | 535 |     // If a buffer was replaced this frame, release the former buffer | 
 | 536 |     virtual void releasePendingBuffer(nsecs_t /*dequeueReadyTime*/) { } | 
 | 537 |  | 
 | 538 |     virtual void finalizeFrameEventHistory(const std::shared_ptr<FenceTime>& /*glDoneFence*/, | 
 | 539 |                                            const CompositorTiming& /*compositorTiming*/) {} | 
 | 540 |  | 
 | 541 |     /* | 
 | 542 |      * latchBuffer - called each time the screen is redrawn and returns whether | 
 | 543 |      * the visible regions need to be recomputed (this is a fairly heavy | 
 | 544 |      * operation, so this should be set only if needed). Typically this is used | 
 | 545 |      * to figure out if the content or size of a surface has changed. | 
 | 546 |      */ | 
 | 547 |     virtual bool latchBuffer(bool& /*recomputeVisibleRegions*/, nsecs_t /*latchTime*/, | 
 | 548 |                              nsecs_t /*expectedPresentTime*/) { | 
 | 549 |         return false; | 
 | 550 |     } | 
 | 551 |  | 
 | 552 |     virtual bool isBufferLatched() const { return false; } | 
 | 553 |  | 
 | 554 |     virtual void latchAndReleaseBuffer() {} | 
 | 555 |  | 
 | 556 |     /* | 
 | 557 |      * returns the rectangle that crops the content of the layer and scales it | 
 | 558 |      * to the layer's size. | 
 | 559 |      */ | 
 | 560 |     virtual Rect getBufferCrop() const { return Rect(); } | 
 | 561 |  | 
 | 562 |     /* | 
 | 563 |      * Returns the transform applied to the buffer. | 
 | 564 |      */ | 
 | 565 |     virtual uint32_t getBufferTransform() const { return 0; } | 
 | 566 |  | 
 | 567 |     virtual sp<GraphicBuffer> getBuffer() const { return nullptr; } | 
 | 568 |  | 
 | 569 |     virtual ui::Transform::RotationFlags getTransformHint() const { return ui::Transform::ROT_0; } | 
 | 570 |  | 
 | 571 |     /* | 
 | 572 |      * Returns if a frame is ready | 
 | 573 |      */ | 
 | 574 |     virtual bool hasReadyFrame() const { return false; } | 
 | 575 |  | 
 | 576 |     virtual int32_t getQueuedFrameCount() const { return 0; } | 
 | 577 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 578 |     /** | 
 | 579 |      * Returns active buffer size in the correct orientation. Buffer size is determined by undoing | 
 | 580 |      * any buffer transformations. If the layer has no buffer then return INVALID_RECT. | 
 | 581 |      */ | 
 | 582 |     virtual Rect getBufferSize(const Layer::State&) const { return Rect::INVALID_RECT; } | 
 | 583 |  | 
 | 584 |     /** | 
 | 585 |      * Returns the source bounds. If the bounds are not defined, it is inferred from the | 
 | 586 |      * buffer size. Failing that, the bounds are determined from the passed in parent bounds. | 
 | 587 |      * For the root layer, this is the display viewport size. | 
 | 588 |      */ | 
 | 589 |     virtual FloatRect computeSourceBounds(const FloatRect& parentBounds) const { | 
 | 590 |         return parentBounds; | 
 | 591 |     } | 
 | 592 |     virtual FrameRate getFrameRateForLayerTree() const; | 
 | 593 |  | 
 | 594 |     virtual std::vector<OccupancyTracker::Segment> getOccupancyHistory(bool /*forceFlush*/) { | 
 | 595 |         return {}; | 
 | 596 |     } | 
 | 597 |  | 
 | 598 |     virtual bool getTransformToDisplayInverse() const { return false; } | 
 | 599 |  | 
 | 600 |     // Returns how rounded corners should be drawn for this layer. | 
 | 601 |     // This will traverse the hierarchy until it reaches its root, finding topmost rounded | 
 | 602 |     // corner definition and converting it into current layer's coordinates. | 
 | 603 |     // As of now, only 1 corner radius per display list is supported. Subsequent ones will be | 
 | 604 |     // ignored. | 
 | 605 |     virtual RoundedCornerState getRoundedCornerState() const; | 
 | 606 |  | 
| Leon Scroggins III | f8a1831 | 2021-04-01 16:38:25 -0400 | [diff] [blame] | 607 |     bool hasRoundedCorners() const override { return getRoundedCornerState().radius > .0f; } | 
 | 608 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 609 |     virtual PixelFormat getPixelFormat() const { return PIXEL_FORMAT_NONE; } | 
 | 610 |     /** | 
 | 611 |      * Return whether this layer needs an input info. For most layer types | 
 | 612 |      * this is only true if they explicitly set an input-info but BufferLayer | 
 | 613 |      * overrides this so we can generate input-info for Buffered layers that don't | 
 | 614 |      * have them (for input occlusion detection checks). | 
 | 615 |      */ | 
 | 616 |     virtual bool needsInputInfo() const { return hasInputInfo(); } | 
 | 617 |  | 
 | 618 |     // Implements RefBase. | 
 | 619 |     void onFirstRef() override; | 
 | 620 |  | 
 | 621 |     // implements compositionengine::LayerFE | 
 | 622 |     const compositionengine::LayerFECompositionState* getCompositionState() const override; | 
 | 623 |     bool onPreComposition(nsecs_t) override; | 
 | 624 |     void prepareCompositionState(compositionengine::LayerFE::StateSubset subset) override; | 
 | 625 |     std::vector<compositionengine::LayerFE::LayerSettings> prepareClientCompositionList( | 
 | 626 |             compositionengine::LayerFE::ClientCompositionTargetSettings&) override; | 
 | 627 |     void onLayerDisplayed(const sp<Fence>& releaseFence) override; | 
 | 628 |     const char* getDebugName() const override; | 
 | 629 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 630 |     bool setShadowRadius(float shadowRadius); | 
 | 631 |  | 
 | 632 |     // Before color management is introduced, contents on Android have to be | 
 | 633 |     // desaturated in order to match what they appears like visually. | 
 | 634 |     // With color management, these contents will appear desaturated, thus | 
 | 635 |     // needed to be saturated so that they match what they are designed for | 
 | 636 |     // visually. | 
 | 637 |     bool isLegacyDataSpace() const; | 
 | 638 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 639 |     uint32_t getTransactionFlags() const { return mTransactionFlags; } | 
 | 640 |     uint32_t getTransactionFlags(uint32_t flags); | 
 | 641 |     uint32_t setTransactionFlags(uint32_t flags); | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 642 |  | 
| Lloyd Pique | ef36b00 | 2019-01-23 17:52:04 -0800 | [diff] [blame] | 643 |     // Deprecated, please use compositionengine::Output::belongsInOutput() | 
 | 644 |     // instead. | 
 | 645 |     // TODO(lpique): Move the remaining callers (screencap) to the new function. | 
| chaviw | 4b9d5e1 | 2020-08-04 18:30:35 -0700 | [diff] [blame] | 646 |     bool belongsToDisplay(uint32_t layerStack) const { return getLayerStack() == layerStack; } | 
| Chia-I Wu | ab0c319 | 2017-08-01 11:29:00 -0700 | [diff] [blame] | 647 |  | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 648 |     FloatRect getBounds(const Region& activeTransparentRegion) const; | 
 | 649 |     FloatRect getBounds() const; | 
 | 650 |  | 
 | 651 |     // Compute bounds for the layer and cache the results. | 
| Vishnu Nair | c97b8db | 2019-10-29 18:19:35 -0700 | [diff] [blame] | 652 |     void computeBounds(FloatRect parentBounds, ui::Transform parentTransform, float shadowRadius); | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 653 |  | 
| Dan Stoza | 269dc4d | 2021-01-15 15:07:43 -0800 | [diff] [blame] | 654 |     int32_t getSequence() const override { return sequence; } | 
| Pablo Ceballos | 40845df | 2016-01-25 17:41:15 -0800 | [diff] [blame] | 655 |  | 
| Mikael Pessa | 2e1608f | 2019-07-19 11:25:35 -0700 | [diff] [blame] | 656 |     // For tracing. | 
 | 657 |     // TODO: Replace with raw buffer id from buffer metadata when that becomes available. | 
 | 658 |     // GraphicBuffer::getId() does not provide a reliable global identifier. Since the traces | 
 | 659 |     // creates its tracks by buffer id and has no way of associating a buffer back to the process | 
 | 660 |     // that created it, the current implementation is only sufficient for cases where a buffer is | 
 | 661 |     // only used within a single layer. | 
| chaviw | d62d306 | 2019-09-04 14:48:02 -0700 | [diff] [blame] | 662 |     uint64_t getCurrentBufferId() const { return getBuffer() ? getBuffer()->getId() : 0; } | 
| Mikael Pessa | 2e1608f | 2019-07-19 11:25:35 -0700 | [diff] [blame] | 663 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 664 |     /* | 
 | 665 |      * isSecure - true if this surface is secure, that is if it prevents | 
| Peiyong Lin | 05cc011 | 2020-10-14 16:16:37 -0700 | [diff] [blame] | 666 |      * screenshots or VNC servers. A surface can be set to be secure by the | 
 | 667 |      * application, being secure doesn't mean the surface has DRM contents. | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 668 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 669 |     bool isSecure() const; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 670 |  | 
 | 671 |     /* | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 672 |      * isHiddenByPolicy - true if this layer has been forced invisible. | 
 | 673 |      * just because this is false, doesn't mean isVisible() is true. | 
 | 674 |      * For example if this layer has no active buffer, it may not be hidden by | 
 | 675 |      * policy, but it still can not be visible. | 
 | 676 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 677 |     bool isHiddenByPolicy() const; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 678 |  | 
| Robert Carr | 2e102c9 | 2018-10-23 12:11:15 -0700 | [diff] [blame] | 679 |     bool isRemovedFromCurrentState() const; | 
| chaviw | 8b3871a | 2017-11-01 17:41:01 -0700 | [diff] [blame] | 680 |  | 
| chaviw | 4c34a09 | 2020-07-08 11:30:06 -0700 | [diff] [blame] | 681 |     LayerProto* writeToProto(LayersProto& layersProto, uint32_t traceFlags, const DisplayDevice*); | 
| chaviw | 08f3cb2 | 2020-01-13 13:17:21 -0800 | [diff] [blame] | 682 |  | 
| Vishnu Nair | 8406fd7 | 2019-07-30 11:29:31 -0700 | [diff] [blame] | 683 |     // Write states that are modified by the main thread. This includes drawing | 
 | 684 |     // state as well as buffer data. This should be called in the main or tracing | 
 | 685 |     // thread. | 
| chaviw | 4c34a09 | 2020-07-08 11:30:06 -0700 | [diff] [blame] | 686 |     void writeToProtoDrawingState(LayerProto* layerInfo, uint32_t traceFlags, const DisplayDevice*); | 
| Vishnu Nair | 8406fd7 | 2019-07-30 11:29:31 -0700 | [diff] [blame] | 687 |     // Write drawing or current state. If writing current state, the caller should hold the | 
 | 688 |     // external mStateLock. If writing drawing state, this function should be called on the | 
 | 689 |     // main or tracing thread. | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 690 |     void writeToProtoCommonState(LayerProto* layerInfo, LayerVector::StateSet, | 
| chaviw | 4c34a09 | 2020-07-08 11:30:06 -0700 | [diff] [blame] | 691 |                                  uint32_t traceFlags = SurfaceTracing::TRACE_ALL); | 
| Yiwei Zhang | 7124ad3 | 2018-02-21 13:02:45 -0800 | [diff] [blame] | 692 |  | 
| chaviw | 3277faf | 2021-05-19 16:45:23 -0500 | [diff] [blame] | 693 |     gui::WindowInfo::Type getWindowType() const { return mWindowType; } | 
| Peiyong Lin | 97067b0 | 2019-03-29 17:34:45 +0000 | [diff] [blame] | 694 |  | 
| chaviw | c5676c6 | 2020-09-18 15:01:04 -0700 | [diff] [blame] | 695 |     bool getPrimaryDisplayOnly() const; | 
| chaviw | b4c6e58 | 2019-08-16 14:35:07 -0700 | [diff] [blame] | 696 |  | 
| chaviw | 74b0317 | 2019-08-19 11:09:03 -0700 | [diff] [blame] | 697 |     void updateMirrorInfo(); | 
| chaviw | 74b0317 | 2019-08-19 11:09:03 -0700 | [diff] [blame] | 698 |  | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 699 |     /* | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 700 |      * doTransaction - process the transaction. This is a good place to figure | 
 | 701 |      * out which attributes of the surface have changed. | 
 | 702 |      */ | 
| Robert Carr | 7121caf | 2020-12-15 13:07:32 -0800 | [diff] [blame] | 703 |     virtual uint32_t doTransaction(uint32_t transactionFlags); | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 704 |  | 
 | 705 |     /* | 
| Vishnu Nair | da9c85a | 2019-06-03 17:26:48 -0700 | [diff] [blame] | 706 |      * Remove relative z for the layer if its relative parent is not part of the | 
 | 707 |      * provided layer tree. | 
 | 708 |      */ | 
 | 709 |     void removeRelativeZ(const std::vector<Layer*>& layersInTree); | 
 | 710 |  | 
 | 711 |     /* | 
 | 712 |      * Remove from current state and mark for removal. | 
 | 713 |      */ | 
 | 714 |     void removeFromCurrentState(); | 
 | 715 |  | 
 | 716 |     /* | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 717 |      * called with the state lock from a binder thread when the layer is | 
| Chia-I Wu | c665702 | 2017-08-15 11:18:17 -0700 | [diff] [blame] | 718 |      * removed from the current list to the pending removal list | 
 | 719 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 720 |     void onRemovedFromCurrentState(); | 
| Chia-I Wu | c665702 | 2017-08-15 11:18:17 -0700 | [diff] [blame] | 721 |  | 
| chaviw | 61626f2 | 2018-11-15 16:26:27 -0800 | [diff] [blame] | 722 |     /* | 
 | 723 |      * Called when the layer is added back to the current state list. | 
 | 724 |      */ | 
 | 725 |     void addToCurrentState(); | 
 | 726 |  | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 727 |     /* | 
 | 728 |      * Sets display transform hint on BufferLayerConsumer. | 
 | 729 |      */ | 
 | 730 |     void updateTransformHint(ui::Transform::RotationFlags); | 
| Andy McFadden | 6905205 | 2012-09-14 16:10:11 -0700 | [diff] [blame] | 731 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 732 |     inline const State& getDrawingState() const { return mDrawingState; } | 
| Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 733 |     inline State& getDrawingState() { return mDrawingState; } | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 734 |  | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 735 |     LayerDebugInfo getLayerDebugInfo(const DisplayDevice*) const; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 736 |  | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 737 |     void miniDump(std::string& result, const DisplayDevice&) const; | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 738 |     void dumpFrameStats(std::string& result) const; | 
 | 739 |     void dumpFrameEvents(std::string& result); | 
| Vishnu Nair | 0f085c6 | 2019-08-30 08:49:12 -0700 | [diff] [blame] | 740 |     void dumpCallingUidPid(std::string& result) const; | 
| Svetoslav | d85084b | 2014-03-20 10:28:31 -0700 | [diff] [blame] | 741 |     void clearFrameStats(); | 
| Jamie Gennis | 6547ff4 | 2013-07-16 20:12:42 -0700 | [diff] [blame] | 742 |     void logFrameStats(); | 
| Svetoslav | d85084b | 2014-03-20 10:28:31 -0700 | [diff] [blame] | 743 |     void getFrameStats(FrameStats* outStats) const; | 
| Brian Anderson | 5ea5e59 | 2016-12-01 16:54:33 -0800 | [diff] [blame] | 744 |     void onDisconnect(); | 
| Brian Anderson | 3890c39 | 2016-07-25 12:48:08 -0700 | [diff] [blame] | 745 |     void addAndGetFrameTimestamps(const NewFrameEventsEntry* newEntry, | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 746 |                                   FrameEventHistoryDelta* outDelta); | 
| Pablo Ceballos | ce796e7 | 2016-02-04 19:10:51 -0800 | [diff] [blame] | 747 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 748 |     ui::Transform getTransform() const; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 749 |  | 
| Robert Carr | 6452f12 | 2017-03-21 10:41:29 -0700 | [diff] [blame] | 750 |     // Returns the Alpha of the Surface, accounting for the Alpha | 
 | 751 |     // of parent Surfaces in the hierarchy (alpha's will be multiplied | 
 | 752 |     // down the hierarchy). | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 753 |     half getAlpha() const; | 
 | 754 |     half4 getColor() const; | 
| Lucas Dupin | 19c8f0e | 2019-11-25 17:55:44 -0800 | [diff] [blame] | 755 |     int32_t getBackgroundBlurRadius() const; | 
| Vishnu Nair | b87d94f | 2020-02-13 09:17:36 -0800 | [diff] [blame] | 756 |     bool drawShadows() const { return mEffectiveShadowRadius > 0.f; }; | 
| Robert Carr | 6452f12 | 2017-03-21 10:41:29 -0700 | [diff] [blame] | 757 |  | 
| Vishnu Nair | 6213bd9 | 2020-05-08 17:42:25 -0700 | [diff] [blame] | 758 |     // Returns the transform hint set by Window Manager on the layer or one of its parents. | 
 | 759 |     // This traverses the current state because the data is needed when creating | 
 | 760 |     // the layer(off drawing thread) and the hint should be available before the producer | 
 | 761 |     // is ready to acquire a buffer. | 
 | 762 |     ui::Transform::RotationFlags getFixedTransformHint() const; | 
 | 763 |  | 
| Edgar Arriaga | 844fa67 | 2020-01-16 14:21:42 -0800 | [diff] [blame] | 764 |     /** | 
 | 765 |      * Traverse this layer and it's hierarchy of children directly. Unlike traverseInZOrder | 
 | 766 |      * which will not emit children who have relativeZOrder to another layer, this method | 
 | 767 |      * just directly emits all children. It also emits them in no particular order. | 
 | 768 |      * So this method is not suitable for graphical operations, as it doesn't represent | 
 | 769 |      * the scene state, but it's also more efficient than traverseInZOrder and so useful for | 
 | 770 |      * book-keeping. | 
 | 771 |      */ | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 772 |     void traverse(LayerVector::StateSet, const LayerVector::Visitor&); | 
 | 773 |     void traverseInReverseZOrder(LayerVector::StateSet, const LayerVector::Visitor&); | 
 | 774 |     void traverseInZOrder(LayerVector::StateSet, const LayerVector::Visitor&); | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 775 |  | 
| chaviw | 4b129c2 | 2018-04-09 16:19:43 -0700 | [diff] [blame] | 776 |     /** | 
 | 777 |      * Traverse only children in z order, ignoring relative layers that are not children of the | 
 | 778 |      * parent. | 
 | 779 |      */ | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 780 |     void traverseChildrenInZOrder(LayerVector::StateSet, const LayerVector::Visitor&); | 
| chaviw | a76b271 | 2017-09-20 12:02:26 -0700 | [diff] [blame] | 781 |  | 
| Chia-I Wu | 98f1c10 | 2017-05-30 14:54:08 -0700 | [diff] [blame] | 782 |     size_t getChildrenCount() const; | 
| Valerie Hau | c568680 | 2019-11-22 14:18:09 -0800 | [diff] [blame] | 783 |  | 
 | 784 |     // ONLY CALL THIS FROM THE LAYER DTOR! | 
 | 785 |     // See b/141111965.  We need to add current children to offscreen layers in | 
 | 786 |     // the layer dtor so as not to dangle layers.  Since the layer has not | 
 | 787 |     // committed its transaction when the layer is destroyed, we must add | 
 | 788 |     // current children.  This is safe in the dtor as we will no longer update | 
 | 789 |     // the current state, but should not be called anywhere else! | 
 | 790 |     LayerVector& getCurrentChildren() { return mCurrentChildren; } | 
 | 791 |  | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 792 |     void addChild(const sp<Layer>&); | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 793 |     // Returns index if removed, or negative value otherwise | 
 | 794 |     // for symmetry with Vector::remove | 
 | 795 |     ssize_t removeChild(const sp<Layer>& layer); | 
| Chia-I Wu | e41dbe6 | 2017-06-13 14:10:56 -0700 | [diff] [blame] | 796 |     sp<Layer> getParent() const { return mCurrentParent.promote(); } | 
| Vishnu Nair | 14d218b | 2021-07-13 13:57:39 -0700 | [diff] [blame] | 797 |  | 
 | 798 |     // Should be called with the surfaceflinger statelock held | 
 | 799 |     bool isAtRoot() const { return mIsAtRoot; } | 
 | 800 |     void setIsAtRoot(bool isAtRoot) { mIsAtRoot = isAtRoot; } | 
 | 801 |  | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 802 |     bool hasParent() const { return getParent() != nullptr; } | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 803 |     Rect getScreenBounds(bool reduceTransparentRegion = true) const; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 804 |     bool setChildLayer(const sp<Layer>& childLayer, int32_t z); | 
| Robert Carr | 503c704 | 2017-09-27 15:06:08 -0700 | [diff] [blame] | 805 |     bool setChildRelativeLayer(const sp<Layer>& childLayer, | 
 | 806 |             const sp<IBinder>& relativeToHandle, int32_t relativeZ); | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 807 |  | 
 | 808 |     // Copy the current list of children to the drawing state. Called by | 
 | 809 |     // SurfaceFlinger to complete a transaction. | 
 | 810 |     void commitChildList(); | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 811 |     int32_t getZ(LayerVector::StateSet) const; | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 812 |  | 
| Vishnu Nair | efc42e2 | 2019-12-03 17:36:12 -0800 | [diff] [blame] | 813 |     /** | 
 | 814 |      * Returns the cropped buffer size or the layer crop if the layer has no buffer. Return | 
 | 815 |      * INVALID_RECT if the layer has no buffer and no crop. | 
 | 816 |      * A layer with an invalid buffer size and no crop is considered to be boundless. The layer | 
 | 817 |      * bounds are constrained by its parent bounds. | 
 | 818 |      */ | 
 | 819 |     Rect getCroppedBufferSize(const Layer::State& s) const; | 
 | 820 |  | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 821 |     bool setFrameRate(FrameRate); | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 822 |  | 
| Siarhei Vishniakou | fc434ac | 2021-01-13 10:28:00 -1000 | [diff] [blame] | 823 |     virtual void setFrameTimelineInfoForBuffer(const FrameTimelineInfo& /*info*/) {} | 
| Adithya Srinivasan | b9a7dab | 2021-01-14 23:49:46 +0000 | [diff] [blame] | 824 |     void setFrameTimelineVsyncForBufferTransaction(const FrameTimelineInfo& info, nsecs_t postTime); | 
 | 825 |     void setFrameTimelineVsyncForBufferlessTransaction(const FrameTimelineInfo& info, | 
 | 826 |                                                        nsecs_t postTime); | 
 | 827 |  | 
 | 828 |     void addSurfaceFrameDroppedForBuffer( | 
 | 829 |             std::shared_ptr<frametimeline::SurfaceFrame>& surfaceFrame); | 
 | 830 |     void addSurfaceFramePresentedForBuffer( | 
 | 831 |             std::shared_ptr<frametimeline::SurfaceFrame>& surfaceFrame, nsecs_t acquireFenceTime, | 
 | 832 |             nsecs_t currentLatchTime); | 
 | 833 |  | 
 | 834 |     std::shared_ptr<frametimeline::SurfaceFrame> createSurfaceFrameForTransaction( | 
 | 835 |             const FrameTimelineInfo& info, nsecs_t postTime); | 
 | 836 |     std::shared_ptr<frametimeline::SurfaceFrame> createSurfaceFrameForBuffer( | 
 | 837 |             const FrameTimelineInfo& info, nsecs_t queueTime, std::string debugName); | 
| Ady Abraham | 74e1756 | 2020-08-24 18:18:19 -0700 | [diff] [blame] | 838 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 839 |     // Creates a new handle each time, so we only expect | 
 | 840 |     // this to be called once. | 
 | 841 |     sp<IBinder> getHandle(); | 
 | 842 |     const std::string& getName() const { return mName; } | 
 | 843 |     bool getPremultipledAlpha() const; | 
| chaviw | 3277faf | 2021-05-19 16:45:23 -0500 | [diff] [blame] | 844 |     void setInputInfo(const gui::WindowInfo& info); | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 845 |  | 
| chaviw | 3277faf | 2021-05-19 16:45:23 -0500 | [diff] [blame] | 846 |     gui::WindowInfo fillInputInfo(const sp<DisplayDevice>& display); | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 847 |     /** | 
 | 848 |      * Returns whether this layer has an explicitly set input-info. | 
 | 849 |      */ | 
 | 850 |     bool hasInputInfo() const; | 
 | 851 |  | 
| Adithya Srinivasan | ac977e6 | 2021-05-21 22:50:56 +0000 | [diff] [blame] | 852 |     // Sets the parent's gameMode for this layer and all its children. Parent's gameMode is applied | 
 | 853 |     // only to layers that do not have the GAME_MODE_METADATA set by WMShell. Any layer(along with | 
 | 854 |     // its children) that has the metadata set will use the gameMode from the metadata. | 
| Adithya Srinivasan | 58069dc | 2021-06-04 20:37:02 +0000 | [diff] [blame] | 855 |     void setGameModeForTree(int32_t parentGameMode); | 
 | 856 |     void setGameMode(int32_t gameMode) { mGameMode = gameMode; }; | 
 | 857 |     int32_t getGameMode() const { return mGameMode; } | 
| Adithya Srinivasan | ac977e6 | 2021-05-21 22:50:56 +0000 | [diff] [blame] | 858 |  | 
| Ady Abraham | 62a0be2 | 2020-12-08 16:54:10 -0800 | [diff] [blame] | 859 |     virtual uid_t getOwnerUid() const { return mOwnerUid; } | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 860 |  | 
| Adithya Srinivasan | 9febda8 | 2020-10-19 10:49:41 -0700 | [diff] [blame] | 861 |     pid_t getOwnerPid() { return mOwnerPid; } | 
 | 862 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 863 |     // This layer is not a clone, but it's the parent to the cloned hierarchy. The | 
 | 864 |     // variable mClonedChild represents the top layer that will be cloned so this | 
 | 865 |     // layer will be the parent of mClonedChild. | 
 | 866 |     // The layers in the cloned hierarchy will match the lifetime of the real layers. That is | 
 | 867 |     // if the real layer is destroyed, then the clone layer will also be destroyed. | 
 | 868 |     sp<Layer> mClonedChild; | 
| Robert Carr | 6a0382d | 2021-07-01 15:57:17 -0700 | [diff] [blame] | 869 |     bool mHadClonedChild = false; | 
 | 870 |     void setClonedChild(const sp<Layer>& mClonedChild); | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 871 |  | 
 | 872 |     mutable bool contentDirty{false}; | 
 | 873 |     Region surfaceDamageRegion; | 
 | 874 |  | 
 | 875 |     // Layer serial number.  This gives layers an explicit ordering, so we | 
 | 876 |     // have a stable sort order when their layer stack and Z-order are | 
 | 877 |     // the same. | 
 | 878 |     int32_t sequence{sSequence++}; | 
 | 879 |  | 
 | 880 |     bool mPendingHWCDestroy{false}; | 
| Steven Thomas | 3172e20 | 2020-01-06 19:25:30 -0800 | [diff] [blame] | 881 |  | 
| Vishnu Nair | f6eddb6 | 2021-01-27 22:02:11 -0800 | [diff] [blame] | 882 |     bool backpressureEnabled() { return mDrawingState.flags & layer_state_t::eEnableBackpressure; } | 
| Vishnu Nair | f6eddb6 | 2021-01-27 22:02:11 -0800 | [diff] [blame] | 883 |  | 
| John Reck | cdb4ed7 | 2021-02-04 13:39:33 -0500 | [diff] [blame] | 884 |     bool setStretchEffect(const StretchEffect& effect); | 
| John Reck | c00c669 | 2021-02-16 11:37:33 -0500 | [diff] [blame] | 885 |     StretchEffect getStretchEffect() const; | 
| John Reck | cdb4ed7 | 2021-02-04 13:39:33 -0500 | [diff] [blame] | 886 |  | 
| chaviw | f3f40fe | 2021-04-27 15:54:02 -0500 | [diff] [blame] | 887 |     virtual bool setBufferCrop(const Rect& /* bufferCrop */) { return false; } | 
| Vishnu Nair | 6bdec7d | 2021-05-10 15:01:13 -0700 | [diff] [blame] | 888 |     virtual bool setDestinationFrame(const Rect& /* destinationFrame */) { return false; } | 
| Vishnu Nair | 8eda69e | 2021-02-26 10:42:10 -0800 | [diff] [blame] | 889 |     virtual std::atomic<int32_t>* getPendingBufferCounter() { return nullptr; } | 
 | 890 |     virtual std::string getPendingBufferCounterName() { return ""; } | 
| Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 891 |     virtual bool updateGeometry() { return false; } | 
| Vishnu Nair | 8eda69e | 2021-02-26 10:42:10 -0800 | [diff] [blame] | 892 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 893 | protected: | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 894 |     friend class impl::SurfaceInterceptor; | 
 | 895 |  | 
 | 896 |     // For unit tests | 
 | 897 |     friend class TestableSurfaceFlinger; | 
| Alec Mouri | adebf5c | 2021-01-05 12:57:36 -0800 | [diff] [blame] | 898 |     friend class FpsReporterTest; | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 899 |     friend class RefreshRateSelectionTest; | 
 | 900 |     friend class SetFrameRateTest; | 
| Adithya Srinivasan | b238cd5 | 2021-02-04 17:54:05 +0000 | [diff] [blame] | 901 |     friend class TransactionFrameTracerTest; | 
| Adithya Srinivasan | b9a7dab | 2021-01-14 23:49:46 +0000 | [diff] [blame] | 902 |     friend class TransactionSurfaceFrameTest; | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 903 |  | 
 | 904 |     virtual void setInitialValuesForClone(const sp<Layer>& clonedFrom); | 
 | 905 |     virtual std::optional<compositionengine::LayerFE::LayerSettings> prepareClientComposition( | 
 | 906 |             compositionengine::LayerFE::ClientCompositionTargetSettings&); | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 907 |     virtual void preparePerFrameCompositionState(); | 
| Adithya Srinivasan | b9a7dab | 2021-01-14 23:49:46 +0000 | [diff] [blame] | 908 |     virtual void commitTransaction(State& stateToCommit); | 
| Jorim Jaggi | 9c03b50 | 2020-11-24 23:51:31 +0100 | [diff] [blame] | 909 |     virtual void onSurfaceFrameCreated(const std::shared_ptr<frametimeline::SurfaceFrame>&) {} | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 910 |  | 
 | 911 |     // Returns mCurrentScaling mode (originating from the | 
 | 912 |     // Client) or mOverrideScalingMode mode (originating from | 
 | 913 |     // the Surface Controller) if set. | 
 | 914 |     virtual uint32_t getEffectiveScalingMode() const { return 0; } | 
 | 915 |  | 
 | 916 |     sp<compositionengine::LayerFE> asLayerFE() const; | 
 | 917 |     sp<Layer> getClonedFrom() { return mClonedFrom != nullptr ? mClonedFrom.promote() : nullptr; } | 
 | 918 |     bool isClone() { return mClonedFrom != nullptr; } | 
 | 919 |     bool isClonedFromAlive() { return getClonedFrom() != nullptr; } | 
 | 920 |  | 
 | 921 |     void updateClonedDrawingState(std::map<sp<Layer>, sp<Layer>>& clonedLayersMap); | 
 | 922 |     void updateClonedChildren(const sp<Layer>& mirrorRoot, | 
 | 923 |                               std::map<sp<Layer>, sp<Layer>>& clonedLayersMap); | 
 | 924 |     void updateClonedRelatives(const std::map<sp<Layer>, sp<Layer>>& clonedLayersMap); | 
 | 925 |     void addChildToDrawing(const sp<Layer>&); | 
 | 926 |     void updateClonedInputInfo(const std::map<sp<Layer>, sp<Layer>>& clonedLayersMap); | 
 | 927 |  | 
 | 928 |     // Modifies the passed in layer settings to clear the contents. If the blackout flag is set, | 
 | 929 |     // the settings clears the content with a solid black fill. | 
 | 930 |     void prepareClearClientComposition(LayerFE::LayerSettings&, bool blackout) const; | 
| Derek Sollenberger | c31985e | 2021-05-18 16:38:17 -0400 | [diff] [blame] | 931 |     void prepareShadowClientComposition(LayerFE::LayerSettings& caster, const Rect& layerStackRect); | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 932 |  | 
 | 933 |     void prepareBasicGeometryCompositionState(); | 
 | 934 |     void prepareGeometryCompositionState(); | 
 | 935 |     void prepareCursorCompositionState(); | 
 | 936 |  | 
 | 937 |     uint32_t getEffectiveUsage(uint32_t usage) const; | 
 | 938 |  | 
 | 939 |     /** | 
 | 940 |      * Setup rounded corners coordinates of this layer, taking into account the layer bounds and | 
 | 941 |      * crop coordinates, transforming them into layer space. | 
 | 942 |      */ | 
 | 943 |     void setupRoundedCornersCropCoordinates(Rect win, const FloatRect& roundedCornersCrop) const; | 
 | 944 |     void setParent(const sp<Layer>&); | 
 | 945 |     LayerVector makeTraversalList(LayerVector::StateSet, bool* outSkipRelativeZUsers); | 
 | 946 |     void addZOrderRelative(const wp<Layer>& relative); | 
 | 947 |     void removeZOrderRelative(const wp<Layer>& relative); | 
 | 948 |     compositionengine::OutputLayer* findOutputLayerForDisplay(const DisplayDevice*) const; | 
 | 949 |     bool usingRelativeZ(LayerVector::StateSet) const; | 
 | 950 |  | 
| chaviw | 39d0147 | 2021-04-08 14:26:24 -0500 | [diff] [blame] | 951 |     virtual ui::Transform getInputTransform() const; | 
 | 952 |     virtual Rect getInputBounds() const; | 
 | 953 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 954 |     // constant | 
 | 955 |     sp<SurfaceFlinger> mFlinger; | 
| Mathias Agopian | b7e930d | 2010-06-01 15:12:58 -0700 | [diff] [blame] | 956 |  | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 957 |     bool mPremultipliedAlpha{true}; | 
| Dominik Laskowski | 87a07e4 | 2019-10-10 20:38:02 -0700 | [diff] [blame] | 958 |     const std::string mName; | 
 | 959 |     const std::string mTransactionName{"TX - " + mName}; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 960 |  | 
| Vishnu Nair | 8406fd7 | 2019-07-30 11:29:31 -0700 | [diff] [blame] | 961 |     // These are only accessed by the main thread or the tracing thread. | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 962 |     State mDrawingState; | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 963 |  | 
| Robert Carr | 38d2500 | 2021-06-11 14:30:09 -0700 | [diff] [blame] | 964 |     uint32_t mTransactionFlags{0}; | 
| Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 965 |     // Updated in doTransaction, used to track the last sequence number we | 
 | 966 |     // committed. Currently this is really only used for updating visible | 
 | 967 |     // regions. | 
 | 968 |     int32_t mLastCommittedTxSequence = -1; | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 969 |  | 
| Brian Anderson | d6927fb | 2016-07-23 23:37:30 -0700 | [diff] [blame] | 970 |     // Timestamp history for UIAutomation. Thread safe. | 
| Jamie Gennis | 4b0eba9 | 2013-02-05 13:30:24 -0800 | [diff] [blame] | 971 |     FrameTracker mFrameTracker; | 
| Mathias Agopian | a67932f | 2011-04-20 14:20:59 -0700 | [diff] [blame] | 972 |  | 
| Brian Anderson | d6927fb | 2016-07-23 23:37:30 -0700 | [diff] [blame] | 973 |     // Timestamp history for the consumer to query. | 
 | 974 |     // Accessed by both consumer and producer on main and binder threads. | 
 | 975 |     Mutex mFrameEventHistoryMutex; | 
| Brian Anderson | 3890c39 | 2016-07-25 12:48:08 -0700 | [diff] [blame] | 976 |     ConsumerFrameEventHistory mFrameEventHistory; | 
| Brian Anderson | 3d4039d | 2016-09-23 16:31:30 -0700 | [diff] [blame] | 977 |     FenceTimeline mAcquireTimeline; | 
 | 978 |     FenceTimeline mReleaseTimeline; | 
| Brian Anderson | d6927fb | 2016-07-23 23:37:30 -0700 | [diff] [blame] | 979 |  | 
| Mathias Agopian | a67932f | 2011-04-20 14:20:59 -0700 | [diff] [blame] | 980 |     // main thread | 
| Lloyd Pique | 0b785d8 | 2018-12-04 17:25:27 -0800 | [diff] [blame] | 981 |     sp<NativeHandle> mSidebandStream; | 
| Alec Mouri | e7d1d4a | 2019-02-05 01:13:46 +0000 | [diff] [blame] | 982 |     // False if the buffer and its contents have been previously used for GPU | 
 | 983 |     // composition, true otherwise. | 
 | 984 |     bool mIsActiveBufferUpdatedForGpu = true; | 
 | 985 |  | 
| Robert Carr | c3574f7 | 2016-03-24 12:19:32 -0700 | [diff] [blame] | 986 |     // We encode unset as -1. | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 987 |     std::atomic<uint64_t> mCurrentFrameNumber{0}; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 988 |     // Whether filtering is needed b/c of the drawingstate | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 989 |     bool mNeedsFiltering{false}; | 
| David Sodman | 0c69cad | 2017-08-21 12:12:51 -0700 | [diff] [blame] | 990 |  | 
| Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 991 |     std::atomic<bool> mRemovedFromDrawingState{false}; | 
| chaviw | 8b3871a | 2017-11-01 17:41:01 -0700 | [diff] [blame] | 992 |  | 
| Mathias Agopian | b7e930d | 2010-06-01 15:12:58 -0700 | [diff] [blame] | 993 |     // page-flip thread (currently main thread) | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 994 |     bool mProtectedByApp{false}; // application requires protected path to external sink | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 995 |  | 
 | 996 |     // protected by mLock | 
 | 997 |     mutable Mutex mLock; | 
| David Sodman | 0c69cad | 2017-08-21 12:12:51 -0700 | [diff] [blame] | 998 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 999 |     const wp<Client> mClientRef; | 
| Riley Andrews | 03414a1 | 2014-07-01 14:22:59 -0700 | [diff] [blame] | 1000 |  | 
 | 1001 |     // This layer can be a cursor on some displays. | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 1002 |     bool mPotentialCursor{false}; | 
| Dan Stoza | 6b9454d | 2014-11-07 16:00:59 -0800 | [diff] [blame] | 1003 |  | 
| Robert Carr | 88d76cd | 2021-06-22 16:23:51 -0700 | [diff] [blame] | 1004 |     LayerVector mCurrentChildren{LayerVector::StateSet::Current}; | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 1005 |     LayerVector mDrawingChildren{LayerVector::StateSet::Drawing}; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 1006 |  | 
| Chia-I Wu | e41dbe6 | 2017-06-13 14:10:56 -0700 | [diff] [blame] | 1007 |     wp<Layer> mCurrentParent; | 
 | 1008 |     wp<Layer> mDrawingParent; | 
| David Sodman | 9eeae69 | 2017-11-02 10:53:32 -0700 | [diff] [blame] | 1009 |  | 
| Ady Abraham | 8f1ee7f | 2019-04-05 10:32:50 -0700 | [diff] [blame] | 1010 |     // Window types from WindowManager.LayoutParams | 
| chaviw | 3277faf | 2021-05-19 16:45:23 -0500 | [diff] [blame] | 1011 |     const gui::WindowInfo::Type mWindowType; | 
| Ady Abraham | 8f1ee7f | 2019-04-05 10:32:50 -0700 | [diff] [blame] | 1012 |  | 
| Alec Mouri | 9a29e67 | 2020-09-14 12:39:14 -0700 | [diff] [blame] | 1013 |     // The owner of the layer. If created from a non system process, it will be the calling uid. | 
 | 1014 |     // If created from a system process, the value can be passed in. | 
 | 1015 |     uid_t mOwnerUid; | 
 | 1016 |  | 
| Adithya Srinivasan | 9febda8 | 2020-10-19 10:49:41 -0700 | [diff] [blame] | 1017 |     // The owner pid of the layer. If created from a non system process, it will be the calling pid. | 
 | 1018 |     // If created from a system process, the value can be passed in. | 
 | 1019 |     pid_t mOwnerPid; | 
 | 1020 |  | 
| Adithya Srinivasan | b9a7dab | 2021-01-14 23:49:46 +0000 | [diff] [blame] | 1021 |     // Keeps track of the time SF latched the last buffer from this layer. | 
 | 1022 |     // Used in buffer stuffing analysis in FrameTimeline. | 
 | 1023 |     nsecs_t mLastLatchTime = 0; | 
 | 1024 |  | 
| Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 1025 |     mutable bool mDrawingStateModified = false; | 
| Robert Carr | 0758e5d | 2021-03-11 22:15:04 -0800 | [diff] [blame] | 1026 |  | 
| chaviw | 4b129c2 | 2018-04-09 16:19:43 -0700 | [diff] [blame] | 1027 | private: | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 1028 |     virtual void setTransformHint(ui::Transform::RotationFlags) {} | 
 | 1029 |  | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 1030 |     // Returns true if the layer can draw shadows on its border. | 
 | 1031 |     virtual bool canDrawShadows() const { return true; } | 
 | 1032 |  | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 1033 |     Hwc2::IComposerClient::Composition getCompositionType(const DisplayDevice&) const; | 
| Dominik Laskowski | b7251f4 | 2020-04-20 17:42:59 -0700 | [diff] [blame] | 1034 |  | 
| chaviw | 4b129c2 | 2018-04-09 16:19:43 -0700 | [diff] [blame] | 1035 |     /** | 
 | 1036 |      * Returns an unsorted vector of all layers that are part of this tree. | 
 | 1037 |      * That includes the current layer and all its descendants. | 
 | 1038 |      */ | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 1039 |     std::vector<Layer*> getLayersInTree(LayerVector::StateSet); | 
| chaviw | 4b129c2 | 2018-04-09 16:19:43 -0700 | [diff] [blame] | 1040 |     /** | 
 | 1041 |      * Traverses layers that are part of this tree in the correct z order. | 
 | 1042 |      * layersInTree must be sorted before calling this method. | 
 | 1043 |      */ | 
 | 1044 |     void traverseChildrenInZOrderInner(const std::vector<Layer*>& layersInTree, | 
| Marin Shalamanov | 6ad317c | 2020-07-29 23:34:07 +0200 | [diff] [blame] | 1045 |                                        LayerVector::StateSet, const LayerVector::Visitor&); | 
 | 1046 |     LayerVector makeChildrenTraversalList(LayerVector::StateSet, | 
| chaviw | 4b129c2 | 2018-04-09 16:19:43 -0700 | [diff] [blame] | 1047 |                                           const std::vector<Layer*>& layersInTree); | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 1048 |  | 
| Ady Abraham | 60e42ea | 2020-03-09 19:17:31 -0700 | [diff] [blame] | 1049 |     void updateTreeHasFrameRateVote(); | 
| Ady Abraham | a850c18 | 2021-08-04 13:04:37 -0700 | [diff] [blame] | 1050 |     bool propagateFrameRateForLayerTree(FrameRate parentFrameRate, bool* transactionNeeded); | 
 | 1051 |     bool setFrameRateForLayerTree(FrameRate); | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 1052 |     void setZOrderRelativeOf(const wp<Layer>& relativeOf); | 
| Winson Chung | a30f7c9 | 2021-06-29 15:42:56 -0700 | [diff] [blame] | 1053 |     bool isTrustedOverlay() const; | 
| Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 1054 |  | 
 | 1055 |     // Find the root of the cloned hierarchy, this means the first non cloned parent. | 
 | 1056 |     // This will return null if first non cloned parent is not found. | 
 | 1057 |     sp<Layer> getClonedRoot(); | 
 | 1058 |  | 
 | 1059 |     // Finds the top most layer in the hierarchy. This will find the root Layer where the parent is | 
 | 1060 |     // null. | 
 | 1061 |     sp<Layer> getRootLayer(); | 
| Ady Abraham | 60e42ea | 2020-03-09 19:17:31 -0700 | [diff] [blame] | 1062 |  | 
| Bernardo Rufino | a9d0a53 | 2021-06-11 15:59:12 +0100 | [diff] [blame] | 1063 |     // Fills in the touch occlusion mode of the first parent (including this layer) that | 
 | 1064 |     // hasInputInfo() or no-op if no such parent is found. | 
| chaviw | 3277faf | 2021-05-19 16:45:23 -0500 | [diff] [blame] | 1065 |     void fillTouchOcclusionMode(gui::WindowInfo& info); | 
| Bernardo Rufino | a9d0a53 | 2021-06-11 15:59:12 +0100 | [diff] [blame] | 1066 |  | 
| chaviw | 3277faf | 2021-05-19 16:45:23 -0500 | [diff] [blame] | 1067 |     // Fills in the frame and transform info for the gui::WindowInfo | 
 | 1068 |     void fillInputFrameInfo(gui::WindowInfo& info, const ui::Transform& toPhysicalDisplay); | 
| chaviw | 7e72caf | 2020-12-02 16:50:43 -0800 | [diff] [blame] | 1069 |  | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 1070 |     // Cached properties computed from drawing state | 
| Peiyong Lin | 74861ad | 2020-10-14 11:55:33 -0700 | [diff] [blame] | 1071 |     // Effective transform taking into account parent transforms and any parent scaling, which is | 
 | 1072 |     // a transform from the current layer coordinate space to display(screen) coordinate space. | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 1073 |     ui::Transform mEffectiveTransform; | 
 | 1074 |  | 
 | 1075 |     // Bounds of the layer before any transformation is applied and before it has been cropped | 
 | 1076 |     // by its parents. | 
 | 1077 |     FloatRect mSourceBounds; | 
 | 1078 |  | 
 | 1079 |     // Bounds of the layer in layer space. This is the mSourceBounds cropped by its layer crop and | 
 | 1080 |     // its parent bounds. | 
 | 1081 |     FloatRect mBounds; | 
 | 1082 |  | 
 | 1083 |     // Layer bounds in screen space. | 
 | 1084 |     FloatRect mScreenBounds; | 
| chaviw | 606e5cf | 2019-03-01 10:12:10 -0800 | [diff] [blame] | 1085 |  | 
| Robert Carr | c0df312 | 2019-04-11 13:18:21 -0700 | [diff] [blame] | 1086 |     bool mGetHandleCalled = false; | 
| chaviw | 43cb3cb | 2019-05-31 15:23:41 -0700 | [diff] [blame] | 1087 |  | 
| Vishnu Nair | 0f085c6 | 2019-08-30 08:49:12 -0700 | [diff] [blame] | 1088 |     // Tracks the process and user id of the caller when creating this layer | 
 | 1089 |     // to help debugging. | 
 | 1090 |     pid_t mCallingPid; | 
 | 1091 |     uid_t mCallingUid; | 
| chaviw | b4c6e58 | 2019-08-16 14:35:07 -0700 | [diff] [blame] | 1092 |  | 
 | 1093 |     // The current layer is a clone of mClonedFrom. This means that this layer will update it's | 
 | 1094 |     // properties based on mClonedFrom. When mClonedFrom latches a new buffer for BufferLayers, | 
 | 1095 |     // this layer will update it's buffer. When mClonedFrom updates it's drawing state, children, | 
 | 1096 |     // and relatives, this layer will update as well. | 
 | 1097 |     wp<Layer> mClonedFrom; | 
| Vishnu Nair | c97b8db | 2019-10-29 18:19:35 -0700 | [diff] [blame] | 1098 |  | 
 | 1099 |     // The inherited shadow radius after taking into account the layer hierarchy. This is the | 
 | 1100 |     // final shadow radius for this layer. If a shadow is specified for a layer, then effective | 
 | 1101 |     // shadow radius is the set shadow radius, otherwise its the parent's shadow radius. | 
| Vishnu Nair | f37dcfb | 2019-11-16 07:37:09 -0800 | [diff] [blame] | 1102 |     float mEffectiveShadowRadius = 0.f; | 
| Lucas Dupin | c3800b8 | 2020-10-02 16:24:48 -0700 | [diff] [blame] | 1103 |  | 
| Adithya Srinivasan | ac977e6 | 2021-05-21 22:50:56 +0000 | [diff] [blame] | 1104 |     // Game mode for the layer. Set by WindowManagerShell, game mode is used in | 
 | 1105 |     // metrics(SurfaceFlingerStats). | 
| Adithya Srinivasan | 58069dc | 2021-06-04 20:37:02 +0000 | [diff] [blame] | 1106 |     int32_t mGameMode = 0; | 
| Adithya Srinivasan | ac977e6 | 2021-05-21 22:50:56 +0000 | [diff] [blame] | 1107 |  | 
| Lucas Dupin | c3800b8 | 2020-10-02 16:24:48 -0700 | [diff] [blame] | 1108 |     // A list of regions on this layer that should have blurs. | 
| Galia Peycheva | e0acf38 | 2021-04-12 21:22:34 +0200 | [diff] [blame] | 1109 |     const std::vector<BlurRegion> getBlurRegions() const; | 
| Vishnu Nair | 14d218b | 2021-07-13 13:57:39 -0700 | [diff] [blame] | 1110 |  | 
 | 1111 |     bool mIsAtRoot = false; | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 1112 | }; | 
 | 1113 |  | 
| Marin Shalamanov | 4608442 | 2020-10-13 12:33:42 +0200 | [diff] [blame] | 1114 | std::ostream& operator<<(std::ostream& stream, const Layer::FrameRate& rate); | 
 | 1115 |  | 
| Dominik Laskowski | 3415776 | 2018-10-31 13:07:19 -0700 | [diff] [blame] | 1116 | } // namespace android |