| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 1 | /* | 
 | 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 |  | 
 | 17 | #ifndef ANDROID_LAYER_H | 
 | 18 | #define ANDROID_LAYER_H | 
 | 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> | 
| Robert Carr | 720e506 | 2018-07-30 17:45:14 -0700 | [diff] [blame] | 24 | #include <input/InputWindow.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> | 
| Dan Stoza | 80d6116 | 2017-12-20 15:57:52 -0800 | [diff] [blame] | 30 | #include <ui/FloatRect.h> | 
| Svetoslav | d85084b | 2014-03-20 10:28:31 -0700 | [diff] [blame] | 31 | #include <ui/FrameStats.h> | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 32 | #include <ui/GraphicBuffer.h> | 
 | 33 | #include <ui/PixelFormat.h> | 
 | 34 | #include <ui/Region.h> | 
| Peiyong Lin | efefaac | 2018-08-17 12:27:51 -0700 | [diff] [blame] | 35 | #include <ui/Transform.h> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 36 | #include <utils/RefBase.h> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 37 | #include <utils/Timers.h> | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 38 |  | 
| Robert Carr | cdf8320 | 2018-03-07 12:48:34 -0800 | [diff] [blame] | 39 | #include <cstdint> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 40 | #include <list> | 
| Dominik Laskowski | 075d317 | 2018-05-24 15:50:06 -0700 | [diff] [blame] | 41 | #include <optional> | 
| Peiyong Lin | cbc184f | 2018-08-22 13:24:10 -0700 | [diff] [blame] | 42 | #include <vector> | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 43 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 44 | #include "Client.h" | 
| Alec Mouri | 1c8d720 | 2019-06-01 18:51:35 -0700 | [diff] [blame] | 45 | #include "ClientCache.h" | 
 | 46 | #include "DisplayHardware/ComposerHal.h" | 
 | 47 | #include "DisplayHardware/HWComposer.h" | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 48 | #include "FrameTracker.h" | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 49 | #include "LayerVector.h" | 
| Dan Stoza | b9b0883 | 2014-03-13 11:55:57 -0700 | [diff] [blame] | 50 | #include "MonitoredProducer.h" | 
| Alec Mouri | 1c8d720 | 2019-06-01 18:51:35 -0700 | [diff] [blame] | 51 | #include "RenderArea.h" | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 52 | #include "SurfaceFlinger.h" | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 53 | #include "TransactionCompletedThread.h" | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 54 |  | 
| chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 55 | using namespace android::surfaceflinger; | 
 | 56 |  | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 57 | namespace android { | 
 | 58 |  | 
 | 59 | // --------------------------------------------------------------------------- | 
 | 60 |  | 
| Mathias Agopian | 1f7bec6 | 2010-06-25 18:02:21 -0700 | [diff] [blame] | 61 | class Client; | 
| Mathias Agopian | 3e25fd8 | 2013-04-22 17:52:16 +0200 | [diff] [blame] | 62 | class Colorizer; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 63 | class DisplayDevice; | 
 | 64 | class GraphicBuffer; | 
 | 65 | class SurfaceFlinger; | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 66 | class LayerDebugInfo; | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 67 |  | 
| Lloyd Pique | feb73d7 | 2018-12-04 17:23:44 -0800 | [diff] [blame] | 68 | namespace compositionengine { | 
| Lloyd Pique | 37c2c9b | 2018-12-04 17:25:10 -0800 | [diff] [blame] | 69 | class OutputLayer; | 
| Lloyd Pique | a83776c | 2019-01-29 18:42:32 -0800 | [diff] [blame] | 70 | struct LayerFECompositionState; | 
| Lloyd Pique | feb73d7 | 2018-12-04 17:23:44 -0800 | [diff] [blame] | 71 | } | 
 | 72 |  | 
| Lloyd Pique | 4dccc41 | 2018-01-22 17:21:36 -0800 | [diff] [blame] | 73 | namespace impl { | 
 | 74 | class SurfaceInterceptor; | 
 | 75 | } | 
 | 76 |  | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 77 | // --------------------------------------------------------------------------- | 
 | 78 |  | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 79 | struct LayerCreationArgs { | 
| chaviw | de94d0f | 2020-01-22 13:11:25 -0800 | [diff] [blame] | 80 |     LayerCreationArgs(SurfaceFlinger* flinger, const sp<Client> client, std::string name, | 
| Vishnu Nair | 0f085c6 | 2019-08-30 08:49:12 -0700 | [diff] [blame] | 81 |                       uint32_t w, uint32_t h, uint32_t flags, LayerMetadata metadata); | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 82 |  | 
 | 83 |     SurfaceFlinger* flinger; | 
| chaviw | de94d0f | 2020-01-22 13:11:25 -0800 | [diff] [blame] | 84 |     const sp<Client> client; | 
| Dominik Laskowski | 87a07e4 | 2019-10-10 20:38:02 -0700 | [diff] [blame] | 85 |     std::string name; | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 86 |     uint32_t w; | 
 | 87 |     uint32_t h; | 
 | 88 |     uint32_t flags; | 
| Evan Rosky | a1f1e15 | 2019-01-24 16:17:46 -0800 | [diff] [blame] | 89 |     LayerMetadata metadata; | 
| Vishnu Nair | 0f085c6 | 2019-08-30 08:49:12 -0700 | [diff] [blame] | 90 |     pid_t callingPid; | 
 | 91 |     uid_t callingUid; | 
| chaviw | b4c6e58 | 2019-08-16 14:35:07 -0700 | [diff] [blame] | 92 |     sp<const DisplayDevice> displayDevice; | 
 | 93 |     uint32_t textureName; | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 94 | }; | 
 | 95 |  | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 96 | class Layer : public virtual RefBase, compositionengine::LayerFE { | 
| Lloyd Pique | f1c675b | 2018-09-12 20:45:39 -0700 | [diff] [blame] | 97 |     static std::atomic<int32_t> sSequence; | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 98 |     static constexpr int32_t PRIORITY_UNSET = -1; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 99 |  | 
| Mathias Agopian | d606de6 | 2010-05-10 20:06:11 -0700 | [diff] [blame] | 100 | public: | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 101 |     mutable bool contentDirty{false}; | 
| Dan Stoza | ee44edd | 2015-03-23 15:50:23 -0700 | [diff] [blame] | 102 |     Region surfaceDamageRegion; | 
| Andy McFadden | 4df87bd | 2014-04-21 18:08:54 -0700 | [diff] [blame] | 103 |  | 
 | 104 |     // Layer serial number.  This gives layers an explicit ordering, so we | 
 | 105 |     // have a stable sort order when their layer stack and Z-order are | 
 | 106 |     // the same. | 
| Lloyd Pique | f1c675b | 2018-09-12 20:45:39 -0700 | [diff] [blame] | 107 |     int32_t sequence{sSequence++}; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 108 |  | 
 | 109 |     enum { // flags for doTransaction() | 
 | 110 |         eDontUpdateGeometryState = 0x00000001, | 
 | 111 |         eVisibleRegion = 0x00000002, | 
| Robert Carr | 720e506 | 2018-07-30 17:45:14 -0700 | [diff] [blame] | 112 |         eInputInfoChanged = 0x00000004 | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 113 |     }; | 
 | 114 |  | 
 | 115 |     struct Geometry { | 
 | 116 |         uint32_t w; | 
 | 117 |         uint32_t h; | 
| Peiyong Lin | efefaac | 2018-08-17 12:27:51 -0700 | [diff] [blame] | 118 |         ui::Transform transform; | 
| Robert Carr | 3dcabfa | 2016-03-01 18:36:58 -0800 | [diff] [blame] | 119 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 120 |         inline bool operator==(const Geometry& rhs) const { | 
 | 121 |             return (w == rhs.w && h == rhs.h) && (transform.tx() == rhs.transform.tx()) && | 
| Robert Carr | 99e27f0 | 2016-06-16 15:18:02 -0700 | [diff] [blame] | 122 |                     (transform.ty() == rhs.transform.ty()); | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 123 |         } | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 124 |         inline bool operator!=(const Geometry& rhs) const { return !operator==(rhs); } | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 125 |     }; | 
 | 126 |  | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 127 |     struct RoundedCornerState { | 
 | 128 |         RoundedCornerState() = default; | 
 | 129 |         RoundedCornerState(FloatRect cropRect, float radius) | 
 | 130 |               : cropRect(cropRect), radius(radius) {} | 
 | 131 |  | 
 | 132 |         // Rounded rectangle in local layer coordinate space. | 
 | 133 |         FloatRect cropRect = FloatRect(); | 
 | 134 |         // Radius of the rounded rectangle. | 
 | 135 |         float radius = 0.0f; | 
 | 136 |     }; | 
 | 137 |  | 
| Ady Abraham | 71c437d | 2020-01-31 15:56:57 -0800 | [diff] [blame] | 138 |     // FrameRateCompatibility specifies how we should interpret the frame rate associated with | 
 | 139 |     // the layer. | 
 | 140 |     enum class FrameRateCompatibility { | 
 | 141 |         Default, // Layer didn't specify any specific handling strategy | 
 | 142 |  | 
 | 143 |         ExactOrMultiple, // Layer needs the exact frame rate (or a multiple of it) to present the | 
 | 144 |                          // content properly. Any other value will result in a pull down. | 
 | 145 |  | 
 | 146 |         NoVote, // Layer doesn't have any requirements for the refresh rate and | 
 | 147 |                 // should not be considered when the display refresh rate is determined. | 
 | 148 |     }; | 
 | 149 |  | 
 | 150 |     // Encapsulates the frame rate and compatibility of the layer. This information will be used | 
 | 151 |     // when the display refresh rate is determined. | 
 | 152 |     struct FrameRate { | 
 | 153 |         float rate; | 
 | 154 |         FrameRateCompatibility type; | 
 | 155 |  | 
 | 156 |         FrameRate() : rate(0), type(FrameRateCompatibility::Default) {} | 
 | 157 |         FrameRate(float rate, FrameRateCompatibility type) : rate(rate), type(type) {} | 
 | 158 |  | 
 | 159 |         bool operator==(const FrameRate& other) const { | 
 | 160 |             return rate == other.rate && type == other.type; | 
 | 161 |         } | 
 | 162 |  | 
 | 163 |         bool operator!=(const FrameRate& other) const { return !(*this == other); } | 
| Steven Thomas | 62a4cf8 | 2020-01-31 12:04:03 -0800 | [diff] [blame] | 164 |  | 
 | 165 |         // Convert an ANATIVEWINDOW_FRAME_RATE_COMPATIBILITY_* value to a | 
 | 166 |         // Layer::FrameRateCompatibility. Logs fatal if the compatibility value is invalid. | 
 | 167 |         static FrameRateCompatibility convertCompatibility(int8_t compatibility); | 
| Ady Abraham | 71c437d | 2020-01-31 15:56:57 -0800 | [diff] [blame] | 168 |     }; | 
 | 169 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 170 |     struct State { | 
| Marissa Wall | f58c14b | 2018-07-24 10:50:43 -0700 | [diff] [blame] | 171 |         Geometry active_legacy; | 
 | 172 |         Geometry requested_legacy; | 
| Robert Carr | ae06083 | 2016-11-28 10:51:00 -0800 | [diff] [blame] | 173 |         int32_t z; | 
| Fabien Sanglard | f0c53d6 | 2017-03-03 18:58:50 -0800 | [diff] [blame] | 174 |  | 
 | 175 |         // The identifier of the layer stack this layer belongs to. A layer can | 
 | 176 |         // only be associated to a single layer stack. A layer stack is a | 
 | 177 |         // z-ordered group of layers which can be associated to one or more | 
 | 178 |         // displays. Using the same layer stack on different displays is a way | 
 | 179 |         // to achieve mirroring. | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 180 |         uint32_t layerStack; | 
| Fabien Sanglard | f0c53d6 | 2017-03-03 18:58:50 -0800 | [diff] [blame] | 181 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 182 |         uint8_t flags; | 
 | 183 |         uint8_t reserved[2]; | 
 | 184 |         int32_t sequence; // changes when visible regions can change | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 185 |         bool modified; | 
 | 186 |  | 
| Fabien Sanglard | 4ed383c | 2016-12-13 14:02:41 -0800 | [diff] [blame] | 187 |         // Crop is expressed in layer space coordinate. | 
| Marissa Wall | f58c14b | 2018-07-24 10:50:43 -0700 | [diff] [blame] | 188 |         Rect crop_legacy; | 
 | 189 |         Rect requestedCrop_legacy; | 
| Robert Carr | 99e27f0 | 2016-06-16 15:18:02 -0700 | [diff] [blame] | 190 |  | 
| Robert Carr | 0d48072 | 2017-01-10 16:42:54 -0800 | [diff] [blame] | 191 |         // If set, defers this state update until the identified Layer | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 192 |         // receives a frame with the given frameNumber | 
| Marissa Wall | f58c14b | 2018-07-24 10:50:43 -0700 | [diff] [blame] | 193 |         wp<Layer> barrierLayer_legacy; | 
 | 194 |         uint64_t frameNumber_legacy; | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 195 |  | 
| Mathias Agopian | 2ca7939 | 2013-04-02 18:30:32 -0700 | [diff] [blame] | 196 |         // the transparentRegion hint is a bit special, it's latched only | 
 | 197 |         // when we receive a buffer -- this is because it's "content" | 
 | 198 |         // dependent. | 
| Marissa Wall | f58c14b | 2018-07-24 10:50:43 -0700 | [diff] [blame] | 199 |         Region activeTransparentRegion_legacy; | 
 | 200 |         Region requestedTransparentRegion_legacy; | 
| Daniel Nicoara | 2f5f8a5 | 2016-12-20 16:11:58 -0500 | [diff] [blame] | 201 |  | 
| Evan Rosky | 1f6d6d5 | 2018-12-06 10:47:26 -0800 | [diff] [blame] | 202 |         LayerMetadata metadata; | 
| Robert Carr | db66e62 | 2017-04-10 16:55:57 -0700 | [diff] [blame] | 203 |  | 
 | 204 |         // If non-null, a Surface this Surface's Z-order is interpreted relative to. | 
 | 205 |         wp<Layer> zOrderRelativeOf; | 
| chaviw | e5ac40f | 2019-09-24 16:36:55 -0700 | [diff] [blame] | 206 |         bool isRelativeOf{false}; | 
| Robert Carr | db66e62 | 2017-04-10 16:55:57 -0700 | [diff] [blame] | 207 |  | 
 | 208 |         // A list of surfaces whose Z-order is interpreted relative to ours. | 
 | 209 |         SortedVector<wp<Layer>> zOrderRelatives; | 
| chaviw | 13fdc49 | 2017-06-27 12:40:18 -0700 | [diff] [blame] | 210 |  | 
 | 211 |         half4 color; | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 212 |         float cornerRadius; | 
| Lucas Dupin | 19c8f0e | 2019-11-25 17:55:44 -0800 | [diff] [blame] | 213 |         int backgroundBlurRadius; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 214 |  | 
| Robert Carr | 720e506 | 2018-07-30 17:45:14 -0700 | [diff] [blame] | 215 |         bool inputInfoChanged; | 
 | 216 |         InputWindowInfo inputInfo; | 
| Vishnu Nair | 6fabeec | 2019-03-12 13:42:49 -0700 | [diff] [blame] | 217 |         wp<Layer> touchableRegionCrop; | 
| Robert Carr | 720e506 | 2018-07-30 17:45:14 -0700 | [diff] [blame] | 218 |  | 
| Vishnu Nair | fa247b1 | 2020-02-11 08:58:26 -0800 | [diff] [blame] | 219 |         // dataspace is only used by BufferStateLayer and EffectLayer | 
| Valerie Hau | b153bab | 2019-03-05 10:47:28 -0800 | [diff] [blame] | 220 |         ui::Dataspace dataspace; | 
 | 221 |  | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 222 |         // The fields below this point are only used by BufferStateLayer | 
| Valerie Hau | 134651a | 2020-01-28 16:21:22 -0800 | [diff] [blame] | 223 |         uint64_t frameNumber; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 224 |         Geometry active; | 
 | 225 |  | 
 | 226 |         uint32_t transform; | 
 | 227 |         bool transformToDisplayInverse; | 
 | 228 |  | 
 | 229 |         Rect crop; | 
 | 230 |         Region transparentRegionHint; | 
 | 231 |  | 
 | 232 |         sp<GraphicBuffer> buffer; | 
| Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 233 |         client_cache_t clientCacheId; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 234 |         sp<Fence> acquireFence; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 235 |         HdrMetadata hdrMetadata; | 
 | 236 |         Region surfaceDamageRegion; | 
 | 237 |         int32_t api; | 
 | 238 |  | 
 | 239 |         sp<NativeHandle> sidebandStream; | 
| Peiyong Lin | d378863 | 2018-09-18 16:01:31 -0700 | [diff] [blame] | 240 |         mat4 colorTransform; | 
| Peiyong Lin | 747321c | 2018-10-01 10:03:11 -0700 | [diff] [blame] | 241 |         bool hasColorTransform; | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 242 |  | 
| Valerie Hau | a72e281 | 2019-01-23 13:40:39 -0800 | [diff] [blame] | 243 |         // pointer to background color layer that, if set, appears below the buffer state layer | 
 | 244 |         // and the buffer state layer's children.  Z order will be set to | 
 | 245 |         // INT_MIN | 
 | 246 |         sp<Layer> bgColorLayer; | 
| Valerie Hau | ed54efa | 2019-01-11 20:03:14 -0800 | [diff] [blame] | 247 |  | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 248 |         // The deque of callback handles for this frame. The back of the deque contains the most | 
 | 249 |         // recent callback handle. | 
 | 250 |         std::deque<sp<CallbackHandle>> callbackHandles; | 
| Peiyong Lin | c502cb7 | 2019-03-01 15:00:23 -0800 | [diff] [blame] | 251 |         bool colorSpaceAgnostic; | 
| chaviw | fa67b55 | 2019-08-12 16:51:55 -0700 | [diff] [blame] | 252 |         nsecs_t desiredPresentTime = -1; | 
| Vishnu Nair | 08f6eae | 2019-11-26 14:01:39 -0800 | [diff] [blame] | 253 |  | 
 | 254 |         // Length of the cast shadow. If the radius is > 0, a shadow of length shadowRadius will | 
 | 255 |         // be rendered around the layer. | 
| Vishnu Nair | c97b8db | 2019-10-29 18:19:35 -0700 | [diff] [blame] | 256 |         float shadowRadius; | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 257 |  | 
 | 258 |         // Priority of the layer assigned by Window Manager. | 
 | 259 |         int32_t frameRateSelectionPriority; | 
| Steven Thomas | 3172e20 | 2020-01-06 19:25:30 -0800 | [diff] [blame] | 260 |  | 
| Ady Abraham | 71c437d | 2020-01-31 15:56:57 -0800 | [diff] [blame] | 261 |         FrameRate frameRate; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 262 |     }; | 
 | 263 |  | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 264 |     explicit Layer(const LayerCreationArgs& args); | 
| Mathias Agopian | b7e930d | 2010-06-01 15:12:58 -0700 | [diff] [blame] | 265 |     virtual ~Layer(); | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 266 |  | 
| Dominik Laskowski | 7584836 | 2019-11-11 17:57:20 -0800 | [diff] [blame] | 267 |     void onFirstRef() override; | 
 | 268 |  | 
| Dominik Laskowski | f7a09ed | 2019-10-07 13:54:18 -0700 | [diff] [blame] | 269 |     int getWindowType() const { return mWindowType; } | 
 | 270 |  | 
| Chia-I Wu | ab0c319 | 2017-08-01 11:29:00 -0700 | [diff] [blame] | 271 |     void setPrimaryDisplayOnly() { mPrimaryDisplayOnly = true; } | 
| Lloyd Pique | ef36b00 | 2019-01-23 17:52:04 -0800 | [diff] [blame] | 272 |     bool getPrimaryDisplayOnly() const { return mPrimaryDisplayOnly; } | 
| Chia-I Wu | ab0c319 | 2017-08-01 11:29:00 -0700 | [diff] [blame] | 273 |  | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 274 |     // ------------------------------------------------------------------------ | 
 | 275 |     // Geometry setting functions. | 
 | 276 |     // | 
 | 277 |     // The following group of functions are used to specify the layers | 
 | 278 |     // bounds, and the mapping of the texture on to those bounds. According | 
 | 279 |     // to various settings changes to them may apply immediately, or be delayed until | 
 | 280 |     // a pending resize is completed by the producer submitting a buffer. For example | 
 | 281 |     // if we were to change the buffer size, and update the matrix ahead of the | 
 | 282 |     // new buffer arriving, then we would be stretching the buffer to a different | 
 | 283 |     // aspect before and after the buffer arriving, which probably isn't what we wanted. | 
 | 284 |     // | 
 | 285 |     // The first set of geometry functions are controlled by the scaling mode, described | 
 | 286 |     // in window.h. The scaling mode may be set by the client, as it submits buffers. | 
 | 287 |     // This value may be overriden through SurfaceControl, with setOverrideScalingMode. | 
 | 288 |     // | 
 | 289 |     // Put simply, if our scaling mode is SCALING_MODE_FREEZE, then | 
 | 290 |     // matrix updates will not be applied while a resize is pending | 
 | 291 |     // and the size and transform will remain in their previous state | 
 | 292 |     // until a new buffer is submitted. If the scaling mode is another value | 
 | 293 |     // then the old-buffer will immediately be scaled to the pending size | 
 | 294 |     // and the new matrix will be immediately applied following this scaling | 
 | 295 |     // transformation. | 
| Robert Carr | 8d5227b | 2017-03-16 15:41:03 -0700 | [diff] [blame] | 296 |  | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 297 |     // Set the default buffer size for the assosciated Producer, in pixels. This is | 
 | 298 |     // also the rendered size of the layer prior to any transformations. Parent | 
 | 299 |     // or local matrix transformations will not affect the size of the buffer, | 
 | 300 |     // but may affect it's on-screen size or clipping. | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 301 |     virtual bool setSize(uint32_t w, uint32_t h); | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 302 |     // Set a 2x2 transformation matrix on the layer. This transform | 
 | 303 |     // will be applied after parent transforms, but before any final | 
 | 304 |     // producer specified transform. | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 305 |     virtual bool setMatrix(const layer_state_t::matrix22_t& matrix, | 
 | 306 |                            bool allowNonRectPreservingTransforms); | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 307 |  | 
 | 308 |     // This second set of geometry attributes are controlled by | 
 | 309 |     // setGeometryAppliesWithResize, and their default mode is to be | 
 | 310 |     // immediate. If setGeometryAppliesWithResize is specified | 
 | 311 |     // while a resize is pending, then update of these attributes will | 
 | 312 |     // be delayed until the resize completes. | 
 | 313 |  | 
 | 314 |     // setPosition operates in parent buffer space (pre parent-transform) or display | 
 | 315 |     // space for top-level layers. | 
| chaviw | 214c89d | 2019-09-04 16:03:53 -0700 | [diff] [blame] | 316 |     virtual bool setPosition(float x, float y); | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 317 |     // Buffer space | 
| chaviw | 214c89d | 2019-09-04 16:03:53 -0700 | [diff] [blame] | 318 |     virtual bool setCrop_legacy(const Rect& crop); | 
| Robert Carr | 8d5227b | 2017-03-16 15:41:03 -0700 | [diff] [blame] | 319 |  | 
| Robert Carr | 7bf247e | 2017-05-18 14:02:49 -0700 | [diff] [blame] | 320 |     // TODO(b/38182121): Could we eliminate the various latching modes by | 
 | 321 |     // using the layer hierarchy? | 
 | 322 |     // ----------------------------------------------------------------------- | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 323 |     virtual bool setLayer(int32_t z); | 
 | 324 |     virtual bool setRelativeLayer(const sp<IBinder>& relativeToHandle, int32_t relativeZ); | 
| Robert Carr | db66e62 | 2017-04-10 16:55:57 -0700 | [diff] [blame] | 325 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 326 |     virtual bool setAlpha(float alpha); | 
| Valerie Hau | dd0b757 | 2019-01-29 14:59:27 -0800 | [diff] [blame] | 327 |     virtual bool setColor(const half3& /*color*/) { return false; }; | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 328 |  | 
 | 329 |     // Set rounded corner radius for this layer and its children. | 
 | 330 |     // | 
 | 331 |     // We only support 1 radius per layer in the hierarchy, where parent layers have precedence. | 
 | 332 |     // The shape of the rounded corner rectangle is specified by the crop rectangle of the layer | 
 | 333 |     // from which we inferred the rounded corner radius. | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 334 |     virtual bool setCornerRadius(float cornerRadius); | 
| Lucas Dupin | 19c8f0e | 2019-11-25 17:55:44 -0800 | [diff] [blame] | 335 |     // When non-zero, everything below this layer will be blurred by backgroundBlurRadius, which | 
 | 336 |     // is specified in pixels. | 
 | 337 |     virtual bool setBackgroundBlurRadius(int backgroundBlurRadius); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 338 |     virtual bool setTransparentRegionHint(const Region& transparent); | 
 | 339 |     virtual bool setFlags(uint8_t flags, uint8_t mask); | 
 | 340 |     virtual bool setLayerStack(uint32_t layerStack); | 
 | 341 |     virtual uint32_t getLayerStack() const; | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 342 |     virtual void deferTransactionUntil_legacy(const sp<IBinder>& barrierHandle, | 
 | 343 |                                               uint64_t frameNumber); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 344 |     virtual void deferTransactionUntil_legacy(const sp<Layer>& barrierLayer, uint64_t frameNumber); | 
 | 345 |     virtual bool setOverrideScalingMode(int32_t overrideScalingMode); | 
| Evan Rosky | ef876c9 | 2019-01-25 17:46:06 -0800 | [diff] [blame] | 346 |     virtual bool setMetadata(const LayerMetadata& data); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 347 |     virtual bool reparentChildren(const sp<IBinder>& layer); | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 348 |     virtual void setChildrenDrawingParent(const sp<Layer>& layer); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 349 |     virtual bool reparent(const sp<IBinder>& newParentHandle); | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 350 |     virtual bool detachChildren(); | 
| chaviw | 5aedec9 | 2018-10-22 10:40:38 -0700 | [diff] [blame] | 351 |     bool attachChildren(); | 
 | 352 |     bool isLayerDetached() const { return mLayerDetached; } | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 353 |     virtual bool setColorTransform(const mat4& matrix); | 
 | 354 |     virtual mat4 getColorTransform() const; | 
 | 355 |     virtual bool hasColorTransform() const; | 
| Peiyong Lin | c502cb7 | 2019-03-01 15:00:23 -0800 | [diff] [blame] | 356 |     virtual bool isColorSpaceAgnostic() const { return mDrawingState.colorSpaceAgnostic; } | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 357 |  | 
 | 358 |     // Used only to set BufferStateLayer state | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 359 |     virtual bool setTransform(uint32_t /*transform*/) { return false; }; | 
 | 360 |     virtual bool setTransformToDisplayInverse(bool /*transformToDisplayInverse*/) { return false; }; | 
 | 361 |     virtual bool setCrop(const Rect& /*crop*/) { return false; }; | 
 | 362 |     virtual bool setFrame(const Rect& /*frame*/) { return false; }; | 
| Valerie Hau | bf78464 | 2020-01-29 07:25:23 -0800 | [diff] [blame] | 363 |     virtual bool setBuffer(const sp<GraphicBuffer>& /*buffer*/, const sp<Fence>& /*acquireFence*/, | 
 | 364 |                            nsecs_t /*postTime*/, nsecs_t /*desiredPresentTime*/, | 
| Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 365 |                            const client_cache_t& /*clientCacheId*/) { | 
| Ady Abraham | 09bd392 | 2019-04-08 10:44:56 -0700 | [diff] [blame] | 366 |         return false; | 
| Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 367 |     }; | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 368 |     virtual bool setAcquireFence(const sp<Fence>& /*fence*/) { return false; }; | 
 | 369 |     virtual bool setDataspace(ui::Dataspace /*dataspace*/) { return false; }; | 
 | 370 |     virtual bool setHdrMetadata(const HdrMetadata& /*hdrMetadata*/) { return false; }; | 
 | 371 |     virtual bool setSurfaceDamageRegion(const Region& /*surfaceDamage*/) { return false; }; | 
 | 372 |     virtual bool setApi(int32_t /*api*/) { return false; }; | 
 | 373 |     virtual bool setSidebandStream(const sp<NativeHandle>& /*sidebandStream*/) { return false; }; | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 374 |     virtual bool setTransactionCompletedListeners( | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 375 |             const std::vector<sp<CallbackHandle>>& /*handles*/) { | 
| Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 376 |         return false; | 
 | 377 |     }; | 
| Valerie Hau | 7618b23 | 2020-01-09 16:03:08 -0800 | [diff] [blame] | 378 |     virtual void forceSendCallbacks() {} | 
| Valerie Hau | 871d635 | 2020-01-29 08:44:02 -0800 | [diff] [blame] | 379 |     virtual bool addFrameEvent(const sp<Fence>& /*acquireFence*/, nsecs_t /*postedTime*/, | 
 | 380 |                                nsecs_t /*requestedPresentTime*/) { | 
 | 381 |         return false; | 
 | 382 |     } | 
| Valerie Hau | dd0b757 | 2019-01-29 14:59:27 -0800 | [diff] [blame] | 383 |     virtual bool setBackgroundColor(const half3& color, float alpha, ui::Dataspace dataspace); | 
| Peiyong Lin | c502cb7 | 2019-03-01 15:00:23 -0800 | [diff] [blame] | 384 |     virtual bool setColorSpaceAgnostic(const bool agnostic); | 
| Vishnu Nair | c97b8db | 2019-10-29 18:19:35 -0700 | [diff] [blame] | 385 |     bool setShadowRadius(float shadowRadius); | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 386 |     virtual bool setFrameRateSelectionPriority(int32_t priority); | 
 | 387 |     //  If the variable is not set on the layer, it traverses up the tree to inherit the frame | 
 | 388 |     //  rate priority from its parent. | 
 | 389 |     virtual int32_t getFrameRateSelectionPriority() const; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 390 |  | 
| chaviw | 4244e03 | 2019-09-04 11:27:49 -0700 | [diff] [blame] | 391 |     virtual ui::Dataspace getDataSpace() const { return ui::Dataspace::UNKNOWN; } | 
| Chia-I Wu | 01591c9 | 2018-05-22 12:03:00 -0700 | [diff] [blame] | 392 |  | 
| Peiyong Lin | dd9b2ae | 2018-03-01 16:22:45 -0800 | [diff] [blame] | 393 |     // Before color management is introduced, contents on Android have to be | 
 | 394 |     // desaturated in order to match what they appears like visually. | 
 | 395 |     // With color management, these contents will appear desaturated, thus | 
 | 396 |     // needed to be saturated so that they match what they are designed for | 
| Chia-I Wu | 1148147 | 2018-05-04 10:43:19 -0700 | [diff] [blame] | 397 |     // visually. | 
 | 398 |     bool isLegacyDataSpace() const; | 
| Peiyong Lin | dd9b2ae | 2018-03-01 16:22:45 -0800 | [diff] [blame] | 399 |  | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 400 |     virtual sp<compositionengine::LayerFE> getCompositionEngineLayerFE() const; | 
 | 401 |     virtual compositionengine::LayerFECompositionState* editCompositionState(); | 
| Lloyd Pique | feb73d7 | 2018-12-04 17:23:44 -0800 | [diff] [blame] | 402 |  | 
| Dan Stoza | ee44edd | 2015-03-23 15:50:23 -0700 | [diff] [blame] | 403 |     // If we have received a new buffer this frame, we will pass its surface | 
 | 404 |     // damage down to hardware composer. Otherwise, we must send a region with | 
 | 405 |     // one empty rect. | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 406 |     virtual void useSurfaceDamage() {} | 
 | 407 |     virtual void useEmptyDamage() {} | 
| Dan Stoza | ee44edd | 2015-03-23 15:50:23 -0700 | [diff] [blame] | 408 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 409 |     uint32_t getTransactionFlags() const { return mTransactionFlags; } | 
 | 410 |     uint32_t getTransactionFlags(uint32_t flags); | 
 | 411 |     uint32_t setTransactionFlags(uint32_t flags); | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 412 |  | 
| Lloyd Pique | ef36b00 | 2019-01-23 17:52:04 -0800 | [diff] [blame] | 413 |     // Deprecated, please use compositionengine::Output::belongsInOutput() | 
 | 414 |     // instead. | 
 | 415 |     // TODO(lpique): Move the remaining callers (screencap) to the new function. | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 416 |     bool belongsToDisplay(uint32_t layerStack, bool isPrimaryDisplay) const { | 
| Chia-I Wu | ab0c319 | 2017-08-01 11:29:00 -0700 | [diff] [blame] | 417 |         return getLayerStack() == layerStack && (!mPrimaryDisplayOnly || isPrimaryDisplay); | 
 | 418 |     } | 
 | 419 |  | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 420 |     FloatRect getBounds(const Region& activeTransparentRegion) const; | 
 | 421 |     FloatRect getBounds() const; | 
 | 422 |  | 
 | 423 |     // Compute bounds for the layer and cache the results. | 
| Vishnu Nair | c97b8db | 2019-10-29 18:19:35 -0700 | [diff] [blame] | 424 |     void computeBounds(FloatRect parentBounds, ui::Transform parentTransform, float shadowRadius); | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 425 |  | 
| Vishnu Nair | c652ff8 | 2019-03-15 12:48:54 -0700 | [diff] [blame] | 426 |     // Returns the buffer scale transform if a scaling mode is set. | 
 | 427 |     ui::Transform getBufferScaleTransform() const; | 
 | 428 |  | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 429 |     // Get effective layer transform, taking into account all its parent transform with any | 
 | 430 |     // scaling if the parent scaling more is not NATIVE_WINDOW_SCALING_MODE_FREEZE. | 
| Vishnu Nair | c652ff8 | 2019-03-15 12:48:54 -0700 | [diff] [blame] | 431 |     ui::Transform getTransformWithScale(const ui::Transform& bufferScaleTransform) const; | 
 | 432 |  | 
 | 433 |     // Returns the bounds of the layer without any buffer scaling. | 
 | 434 |     FloatRect getBoundsPreScaling(const ui::Transform& bufferScaleTransform) const; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 435 |  | 
| Pablo Ceballos | 40845df | 2016-01-25 17:41:15 -0800 | [diff] [blame] | 436 |     int32_t getSequence() const { return sequence; } | 
 | 437 |  | 
| Mikael Pessa | 2e1608f | 2019-07-19 11:25:35 -0700 | [diff] [blame] | 438 |     // For tracing. | 
 | 439 |     // TODO: Replace with raw buffer id from buffer metadata when that becomes available. | 
 | 440 |     // GraphicBuffer::getId() does not provide a reliable global identifier. Since the traces | 
 | 441 |     // creates its tracks by buffer id and has no way of associating a buffer back to the process | 
 | 442 |     // that created it, the current implementation is only sufficient for cases where a buffer is | 
 | 443 |     // only used within a single layer. | 
| chaviw | d62d306 | 2019-09-04 14:48:02 -0700 | [diff] [blame] | 444 |     uint64_t getCurrentBufferId() const { return getBuffer() ? getBuffer()->getId() : 0; } | 
| Mikael Pessa | 2e1608f | 2019-07-19 11:25:35 -0700 | [diff] [blame] | 445 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 446 |     // ----------------------------------------------------------------------- | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 447 |     // Virtuals | 
| chaviw | 8a01fa4 | 2019-08-19 12:39:31 -0700 | [diff] [blame] | 448 |  | 
 | 449 |     // Provide unique string for each class type in the Layer hierarchy | 
 | 450 |     virtual const char* getType() const = 0; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 451 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 452 |     /* | 
 | 453 |      * isOpaque - true if this surface is opaque | 
| Andy McFadden | 4125a4f | 2014-01-29 17:17:11 -0800 | [diff] [blame] | 454 |      * | 
 | 455 |      * This takes into account the buffer format (i.e. whether or not the | 
 | 456 |      * pixel format includes an alpha channel) and the "opaque" flag set | 
 | 457 |      * on the layer.  It does not examine the current plane alpha value. | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 458 |      */ | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 459 |     virtual bool isOpaque(const Layer::State&) const { return false; } | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 460 |  | 
 | 461 |     /* | 
 | 462 |      * isSecure - true if this surface is secure, that is if it prevents | 
 | 463 |      * screenshots or VNC servers. | 
 | 464 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 465 |     bool isSecure() const; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 466 |  | 
 | 467 |     /* | 
 | 468 |      * isVisible - true if this layer is visible, false otherwise | 
 | 469 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 470 |     virtual bool isVisible() const = 0; | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 471 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 472 |     /* | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 473 |      * isHiddenByPolicy - true if this layer has been forced invisible. | 
 | 474 |      * just because this is false, doesn't mean isVisible() is true. | 
 | 475 |      * For example if this layer has no active buffer, it may not be hidden by | 
 | 476 |      * policy, but it still can not be visible. | 
 | 477 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 478 |     bool isHiddenByPolicy() const; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 479 |  | 
 | 480 |     /* | 
| chaviw | 3e727cd | 2019-01-31 13:41:05 -0800 | [diff] [blame] | 481 |      * Returns whether this layer can receive input. | 
 | 482 |      */ | 
 | 483 |     virtual bool canReceiveInput() const; | 
 | 484 |  | 
 | 485 |     /* | 
| Peiyong Lin | fb530cf | 2018-12-15 05:07:38 +0000 | [diff] [blame] | 486 |      * isProtected - true if the layer may contain protected content in the | 
 | 487 |      * GRALLOC_USAGE_PROTECTED sense. | 
 | 488 |      */ | 
 | 489 |     virtual bool isProtected() const { return false; } | 
 | 490 |  | 
 | 491 |     /* | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 492 |      * isFixedSize - true if content has a fixed size | 
 | 493 |      */ | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 494 |     virtual bool isFixedSize() const { return true; } | 
 | 495 |  | 
| Lloyd Pique | a83776c | 2019-01-29 18:42:32 -0800 | [diff] [blame] | 496 |     /* | 
 | 497 |      * usesSourceCrop - true if content should use a source crop | 
 | 498 |      */ | 
 | 499 |     virtual bool usesSourceCrop() const { return false; } | 
 | 500 |  | 
| Dan Stoza | 436ccf3 | 2018-06-21 12:10:12 -0700 | [diff] [blame] | 501 |     // Most layers aren't created from the main thread, and therefore need to | 
 | 502 |     // grab the SF state lock to access HWC, but ContainerLayer does, so we need | 
 | 503 |     // to avoid grabbing the lock again to avoid deadlock | 
 | 504 |     virtual bool isCreatedFromMainThread() const { return false; } | 
 | 505 |  | 
| Robert Carr | 2e102c9 | 2018-10-23 12:11:15 -0700 | [diff] [blame] | 506 |     bool isRemovedFromCurrentState() const; | 
| chaviw | 8b3871a | 2017-11-01 17:41:01 -0700 | [diff] [blame] | 507 |  | 
| chaviw | 6d89e2d | 2020-01-14 14:42:01 -0800 | [diff] [blame] | 508 |     LayerProto* writeToProto(LayersProto& layersProto, | 
| Alec Mouri | 6b9e991 | 2020-01-21 10:50:24 -0800 | [diff] [blame] | 509 |                              uint32_t traceFlags = SurfaceTracing::TRACE_ALL, | 
 | 510 |                              const sp<const DisplayDevice>& device = nullptr) const; | 
| chaviw | 08f3cb2 | 2020-01-13 13:17:21 -0800 | [diff] [blame] | 511 |  | 
| Vishnu Nair | 8406fd7 | 2019-07-30 11:29:31 -0700 | [diff] [blame] | 512 |     // Write states that are modified by the main thread. This includes drawing | 
 | 513 |     // state as well as buffer data. This should be called in the main or tracing | 
 | 514 |     // thread. | 
 | 515 |     void writeToProtoDrawingState(LayerProto* layerInfo, | 
 | 516 |                                   uint32_t traceFlags = SurfaceTracing::TRACE_ALL) const; | 
| Vishnu Nair | 8406fd7 | 2019-07-30 11:29:31 -0700 | [diff] [blame] | 517 |     // Write drawing or current state. If writing current state, the caller should hold the | 
 | 518 |     // external mStateLock. If writing drawing state, this function should be called on the | 
 | 519 |     // main or tracing thread. | 
 | 520 |     void writeToProtoCommonState(LayerProto* layerInfo, LayerVector::StateSet stateSet, | 
 | 521 |                                  uint32_t traceFlags = SurfaceTracing::TRACE_ALL) const; | 
| Yiwei Zhang | 7124ad3 | 2018-02-21 13:02:45 -0800 | [diff] [blame] | 522 |  | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 523 |     virtual Geometry getActiveGeometry(const Layer::State& s) const { return s.active_legacy; } | 
 | 524 |     virtual uint32_t getActiveWidth(const Layer::State& s) const { return s.active_legacy.w; } | 
 | 525 |     virtual uint32_t getActiveHeight(const Layer::State& s) const { return s.active_legacy.h; } | 
| Peiyong Lin | efefaac | 2018-08-17 12:27:51 -0700 | [diff] [blame] | 526 |     virtual ui::Transform getActiveTransform(const Layer::State& s) const { | 
| Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 527 |         return s.active_legacy.transform; | 
 | 528 |     } | 
 | 529 |     virtual Region getActiveTransparentRegion(const Layer::State& s) const { | 
 | 530 |         return s.activeTransparentRegion_legacy; | 
 | 531 |     } | 
 | 532 |     virtual Rect getCrop(const Layer::State& s) const { return s.crop_legacy; } | 
| Lloyd Pique | f16688f | 2019-02-19 17:47:57 -0800 | [diff] [blame] | 533 |     virtual bool needsFiltering(const sp<const DisplayDevice>&) const { return false; } | 
| Peiyong Lin | 97067b0 | 2019-03-29 17:34:45 +0000 | [diff] [blame] | 534 |  | 
| chaviw | 74b0317 | 2019-08-19 11:09:03 -0700 | [diff] [blame] | 535 |     // This layer is not a clone, but it's the parent to the cloned hierarchy. The | 
 | 536 |     // variable mClonedChild represents the top layer that will be cloned so this | 
 | 537 |     // layer will be the parent of mClonedChild. | 
 | 538 |     // The layers in the cloned hierarchy will match the lifetime of the real layers. That is | 
 | 539 |     // if the real layer is destroyed, then the clone layer will also be destroyed. | 
 | 540 |     sp<Layer> mClonedChild; | 
| chaviw | b4c6e58 | 2019-08-16 14:35:07 -0700 | [diff] [blame] | 541 |  | 
| chaviw | 74b0317 | 2019-08-19 11:09:03 -0700 | [diff] [blame] | 542 |     virtual sp<Layer> createClone() = 0; | 
 | 543 |     void updateMirrorInfo(); | 
 | 544 |     virtual void updateCloneBufferInfo(){}; | 
 | 545 |  | 
 | 546 | protected: | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 547 |     sp<compositionengine::LayerFE> asLayerFE() const; | 
| chaviw | 74b0317 | 2019-08-19 11:09:03 -0700 | [diff] [blame] | 548 |     sp<Layer> getClonedFrom() { return mClonedFrom != nullptr ? mClonedFrom.promote() : nullptr; } | 
 | 549 |     bool isClone() { return mClonedFrom != nullptr; } | 
 | 550 |     bool isClonedFromAlive() { return getClonedFrom() != nullptr; } | 
 | 551 |  | 
| chaviw | b4c6e58 | 2019-08-16 14:35:07 -0700 | [diff] [blame] | 552 |     virtual void setInitialValuesForClone(const sp<Layer>& clonedFrom); | 
 | 553 |  | 
| chaviw | 74b0317 | 2019-08-19 11:09:03 -0700 | [diff] [blame] | 554 |     void updateClonedDrawingState(std::map<sp<Layer>, sp<Layer>>& clonedLayersMap); | 
 | 555 |     void updateClonedChildren(const sp<Layer>& mirrorRoot, | 
 | 556 |                               std::map<sp<Layer>, sp<Layer>>& clonedLayersMap); | 
| chaviw | af87b3e | 2019-10-01 16:59:28 -0700 | [diff] [blame] | 557 |     void updateClonedRelatives(const std::map<sp<Layer>, sp<Layer>>& clonedLayersMap); | 
| chaviw | 74b0317 | 2019-08-19 11:09:03 -0700 | [diff] [blame] | 558 |     void addChildToDrawing(const sp<Layer>& layer); | 
| chaviw | af87b3e | 2019-10-01 16:59:28 -0700 | [diff] [blame] | 559 |     void updateClonedInputInfo(const std::map<sp<Layer>, sp<Layer>>& clonedLayersMap); | 
| Vishnu Nair | b87d94f | 2020-02-13 09:17:36 -0800 | [diff] [blame] | 560 |     virtual std::optional<compositionengine::LayerFE::LayerSettings> prepareClientComposition( | 
 | 561 |             compositionengine::LayerFE::ClientCompositionTargetSettings&); | 
 | 562 |     virtual std::optional<compositionengine::LayerFE::LayerSettings> prepareShadowClientComposition( | 
 | 563 |             const LayerFE::LayerSettings& layerSettings, const Rect& displayViewport, | 
 | 564 |             ui::Dataspace outputDataspace); | 
 | 565 |     // Modifies the passed in layer settings to clear the contents. If the blackout flag is set, | 
 | 566 |     // the settings clears the content with a solid black fill. | 
 | 567 |     void prepareClearClientComposition(LayerFE::LayerSettings& layerSettings, bool blackout) const; | 
| chaviw | 74b0317 | 2019-08-19 11:09:03 -0700 | [diff] [blame] | 568 |  | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 569 | public: | 
| Lloyd Pique | cb54b3b | 2019-01-29 18:42:54 -0800 | [diff] [blame] | 570 |     /* | 
 | 571 |      * compositionengine::LayerFE overrides | 
 | 572 |      */ | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 573 |     const compositionengine::LayerFECompositionState* getCompositionState() const override; | 
| Lloyd Pique | f16688f | 2019-02-19 17:47:57 -0800 | [diff] [blame] | 574 |     bool onPreComposition(nsecs_t) override; | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 575 |     void prepareCompositionState(compositionengine::LayerFE::StateSubset subset) override; | 
| Vishnu Nair | b87d94f | 2020-02-13 09:17:36 -0800 | [diff] [blame] | 576 |     std::vector<compositionengine::LayerFE::LayerSettings> prepareClientCompositionList( | 
| Lloyd Pique | f16688f | 2019-02-19 17:47:57 -0800 | [diff] [blame] | 577 |             compositionengine::LayerFE::ClientCompositionTargetSettings&) override; | 
| Lloyd Pique | cb54b3b | 2019-01-29 18:42:54 -0800 | [diff] [blame] | 578 |     void onLayerDisplayed(const sp<Fence>& releaseFence) override; | 
| Lloyd Pique | a83776c | 2019-01-29 18:42:32 -0800 | [diff] [blame] | 579 |     const char* getDebugName() const override; | 
| Lloyd Pique | cb54b3b | 2019-01-29 18:42:54 -0800 | [diff] [blame] | 580 |  | 
| Lloyd Pique | a83776c | 2019-01-29 18:42:32 -0800 | [diff] [blame] | 581 | protected: | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 582 |     void prepareBasicGeometryCompositionState(); | 
 | 583 |     void prepareGeometryCompositionState(); | 
 | 584 |     virtual void preparePerFrameCompositionState(); | 
 | 585 |     void prepareCursorCompositionState(); | 
| Lloyd Pique | a83776c | 2019-01-29 18:42:32 -0800 | [diff] [blame] | 586 |  | 
 | 587 | public: | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 588 |     virtual void setDefaultBufferSize(uint32_t /*w*/, uint32_t /*h*/) {} | 
| David Sodman | eb085e0 | 2017-10-05 18:49:04 -0700 | [diff] [blame] | 589 |  | 
| Chia-I Wu | 692e083 | 2018-06-05 15:46:58 -0700 | [diff] [blame] | 590 |     virtual bool isHdrY410() const { return false; } | 
 | 591 |  | 
| Lloyd Pique | 37c2c9b | 2018-12-04 17:25:10 -0800 | [diff] [blame] | 592 |     Hwc2::IComposerClient::Composition getCompositionType( | 
 | 593 |             const sp<const DisplayDevice>& display) const; | 
 | 594 |     bool getClearClientTarget(const sp<const DisplayDevice>& display) const; | 
| Riley Andrews | 03414a1 | 2014-07-01 14:22:59 -0700 | [diff] [blame] | 595 |  | 
| Ana Krulec | 010d219 | 2018-10-08 06:29:54 -0700 | [diff] [blame] | 596 |     virtual bool shouldPresentNow(nsecs_t /*expectedPresentTime*/) const { return false; } | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 597 |     virtual void setTransformHint(uint32_t /*orientation*/) const { } | 
| Dan Stoza | 6b9454d | 2014-11-07 16:00:59 -0800 | [diff] [blame] | 598 |  | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 599 |     /* | 
| Dan Stoza | e77c766 | 2016-05-13 11:37:28 -0700 | [diff] [blame] | 600 |      * called after composition. | 
 | 601 |      * returns true if the layer latched a new buffer this frame. | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 602 |      */ | 
| Adithya Srinivasan | b69e076 | 2019-11-11 18:39:53 -0800 | [diff] [blame] | 603 |     virtual bool onPostComposition(sp<const DisplayDevice> /*displayDevice*/, | 
| Dominik Laskowski | 075d317 | 2018-05-24 15:50:06 -0700 | [diff] [blame] | 604 |                                    const std::shared_ptr<FenceTime>& /*glDoneFence*/, | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 605 |                                    const std::shared_ptr<FenceTime>& /*presentFence*/, | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 606 |                                    const CompositorTiming& /*compositorTiming*/) { | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 607 |         return false; | 
 | 608 |     } | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 609 |  | 
| Dan Stoza | 9e56aa0 | 2015-11-02 13:00:03 -0800 | [diff] [blame] | 610 |     // If a buffer was replaced this frame, release the former buffer | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 611 |     virtual void releasePendingBuffer(nsecs_t /*dequeueReadyTime*/) { } | 
 | 612 |  | 
| Valerie Hau | 871d635 | 2020-01-29 08:44:02 -0800 | [diff] [blame] | 613 |     virtual void finalizeFrameEventHistory(const std::shared_ptr<FenceTime>& /*glDoneFence*/, | 
 | 614 |                                            const CompositorTiming& /*compositorTiming*/) {} | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 615 |     /* | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 616 |      * doTransaction - process the transaction. This is a good place to figure | 
 | 617 |      * out which attributes of the surface have changed. | 
 | 618 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 619 |     uint32_t doTransaction(uint32_t transactionFlags); | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 620 |  | 
 | 621 |     /* | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 622 |      * latchBuffer - called each time the screen is redrawn and returns whether | 
 | 623 |      * the visible regions need to be recomputed (this is a fairly heavy | 
 | 624 |      * operation, so this should be set only if needed). Typically this is used | 
 | 625 |      * to figure out if the content or size of a surface has changed. | 
 | 626 |      */ | 
| Dominik Laskowski | a8955dd | 2019-07-10 10:19:09 -0700 | [diff] [blame] | 627 |     virtual bool latchBuffer(bool& /*recomputeVisibleRegions*/, nsecs_t /*latchTime*/, | 
 | 628 |                              nsecs_t /*expectedPresentTime*/) { | 
 | 629 |         return false; | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 630 |     } | 
 | 631 |  | 
 | 632 |     virtual bool isBufferLatched() const { return false; } | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 633 |  | 
| chaviw | 49a108c | 2019-08-12 11:23:06 -0700 | [diff] [blame] | 634 |     virtual void latchAndReleaseBuffer() {} | 
 | 635 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 636 |     /* | 
| Vishnu Nair | da9c85a | 2019-06-03 17:26:48 -0700 | [diff] [blame] | 637 |      * Remove relative z for the layer if its relative parent is not part of the | 
 | 638 |      * provided layer tree. | 
 | 639 |      */ | 
 | 640 |     void removeRelativeZ(const std::vector<Layer*>& layersInTree); | 
 | 641 |  | 
 | 642 |     /* | 
 | 643 |      * Remove from current state and mark for removal. | 
 | 644 |      */ | 
 | 645 |     void removeFromCurrentState(); | 
 | 646 |  | 
 | 647 |     /* | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 648 |      * 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] | 649 |      * removed from the current list to the pending removal list | 
 | 650 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 651 |     void onRemovedFromCurrentState(); | 
| Chia-I Wu | c665702 | 2017-08-15 11:18:17 -0700 | [diff] [blame] | 652 |  | 
| chaviw | 61626f2 | 2018-11-15 16:26:27 -0800 | [diff] [blame] | 653 |     /* | 
 | 654 |      * Called when the layer is added back to the current state list. | 
 | 655 |      */ | 
 | 656 |     void addToCurrentState(); | 
 | 657 |  | 
| Andy McFadden | bf974ab | 2012-12-04 16:51:15 -0800 | [diff] [blame] | 658 |     // Updates the transform hint in our SurfaceFlingerConsumer to match | 
| Mathias Agopian | 8430095 | 2012-11-21 16:02:13 -0800 | [diff] [blame] | 659 |     // the current orientation of the display device. | 
| Dominik Laskowski | a2edf61 | 2018-06-01 13:15:16 -0700 | [diff] [blame] | 660 |     void updateTransformHint(const sp<const DisplayDevice>& display) const; | 
| Andy McFadden | 6905205 | 2012-09-14 16:10:11 -0700 | [diff] [blame] | 661 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 662 |     /* | 
 | 663 |      * returns the rectangle that crops the content of the layer and scales it | 
 | 664 |      * to the layer's size. | 
 | 665 |      */ | 
| chaviw | 4244e03 | 2019-09-04 11:27:49 -0700 | [diff] [blame] | 666 |     virtual Rect getBufferCrop() const { return Rect(); } | 
 | 667 |  | 
 | 668 |     /* | 
 | 669 |      * Returns the transform applied to the buffer. | 
 | 670 |      */ | 
 | 671 |     virtual uint32_t getBufferTransform() const { return 0; } | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 672 |  | 
| chaviw | d62d306 | 2019-09-04 14:48:02 -0700 | [diff] [blame] | 673 |     virtual sp<GraphicBuffer> getBuffer() const { return nullptr; } | 
 | 674 |  | 
| Eric Penner | 51c59cd | 2014-07-28 19:51:58 -0700 | [diff] [blame] | 675 |     /* | 
| Marissa Wall | fd66862 | 2018-05-10 10:21:13 -0700 | [diff] [blame] | 676 |      * Returns if a frame is ready | 
| Eric Penner | 51c59cd | 2014-07-28 19:51:58 -0700 | [diff] [blame] | 677 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 678 |     virtual bool hasReadyFrame() const { return false; } | 
| Eric Penner | 51c59cd | 2014-07-28 19:51:58 -0700 | [diff] [blame] | 679 |  | 
| Marissa Wall | fd66862 | 2018-05-10 10:21:13 -0700 | [diff] [blame] | 680 |     virtual int32_t getQueuedFrameCount() const { return 0; } | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 681 |  | 
| Dan Stoza | 9e56aa0 | 2015-11-02 13:00:03 -0800 | [diff] [blame] | 682 |     // ----------------------------------------------------------------------- | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 683 |     inline const State& getDrawingState() const { return mDrawingState; } | 
 | 684 |     inline const State& getCurrentState() const { return mCurrentState; } | 
 | 685 |     inline State& getCurrentState() { return mCurrentState; } | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 686 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 687 |     LayerDebugInfo getLayerDebugInfo() const; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 688 |  | 
 | 689 |     /* always call base class first */ | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 690 |     static void miniDumpHeader(std::string& result); | 
| Lloyd Pique | 37c2c9b | 2018-12-04 17:25:10 -0800 | [diff] [blame] | 691 |     void miniDump(std::string& result, const sp<DisplayDevice>& display) const; | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 692 |     void dumpFrameStats(std::string& result) const; | 
 | 693 |     void dumpFrameEvents(std::string& result); | 
| Vishnu Nair | 0f085c6 | 2019-08-30 08:49:12 -0700 | [diff] [blame] | 694 |     void dumpCallingUidPid(std::string& result) const; | 
| Svetoslav | d85084b | 2014-03-20 10:28:31 -0700 | [diff] [blame] | 695 |     void clearFrameStats(); | 
| Jamie Gennis | 6547ff4 | 2013-07-16 20:12:42 -0700 | [diff] [blame] | 696 |     void logFrameStats(); | 
| Svetoslav | d85084b | 2014-03-20 10:28:31 -0700 | [diff] [blame] | 697 |     void getFrameStats(FrameStats* outStats) const; | 
| Mathias Agopian | 1b5e102 | 2010-04-20 17:55:49 -0700 | [diff] [blame] | 698 |  | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 699 |     virtual std::vector<OccupancyTracker::Segment> getOccupancyHistory(bool /*forceFlush*/) { | 
 | 700 |         return {}; | 
 | 701 |     } | 
| Dan Stoza | e77c766 | 2016-05-13 11:37:28 -0700 | [diff] [blame] | 702 |  | 
| Brian Anderson | 5ea5e59 | 2016-12-01 16:54:33 -0800 | [diff] [blame] | 703 |     void onDisconnect(); | 
| Brian Anderson | 3890c39 | 2016-07-25 12:48:08 -0700 | [diff] [blame] | 704 |     void addAndGetFrameTimestamps(const NewFrameEventsEntry* newEntry, | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 705 |                                   FrameEventHistoryDelta* outDelta); | 
| Pablo Ceballos | ce796e7 | 2016-02-04 19:10:51 -0800 | [diff] [blame] | 706 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 707 |     virtual bool getTransformToDisplayInverse() const { return false; } | 
| Robert Carr | 367c568 | 2016-06-20 11:55:28 -0700 | [diff] [blame] | 708 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 709 |     ui::Transform getTransform() const; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 710 |  | 
| Robert Carr | 6452f12 | 2017-03-21 10:41:29 -0700 | [diff] [blame] | 711 |     // Returns the Alpha of the Surface, accounting for the Alpha | 
 | 712 |     // of parent Surfaces in the hierarchy (alpha's will be multiplied | 
 | 713 |     // down the hierarchy). | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 714 |     half getAlpha() const; | 
 | 715 |     half4 getColor() const; | 
| Lucas Dupin | 19c8f0e | 2019-11-25 17:55:44 -0800 | [diff] [blame] | 716 |     int32_t getBackgroundBlurRadius() const; | 
| Vishnu Nair | b87d94f | 2020-02-13 09:17:36 -0800 | [diff] [blame] | 717 |     bool drawShadows() const { return mEffectiveShadowRadius > 0.f; }; | 
| Robert Carr | 6452f12 | 2017-03-21 10:41:29 -0700 | [diff] [blame] | 718 |  | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 719 |     // Returns how rounded corners should be drawn for this layer. | 
 | 720 |     // This will traverse the hierarchy until it reaches its root, finding topmost rounded | 
 | 721 |     // corner definition and converting it into current layer's coordinates. | 
 | 722 |     // As of now, only 1 corner radius per display list is supported. Subsequent ones will be | 
 | 723 |     // ignored. | 
| Valerie Hau | 92bf548 | 2020-02-10 09:49:08 -0800 | [diff] [blame] | 724 |     virtual RoundedCornerState getRoundedCornerState() const; | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 725 |  | 
| Vishnu Nair | 08f6eae | 2019-11-26 14:01:39 -0800 | [diff] [blame] | 726 |     renderengine::ShadowSettings getShadowSettings(const Rect& viewport) const; | 
 | 727 |  | 
| Edgar Arriaga | 844fa67 | 2020-01-16 14:21:42 -0800 | [diff] [blame] | 728 |     /** | 
 | 729 |      * Traverse this layer and it's hierarchy of children directly. Unlike traverseInZOrder | 
 | 730 |      * which will not emit children who have relativeZOrder to another layer, this method | 
 | 731 |      * just directly emits all children. It also emits them in no particular order. | 
 | 732 |      * So this method is not suitable for graphical operations, as it doesn't represent | 
 | 733 |      * the scene state, but it's also more efficient than traverseInZOrder and so useful for | 
 | 734 |      * book-keeping. | 
 | 735 |      */ | 
 | 736 |     void traverse(LayerVector::StateSet stateSet, const LayerVector::Visitor& visitor); | 
| Dan Stoza | 412903f | 2017-04-27 13:42:17 -0700 | [diff] [blame] | 737 |     void traverseInReverseZOrder(LayerVector::StateSet stateSet, | 
 | 738 |                                  const LayerVector::Visitor& visitor); | 
 | 739 |     void traverseInZOrder(LayerVector::StateSet stateSet, const LayerVector::Visitor& visitor); | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 740 |  | 
| chaviw | 4b129c2 | 2018-04-09 16:19:43 -0700 | [diff] [blame] | 741 |     /** | 
 | 742 |      * Traverse only children in z order, ignoring relative layers that are not children of the | 
 | 743 |      * parent. | 
 | 744 |      */ | 
| chaviw | a76b271 | 2017-09-20 12:02:26 -0700 | [diff] [blame] | 745 |     void traverseChildrenInZOrder(LayerVector::StateSet stateSet, | 
 | 746 |                                   const LayerVector::Visitor& visitor); | 
 | 747 |  | 
| Chia-I Wu | 98f1c10 | 2017-05-30 14:54:08 -0700 | [diff] [blame] | 748 |     size_t getChildrenCount() const; | 
| Valerie Hau | c568680 | 2019-11-22 14:18:09 -0800 | [diff] [blame] | 749 |  | 
 | 750 |     // ONLY CALL THIS FROM THE LAYER DTOR! | 
 | 751 |     // See b/141111965.  We need to add current children to offscreen layers in | 
 | 752 |     // the layer dtor so as not to dangle layers.  Since the layer has not | 
 | 753 |     // committed its transaction when the layer is destroyed, we must add | 
 | 754 |     // current children.  This is safe in the dtor as we will no longer update | 
 | 755 |     // the current state, but should not be called anywhere else! | 
 | 756 |     LayerVector& getCurrentChildren() { return mCurrentChildren; } | 
 | 757 |  | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 758 |     void addChild(const sp<Layer>& layer); | 
 | 759 |     // Returns index if removed, or negative value otherwise | 
 | 760 |     // for symmetry with Vector::remove | 
 | 761 |     ssize_t removeChild(const sp<Layer>& layer); | 
| Chia-I Wu | e41dbe6 | 2017-06-13 14:10:56 -0700 | [diff] [blame] | 762 |     sp<Layer> getParent() const { return mCurrentParent.promote(); } | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 763 |     bool hasParent() const { return getParent() != nullptr; } | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 764 |     Rect getScreenBounds(bool reduceTransparentRegion = true) const; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 765 |     bool setChildLayer(const sp<Layer>& childLayer, int32_t z); | 
| Robert Carr | 503c704 | 2017-09-27 15:06:08 -0700 | [diff] [blame] | 766 |     bool setChildRelativeLayer(const sp<Layer>& childLayer, | 
 | 767 |             const sp<IBinder>& relativeToHandle, int32_t relativeZ); | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 768 |  | 
 | 769 |     // Copy the current list of children to the drawing state. Called by | 
 | 770 |     // SurfaceFlinger to complete a transaction. | 
 | 771 |     void commitChildList(); | 
| chaviw | 301b1d8 | 2019-11-06 13:15:09 -0800 | [diff] [blame] | 772 |     int32_t getZ(LayerVector::StateSet stateSet) const; | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 773 |     virtual void pushPendingState(); | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 774 |  | 
| Vishnu Nair | 88a11f2 | 2018-11-28 18:30:57 -0800 | [diff] [blame] | 775 |     /** | 
 | 776 |      * Returns active buffer size in the correct orientation. Buffer size is determined by undoing | 
 | 777 |      * any buffer transformations. If the layer has no buffer then return INVALID_RECT. | 
 | 778 |      */ | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 779 |     virtual Rect getBufferSize(const Layer::State&) const { return Rect::INVALID_RECT; } | 
| Vishnu Nair | 88a11f2 | 2018-11-28 18:30:57 -0800 | [diff] [blame] | 780 |  | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 781 |     /** | 
 | 782 |      * Returns the source bounds. If the bounds are not defined, it is inferred from the | 
 | 783 |      * buffer size. Failing that, the bounds are determined from the passed in parent bounds. | 
 | 784 |      * For the root layer, this is the display viewport size. | 
 | 785 |      */ | 
 | 786 |     virtual FloatRect computeSourceBounds(const FloatRect& parentBounds) const { | 
 | 787 |         return parentBounds; | 
 | 788 |     } | 
 | 789 |  | 
| Lloyd Pique | 37c2c9b | 2018-12-04 17:25:10 -0800 | [diff] [blame] | 790 |     compositionengine::OutputLayer* findOutputLayerForDisplay( | 
 | 791 |             const sp<const DisplayDevice>& display) const; | 
 | 792 |  | 
| Lloyd Pique | a246866 | 2019-03-07 21:31:06 -0800 | [diff] [blame] | 793 |     Region debugGetVisibleRegionOnDefaultDisplay() const; | 
 | 794 |  | 
| Vishnu Nair | efc42e2 | 2019-12-03 17:36:12 -0800 | [diff] [blame] | 795 |     /** | 
 | 796 |      * Returns the cropped buffer size or the layer crop if the layer has no buffer. Return | 
 | 797 |      * INVALID_RECT if the layer has no buffer and no crop. | 
 | 798 |      * A layer with an invalid buffer size and no crop is considered to be boundless. The layer | 
 | 799 |      * bounds are constrained by its parent bounds. | 
 | 800 |      */ | 
 | 801 |     Rect getCroppedBufferSize(const Layer::State& s) const; | 
 | 802 |  | 
| Steven Thomas | 62a4cf8 | 2020-01-31 12:04:03 -0800 | [diff] [blame] | 803 |     bool setFrameRate(FrameRate frameRate); | 
| Ady Abraham | 71c437d | 2020-01-31 15:56:57 -0800 | [diff] [blame] | 804 |     virtual FrameRate getFrameRate() const; | 
| Steven Thomas | 3172e20 | 2020-01-06 19:25:30 -0800 | [diff] [blame] | 805 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 806 | protected: | 
 | 807 |     // constant | 
 | 808 |     sp<SurfaceFlinger> mFlinger; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 809 |     /* | 
 | 810 |      * Trivial class, used to ensure that mFlinger->onLayerDestroyed(mLayer) | 
 | 811 |      * is called. | 
 | 812 |      */ | 
 | 813 |     class LayerCleaner { | 
 | 814 |         sp<SurfaceFlinger> mFlinger; | 
| Robert Carr | 2e102c9 | 2018-10-23 12:11:15 -0700 | [diff] [blame] | 815 |         sp<Layer> mLayer; | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 816 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 817 |     protected: | 
| Irvel | 468051e | 2016-06-13 16:44:44 -0700 | [diff] [blame] | 818 |         ~LayerCleaner() { | 
 | 819 |             // destroy client resources | 
| Robert Carr | 2e102c9 | 2018-10-23 12:11:15 -0700 | [diff] [blame] | 820 |             mFlinger->onHandleDestroyed(mLayer); | 
| Irvel | 468051e | 2016-06-13 16:44:44 -0700 | [diff] [blame] | 821 |         } | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 822 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 823 |     public: | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 824 |         LayerCleaner(const sp<SurfaceFlinger>& flinger, const sp<Layer>& layer) | 
 | 825 |               : mFlinger(flinger), mLayer(layer) {} | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 826 |     }; | 
 | 827 |  | 
| Lloyd Pique | 4dccc41 | 2018-01-22 17:21:36 -0800 | [diff] [blame] | 828 |     friend class impl::SurfaceInterceptor; | 
| David Sodman | eb085e0 | 2017-10-05 18:49:04 -0700 | [diff] [blame] | 829 |  | 
| Lloyd Pique | d6b579f | 2018-04-06 15:29:10 -0700 | [diff] [blame] | 830 |     // For unit tests | 
 | 831 |     friend class TestableSurfaceFlinger; | 
| Ana Krulec | c84d09b | 2019-11-02 23:10:29 +0100 | [diff] [blame] | 832 |     friend class RefreshRateSelectionTest; | 
| Lloyd Pique | d6b579f | 2018-04-06 15:29:10 -0700 | [diff] [blame] | 833 |  | 
| Valerie Hau | b153bab | 2019-03-05 10:47:28 -0800 | [diff] [blame] | 834 |     virtual void commitTransaction(const State& stateToCommit); | 
| Mathias Agopian | 1eae0ee | 2013-06-05 16:59:15 -0700 | [diff] [blame] | 835 |  | 
| Mathias Agopian | 3330b20 | 2009-10-05 17:07:12 -0700 | [diff] [blame] | 836 |     uint32_t getEffectiveUsage(uint32_t usage) const; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 837 |  | 
| Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 838 |     /** | 
 | 839 |      * Setup rounded corners coordinates of this layer, taking into account the layer bounds and | 
 | 840 |      * crop coordinates, transforming them into layer space. | 
 | 841 |      */ | 
 | 842 |     void setupRoundedCornersCropCoordinates(Rect win, const FloatRect& roundedCornersCrop) const; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 843 |     void setParent(const sp<Layer>& layer); | 
| Robert Carr | 29abff8 | 2017-12-04 13:51:20 -0800 | [diff] [blame] | 844 |     LayerVector makeTraversalList(LayerVector::StateSet stateSet, bool* outSkipRelativeZUsers); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 845 |     void addZOrderRelative(const wp<Layer>& relative); | 
 | 846 |     void removeZOrderRelative(const wp<Layer>& relative); | 
| Robert Carr | db66e62 | 2017-04-10 16:55:57 -0700 | [diff] [blame] | 847 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 848 |     class SyncPoint { | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 849 |     public: | 
| chaviw | 43cb3cb | 2019-05-31 15:23:41 -0700 | [diff] [blame] | 850 |         explicit SyncPoint(uint64_t frameNumber, wp<Layer> requestedSyncLayer) | 
 | 851 |               : mFrameNumber(frameNumber), | 
 | 852 |                 mFrameIsAvailable(false), | 
 | 853 |                 mTransactionIsApplied(false), | 
 | 854 |                 mRequestedSyncLayer(requestedSyncLayer) {} | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 855 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 856 |         uint64_t getFrameNumber() const { return mFrameNumber; } | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 857 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 858 |         bool frameIsAvailable() const { return mFrameIsAvailable; } | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 859 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 860 |         void setFrameAvailable() { mFrameIsAvailable = true; } | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 861 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 862 |         bool transactionIsApplied() const { return mTransactionIsApplied; } | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 863 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 864 |         void setTransactionApplied() { mTransactionIsApplied = true; } | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 865 |  | 
| chaviw | 43cb3cb | 2019-05-31 15:23:41 -0700 | [diff] [blame] | 866 |         sp<Layer> getRequestedSyncLayer() { return mRequestedSyncLayer.promote(); } | 
 | 867 |  | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 868 |     private: | 
 | 869 |         const uint64_t mFrameNumber; | 
 | 870 |         std::atomic<bool> mFrameIsAvailable; | 
 | 871 |         std::atomic<bool> mTransactionIsApplied; | 
| chaviw | 43cb3cb | 2019-05-31 15:23:41 -0700 | [diff] [blame] | 872 |         wp<Layer> mRequestedSyncLayer; | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 873 |     }; | 
 | 874 |  | 
| Dan Stoza | cac3538 | 2016-01-27 12:21:06 -0800 | [diff] [blame] | 875 |     // SyncPoints which will be signaled when the correct frame is at the head | 
 | 876 |     // of the queue and dropped after the frame has been latched. Protected by | 
 | 877 |     // mLocalSyncPointMutex. | 
 | 878 |     Mutex mLocalSyncPointMutex; | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 879 |     std::list<std::shared_ptr<SyncPoint>> mLocalSyncPoints; | 
 | 880 |  | 
| Dan Stoza | cac3538 | 2016-01-27 12:21:06 -0800 | [diff] [blame] | 881 |     // SyncPoints which will be signaled and then dropped when the transaction | 
 | 882 |     // is applied | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 883 |     std::list<std::shared_ptr<SyncPoint>> mRemoteSyncPoints; | 
 | 884 |  | 
| Dan Stoza | cac3538 | 2016-01-27 12:21:06 -0800 | [diff] [blame] | 885 |     // Returns false if the relevant frame has already been latched | 
 | 886 |     bool addSyncPoint(const std::shared_ptr<SyncPoint>& point); | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 887 |  | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 888 |     void popPendingState(State* stateToCommit); | 
 | 889 |     virtual bool applyPendingStates(State* stateToCommit); | 
 | 890 |     virtual uint32_t doTransactionResize(uint32_t flags, Layer::State* stateToCommit); | 
| Robert Carr | c3574f7 | 2016-03-24 12:19:32 -0700 | [diff] [blame] | 891 |  | 
 | 892 |     // Returns mCurrentScaling mode (originating from the | 
 | 893 |     // Client) or mOverrideScalingMode mode (originating from | 
 | 894 |     // the Surface Controller) if set. | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 895 |     virtual uint32_t getEffectiveScalingMode() const { return 0; } | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 896 |  | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 897 | public: | 
| Irvel | 468051e | 2016-06-13 16:44:44 -0700 | [diff] [blame] | 898 |     /* | 
 | 899 |      * The layer handle is just a BBinder object passed to the client | 
 | 900 |      * (remote process) -- we don't keep any reference on our side such that | 
 | 901 |      * the dtor is called when the remote side let go of its reference. | 
 | 902 |      * | 
 | 903 |      * LayerCleaner ensures that mFlinger->onLayerDestroyed() is called for | 
 | 904 |      * this layer when the handle is destroyed. | 
 | 905 |      */ | 
 | 906 |     class Handle : public BBinder, public LayerCleaner { | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 907 |     public: | 
 | 908 |         Handle(const sp<SurfaceFlinger>& flinger, const sp<Layer>& layer) | 
 | 909 |               : LayerCleaner(flinger, layer), owner(layer) {} | 
| Irvel | 468051e | 2016-06-13 16:44:44 -0700 | [diff] [blame] | 910 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 911 |         wp<Layer> owner; | 
| Irvel | 468051e | 2016-06-13 16:44:44 -0700 | [diff] [blame] | 912 |     }; | 
 | 913 |  | 
| Robert Carr | c0df312 | 2019-04-11 13:18:21 -0700 | [diff] [blame] | 914 |     // Creates a new handle each time, so we only expect | 
 | 915 |     // this to be called once. | 
| Irvel | 468051e | 2016-06-13 16:44:44 -0700 | [diff] [blame] | 916 |     sp<IBinder> getHandle(); | 
| Dominik Laskowski | 87a07e4 | 2019-10-10 20:38:02 -0700 | [diff] [blame] | 917 |     const std::string& getName() const { return mName; } | 
| Dominik Laskowski | a8955dd | 2019-07-10 10:19:09 -0700 | [diff] [blame] | 918 |     virtual void notifyAvailableFrames(nsecs_t /*expectedPresentTime*/) {} | 
| Robert Carr | 105e64b | 2018-03-07 12:47:50 -0800 | [diff] [blame] | 919 |     virtual PixelFormat getPixelFormat() const { return PIXEL_FORMAT_NONE; } | 
| chaviw | 13fdc49 | 2017-06-27 12:40:18 -0700 | [diff] [blame] | 920 |     bool getPremultipledAlpha() const; | 
| Igor Murashkin | a4a3149 | 2012-10-29 13:36:11 -0700 | [diff] [blame] | 921 |  | 
| Robert Carr | 2e102c9 | 2018-10-23 12:11:15 -0700 | [diff] [blame] | 922 |     bool mPendingHWCDestroy{false}; | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 923 |     void setInputInfo(const InputWindowInfo& info); | 
| Robert Carr | 720e506 | 2018-07-30 17:45:14 -0700 | [diff] [blame] | 924 |  | 
| Arthur Hung | d20b270 | 2019-01-14 18:16:16 +0800 | [diff] [blame] | 925 |     InputWindowInfo fillInputInfo(); | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 926 |     bool hasInput() const; | 
| Robert Carr | 2e102c9 | 2018-10-23 12:11:15 -0700 | [diff] [blame] | 927 |  | 
| David Sodman | 41fdfc9 | 2017-11-06 16:09:56 -0800 | [diff] [blame] | 928 | protected: | 
| Mathias Agopian | b7e930d | 2010-06-01 15:12:58 -0700 | [diff] [blame] | 929 |     // ----------------------------------------------------------------------- | 
| Robert Carr | 1c5481e | 2019-07-01 14:42:27 -0700 | [diff] [blame] | 930 |     bool usingRelativeZ(LayerVector::StateSet stateSet) const; | 
| Mathias Agopian | b7e930d | 2010-06-01 15:12:58 -0700 | [diff] [blame] | 931 |  | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 932 |     bool mPremultipliedAlpha{true}; | 
| Dominik Laskowski | 87a07e4 | 2019-10-10 20:38:02 -0700 | [diff] [blame] | 933 |     const std::string mName; | 
 | 934 |     const std::string mTransactionName{"TX - " + mName}; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 935 |  | 
| Chia-I Wu | ab0c319 | 2017-08-01 11:29:00 -0700 | [diff] [blame] | 936 |     bool mPrimaryDisplayOnly = false; | 
 | 937 |  | 
| Vishnu Nair | 8406fd7 | 2019-07-30 11:29:31 -0700 | [diff] [blame] | 938 |     // These are only accessed by the main thread or the tracing thread. | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 939 |     State mDrawingState; | 
| Vishnu Nair | 8406fd7 | 2019-07-30 11:29:31 -0700 | [diff] [blame] | 940 |     // Store a copy of the pending state so that the drawing thread can access the | 
 | 941 |     // states without a lock. | 
 | 942 |     Vector<State> mPendingStatesSnapshot; | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 943 |  | 
| Vishnu Nair | 8406fd7 | 2019-07-30 11:29:31 -0700 | [diff] [blame] | 944 |     // these are protected by an external lock (mStateLock) | 
 | 945 |     State mCurrentState; | 
 | 946 |     std::atomic<uint32_t> mTransactionFlags{0}; | 
| Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 947 |     Vector<State> mPendingStates; | 
| Dan Stoza | 7dde599 | 2015-05-22 09:51:44 -0700 | [diff] [blame] | 948 |  | 
| Brian Anderson | d6927fb | 2016-07-23 23:37:30 -0700 | [diff] [blame] | 949 |     // Timestamp history for UIAutomation. Thread safe. | 
| Jamie Gennis | 4b0eba9 | 2013-02-05 13:30:24 -0800 | [diff] [blame] | 950 |     FrameTracker mFrameTracker; | 
| Mathias Agopian | a67932f | 2011-04-20 14:20:59 -0700 | [diff] [blame] | 951 |  | 
| Brian Anderson | d6927fb | 2016-07-23 23:37:30 -0700 | [diff] [blame] | 952 |     // Timestamp history for the consumer to query. | 
 | 953 |     // Accessed by both consumer and producer on main and binder threads. | 
 | 954 |     Mutex mFrameEventHistoryMutex; | 
| Brian Anderson | 3890c39 | 2016-07-25 12:48:08 -0700 | [diff] [blame] | 955 |     ConsumerFrameEventHistory mFrameEventHistory; | 
| Brian Anderson | 3d4039d | 2016-09-23 16:31:30 -0700 | [diff] [blame] | 956 |     FenceTimeline mAcquireTimeline; | 
 | 957 |     FenceTimeline mReleaseTimeline; | 
| Brian Anderson | d6927fb | 2016-07-23 23:37:30 -0700 | [diff] [blame] | 958 |  | 
| Mathias Agopian | a67932f | 2011-04-20 14:20:59 -0700 | [diff] [blame] | 959 |     // main thread | 
| Lloyd Pique | 0b785d8 | 2018-12-04 17:25:27 -0800 | [diff] [blame] | 960 |     sp<NativeHandle> mSidebandStream; | 
| Alec Mouri | e7d1d4a | 2019-02-05 01:13:46 +0000 | [diff] [blame] | 961 |     // False if the buffer and its contents have been previously used for GPU | 
 | 962 |     // composition, true otherwise. | 
 | 963 |     bool mIsActiveBufferUpdatedForGpu = true; | 
 | 964 |  | 
| Robert Carr | c3574f7 | 2016-03-24 12:19:32 -0700 | [diff] [blame] | 965 |     // We encode unset as -1. | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 966 |     int32_t mOverrideScalingMode{-1}; | 
 | 967 |     std::atomic<uint64_t> mCurrentFrameNumber{0}; | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 968 |     // Whether filtering is needed b/c of the drawingstate | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 969 |     bool mNeedsFiltering{false}; | 
| David Sodman | 0c69cad | 2017-08-21 12:12:51 -0700 | [diff] [blame] | 970 |  | 
| Robert Carr | 2e102c9 | 2018-10-23 12:11:15 -0700 | [diff] [blame] | 971 |     std::atomic<bool> mRemovedFromCurrentState{false}; | 
| chaviw | 8b3871a | 2017-11-01 17:41:01 -0700 | [diff] [blame] | 972 |  | 
| Mathias Agopian | b7e930d | 2010-06-01 15:12:58 -0700 | [diff] [blame] | 973 |     // page-flip thread (currently main thread) | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 974 |     bool mProtectedByApp{false}; // application requires protected path to external sink | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 975 |  | 
 | 976 |     // protected by mLock | 
 | 977 |     mutable Mutex mLock; | 
| David Sodman | 0c69cad | 2017-08-21 12:12:51 -0700 | [diff] [blame] | 978 |  | 
| Mathias Agopian | 13127d8 | 2013-03-05 17:47:11 -0800 | [diff] [blame] | 979 |     const wp<Client> mClientRef; | 
| Riley Andrews | 03414a1 | 2014-07-01 14:22:59 -0700 | [diff] [blame] | 980 |  | 
 | 981 |     // This layer can be a cursor on some displays. | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 982 |     bool mPotentialCursor{false}; | 
| Dan Stoza | 6b9454d | 2014-11-07 16:00:59 -0800 | [diff] [blame] | 983 |  | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 984 |     // Child list about to be committed/used for editing. | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 985 |     LayerVector mCurrentChildren{LayerVector::StateSet::Current}; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 986 |     // Child list used for rendering. | 
| Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 987 |     LayerVector mDrawingChildren{LayerVector::StateSet::Drawing}; | 
| Robert Carr | 1f0a16a | 2016-10-24 16:27:39 -0700 | [diff] [blame] | 988 |  | 
| Chia-I Wu | e41dbe6 | 2017-06-13 14:10:56 -0700 | [diff] [blame] | 989 |     wp<Layer> mCurrentParent; | 
 | 990 |     wp<Layer> mDrawingParent; | 
| David Sodman | 9eeae69 | 2017-11-02 10:53:32 -0700 | [diff] [blame] | 991 |  | 
| chaviw | 5aedec9 | 2018-10-22 10:40:38 -0700 | [diff] [blame] | 992 |     // Can only be accessed with the SF state lock held. | 
 | 993 |     bool mLayerDetached{false}; | 
| Robert Carr | 1323c95 | 2019-01-28 18:13:27 -0800 | [diff] [blame] | 994 |     // Can only be accessed with the SF state lock held. | 
 | 995 |     bool mChildrenChanged{false}; | 
| chaviw | 5aedec9 | 2018-10-22 10:40:38 -0700 | [diff] [blame] | 996 |  | 
| Ady Abraham | 8f1ee7f | 2019-04-05 10:32:50 -0700 | [diff] [blame] | 997 |     // Window types from WindowManager.LayoutParams | 
 | 998 |     const int mWindowType; | 
 | 999 |  | 
| chaviw | 4b129c2 | 2018-04-09 16:19:43 -0700 | [diff] [blame] | 1000 | private: | 
 | 1001 |     /** | 
 | 1002 |      * Returns an unsorted vector of all layers that are part of this tree. | 
 | 1003 |      * That includes the current layer and all its descendants. | 
 | 1004 |      */ | 
 | 1005 |     std::vector<Layer*> getLayersInTree(LayerVector::StateSet stateSet); | 
 | 1006 |     /** | 
 | 1007 |      * Traverses layers that are part of this tree in the correct z order. | 
 | 1008 |      * layersInTree must be sorted before calling this method. | 
 | 1009 |      */ | 
 | 1010 |     void traverseChildrenInZOrderInner(const std::vector<Layer*>& layersInTree, | 
 | 1011 |                                        LayerVector::StateSet stateSet, | 
 | 1012 |                                        const LayerVector::Visitor& visitor); | 
 | 1013 |     LayerVector makeChildrenTraversalList(LayerVector::StateSet stateSet, | 
 | 1014 |                                           const std::vector<Layer*>& layersInTree); | 
| Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 1015 |  | 
 | 1016 |     // Cached properties computed from drawing state | 
 | 1017 |     // Effective transform taking into account parent transforms and any parent scaling. | 
 | 1018 |     ui::Transform mEffectiveTransform; | 
 | 1019 |  | 
 | 1020 |     // Bounds of the layer before any transformation is applied and before it has been cropped | 
 | 1021 |     // by its parents. | 
 | 1022 |     FloatRect mSourceBounds; | 
 | 1023 |  | 
 | 1024 |     // Bounds of the layer in layer space. This is the mSourceBounds cropped by its layer crop and | 
 | 1025 |     // its parent bounds. | 
 | 1026 |     FloatRect mBounds; | 
 | 1027 |  | 
 | 1028 |     // Layer bounds in screen space. | 
 | 1029 |     FloatRect mScreenBounds; | 
| chaviw | 606e5cf | 2019-03-01 10:12:10 -0800 | [diff] [blame] | 1030 |  | 
 | 1031 |     void setZOrderRelativeOf(const wp<Layer>& relativeOf); | 
| Robert Carr | c0df312 | 2019-04-11 13:18:21 -0700 | [diff] [blame] | 1032 |  | 
 | 1033 |     bool mGetHandleCalled = false; | 
| chaviw | 43cb3cb | 2019-05-31 15:23:41 -0700 | [diff] [blame] | 1034 |  | 
 | 1035 |     void removeRemoteSyncPoints(); | 
| Vishnu Nair | 0f085c6 | 2019-08-30 08:49:12 -0700 | [diff] [blame] | 1036 |  | 
 | 1037 |     // Tracks the process and user id of the caller when creating this layer | 
 | 1038 |     // to help debugging. | 
 | 1039 |     pid_t mCallingPid; | 
 | 1040 |     uid_t mCallingUid; | 
| chaviw | b4c6e58 | 2019-08-16 14:35:07 -0700 | [diff] [blame] | 1041 |  | 
 | 1042 |     // The current layer is a clone of mClonedFrom. This means that this layer will update it's | 
 | 1043 |     // properties based on mClonedFrom. When mClonedFrom latches a new buffer for BufferLayers, | 
 | 1044 |     // this layer will update it's buffer. When mClonedFrom updates it's drawing state, children, | 
 | 1045 |     // and relatives, this layer will update as well. | 
 | 1046 |     wp<Layer> mClonedFrom; | 
| Vishnu Nair | c97b8db | 2019-10-29 18:19:35 -0700 | [diff] [blame] | 1047 |  | 
 | 1048 |     // The inherited shadow radius after taking into account the layer hierarchy. This is the | 
 | 1049 |     // final shadow radius for this layer. If a shadow is specified for a layer, then effective | 
 | 1050 |     // 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] | 1051 |     float mEffectiveShadowRadius = 0.f; | 
| Vishnu Nair | c97b8db | 2019-10-29 18:19:35 -0700 | [diff] [blame] | 1052 |  | 
 | 1053 |     // Returns true if the layer can draw shadows on its border. | 
 | 1054 |     virtual bool canDrawShadows() const { return true; } | 
| chaviw | af87b3e | 2019-10-01 16:59:28 -0700 | [diff] [blame] | 1055 |  | 
 | 1056 |     // Find the root of the cloned hierarchy, this means the first non cloned parent. | 
 | 1057 |     // This will return null if first non cloned parent is not found. | 
 | 1058 |     sp<Layer> getClonedRoot(); | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 1059 | }; | 
 | 1060 |  | 
| Dominik Laskowski | 3415776 | 2018-10-31 13:07:19 -0700 | [diff] [blame] | 1061 | } // namespace android | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 1062 |  | 
| Lloyd Pique | 37c2c9b | 2018-12-04 17:25:10 -0800 | [diff] [blame] | 1063 | #define RETURN_IF_NO_HWC_LAYER(displayDevice, ...)                                     \ | 
| Dominik Laskowski | 3415776 | 2018-10-31 13:07:19 -0700 | [diff] [blame] | 1064 |     do {                                                                               \ | 
| Lloyd Pique | 37c2c9b | 2018-12-04 17:25:10 -0800 | [diff] [blame] | 1065 |         if (!hasHwcLayer(displayDevice)) {                                             \ | 
| Dominik Laskowski | 3415776 | 2018-10-31 13:07:19 -0700 | [diff] [blame] | 1066 |             ALOGE("[%s] %s failed: no HWC layer found for display %s", mName.string(), \ | 
| Lloyd Pique | 37c2c9b | 2018-12-04 17:25:10 -0800 | [diff] [blame] | 1067 |                   __FUNCTION__, displayDevice->getDebugName().c_str());                \ | 
| Dominik Laskowski | 3415776 | 2018-10-31 13:07:19 -0700 | [diff] [blame] | 1068 |             return __VA_ARGS__;                                                        \ | 
 | 1069 |         }                                                                              \ | 
 | 1070 |     } while (false) | 
| The Android Open Source Project | edbf3b6 | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 1071 |  | 
 | 1072 | #endif // ANDROID_LAYER_H |