blob: 15a9552a141915b9bfd25a4733bfddc793c7b837 [file] [log] [blame]
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2007 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ANDROID_LAYER_H
18#define ANDROID_LAYER_H
19
20#include <stdint.h>
21#include <sys/types.h>
22
Mathias Agopian076b1cc2009-04-10 14:24:30 -070023#include <EGL/egl.h>
24#include <EGL/eglext.h>
Mathias Agopian076b1cc2009-04-10 14:24:30 -070025
Mathias Agopian13127d82013-03-05 17:47:11 -080026#include <utils/RefBase.h>
27#include <utils/String8.h>
28#include <utils/Timers.h>
29
Dan Stoza71bded52016-10-19 11:10:33 -070030#include <gfx/FloatRect.h>
31
Svetoslavd85084b2014-03-20 10:28:31 -070032#include <ui/FrameStats.h>
Mathias Agopian13127d82013-03-05 17:47:11 -080033#include <ui/GraphicBuffer.h>
34#include <ui/PixelFormat.h>
35#include <ui/Region.h>
36
37#include <gui/ISurfaceComposerClient.h>
38
39#include <private/gui/LayerState.h>
40
Dan Stoza7dde5992015-05-22 09:51:44 -070041#include <list>
42
Jamie Gennis82dbc742012-11-08 19:23:28 -080043#include "FrameTracker.h"
Mathias Agopian13127d82013-03-05 17:47:11 -080044#include "Client.h"
Dan Stozab9b08832014-03-13 11:55:57 -070045#include "MonitoredProducer.h"
Mathias Agopian13127d82013-03-05 17:47:11 -080046#include "SurfaceFlinger.h"
47#include "SurfaceFlingerConsumer.h"
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080048#include "Transform.h"
49
Mathias Agopian13127d82013-03-05 17:47:11 -080050#include "DisplayHardware/HWComposer.h"
Mathias Agopian3f844832013-08-07 21:24:32 -070051#include "RenderEngine/Mesh.h"
Mathias Agopian49457ac2013-08-14 18:20:17 -070052#include "RenderEngine/Texture.h"
Mathias Agopian13127d82013-03-05 17:47:11 -080053
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080054namespace android {
55
56// ---------------------------------------------------------------------------
57
Mathias Agopian1f7bec62010-06-25 18:02:21 -070058class Client;
Mathias Agopian3e25fd82013-04-22 17:52:16 +020059class Colorizer;
Mathias Agopian13127d82013-03-05 17:47:11 -080060class DisplayDevice;
61class GraphicBuffer;
62class SurfaceFlinger;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080063
64// ---------------------------------------------------------------------------
65
Andy McFadden882e3a32013-01-08 16:06:15 -080066/*
Andy McFadden882e3a32013-01-08 16:06:15 -080067 * A new BufferQueue and a new SurfaceFlingerConsumer are created when the
68 * Layer is first referenced.
69 *
70 * This also implements onFrameAvailable(), which notifies SurfaceFlinger
71 * that new data has arrived.
72 */
Jesse Hall399184a2014-03-03 15:42:54 -080073class Layer : public SurfaceFlingerConsumer::ContentsChangedListener {
Mathias Agopian13127d82013-03-05 17:47:11 -080074 static int32_t sSequence;
75
Mathias Agopiand606de62010-05-10 20:06:11 -070076public:
Mathias Agopian13127d82013-03-05 17:47:11 -080077 mutable bool contentDirty;
78 // regions below are in window-manager space
79 Region visibleRegion;
80 Region coveredRegion;
81 Region visibleNonTransparentRegion;
Dan Stozaee44edd2015-03-23 15:50:23 -070082 Region surfaceDamageRegion;
Andy McFadden4df87bd2014-04-21 18:08:54 -070083
84 // Layer serial number. This gives layers an explicit ordering, so we
85 // have a stable sort order when their layer stack and Z-order are
86 // the same.
Mathias Agopian13127d82013-03-05 17:47:11 -080087 int32_t sequence;
88
89 enum { // flags for doTransaction()
90 eDontUpdateGeometryState = 0x00000001,
91 eVisibleRegion = 0x00000002,
92 };
93
94 struct Geometry {
95 uint32_t w;
96 uint32_t h;
Robert Carr3dcabfa2016-03-01 18:36:58 -080097 Transform transform;
98
Mathias Agopian13127d82013-03-05 17:47:11 -080099 inline bool operator ==(const Geometry& rhs) const {
Robert Carr99e27f02016-06-16 15:18:02 -0700100 return (w == rhs.w && h == rhs.h) &&
101 (transform.tx() == rhs.transform.tx()) &&
102 (transform.ty() == rhs.transform.ty());
Mathias Agopian13127d82013-03-05 17:47:11 -0800103 }
104 inline bool operator !=(const Geometry& rhs) const {
105 return !operator ==(rhs);
106 }
107 };
108
109 struct State {
110 Geometry active;
111 Geometry requested;
112 uint32_t z;
113 uint32_t layerStack;
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000114#ifdef USE_HWC2
Dan Stoza9e56aa02015-11-02 13:00:03 -0800115 float alpha;
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000116#else
117 uint8_t alpha;
118#endif
Mathias Agopian13127d82013-03-05 17:47:11 -0800119 uint8_t flags;
Dan Stoza7dde5992015-05-22 09:51:44 -0700120 uint8_t mask;
Mathias Agopian13127d82013-03-05 17:47:11 -0800121 uint8_t reserved[2];
122 int32_t sequence; // changes when visible regions can change
Dan Stoza7dde5992015-05-22 09:51:44 -0700123 bool modified;
124
Robert Carrb5d3d262016-03-25 15:08:13 -0700125 Rect crop;
Robert Carr99e27f02016-06-16 15:18:02 -0700126 Rect requestedCrop;
127
Robert Carrb5d3d262016-03-25 15:08:13 -0700128 Rect finalCrop;
129
Dan Stoza7dde5992015-05-22 09:51:44 -0700130 // If set, defers this state update until the Layer identified by handle
131 // receives a frame with the given frameNumber
Dan Stoza22851c32016-08-09 13:21:03 -0700132 wp<IBinder> handle;
Dan Stoza7dde5992015-05-22 09:51:44 -0700133 uint64_t frameNumber;
134
Mathias Agopian2ca79392013-04-02 18:30:32 -0700135 // the transparentRegion hint is a bit special, it's latched only
136 // when we receive a buffer -- this is because it's "content"
137 // dependent.
138 Region activeTransparentRegion;
139 Region requestedTransparentRegion;
Mathias Agopian13127d82013-03-05 17:47:11 -0800140 };
141
Mathias Agopian13127d82013-03-05 17:47:11 -0800142 // -----------------------------------------------------------------------
143
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700144 Layer(SurfaceFlinger* flinger, const sp<Client>& client,
145 const String8& name, uint32_t w, uint32_t h, uint32_t flags);
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700146
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700147 virtual ~Layer();
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800148
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700149 // the this layer's size and format
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700150 status_t setBuffers(uint32_t w, uint32_t h, PixelFormat format, uint32_t flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800151
Mathias Agopian13127d82013-03-05 17:47:11 -0800152 // modify current state
Robert Carr82364e32016-05-15 11:27:47 -0700153 bool setPosition(float x, float y, bool immediate);
Mathias Agopian13127d82013-03-05 17:47:11 -0800154 bool setLayer(uint32_t z);
155 bool setSize(uint32_t w, uint32_t h);
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000156#ifdef USE_HWC2
Dan Stoza9e56aa02015-11-02 13:00:03 -0800157 bool setAlpha(float alpha);
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000158#else
159 bool setAlpha(uint8_t alpha);
160#endif
Mathias Agopian13127d82013-03-05 17:47:11 -0800161 bool setMatrix(const layer_state_t::matrix22_t& matrix);
162 bool setTransparentRegionHint(const Region& transparent);
163 bool setFlags(uint8_t flags, uint8_t mask);
Robert Carr99e27f02016-06-16 15:18:02 -0700164 bool setCrop(const Rect& crop, bool immediate);
Pablo Ceballosacbe6782016-03-04 17:54:21 +0000165 bool setFinalCrop(const Rect& crop);
Mathias Agopian13127d82013-03-05 17:47:11 -0800166 bool setLayerStack(uint32_t layerStack);
Dan Stoza7dde5992015-05-22 09:51:44 -0700167 void deferTransactionUntil(const sp<IBinder>& handle, uint64_t frameNumber);
Robert Carrc3574f72016-03-24 12:19:32 -0700168 bool setOverrideScalingMode(int32_t overrideScalingMode);
Mathias Agopian13127d82013-03-05 17:47:11 -0800169
Dan Stozaee44edd2015-03-23 15:50:23 -0700170 // If we have received a new buffer this frame, we will pass its surface
171 // damage down to hardware composer. Otherwise, we must send a region with
172 // one empty rect.
173 void useSurfaceDamage();
174 void useEmptyDamage();
175
Mathias Agopian13127d82013-03-05 17:47:11 -0800176 uint32_t getTransactionFlags(uint32_t flags);
177 uint32_t setTransactionFlags(uint32_t flags);
178
Dan Stozac7014012014-02-14 15:03:43 -0800179 void computeGeometry(const sp<const DisplayDevice>& hw, Mesh& mesh,
180 bool useIdentityTransform) const;
Michael Lentine6c925ed2014-09-26 17:55:01 -0700181 Rect computeBounds(const Region& activeTransparentRegion) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800182 Rect computeBounds() const;
183
Pablo Ceballos40845df2016-01-25 17:41:15 -0800184 int32_t getSequence() const { return sequence; }
185
Mathias Agopian13127d82013-03-05 17:47:11 -0800186 // -----------------------------------------------------------------------
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700187 // Virtuals
Mathias Agopian13127d82013-03-05 17:47:11 -0800188
Mathias Agopian13127d82013-03-05 17:47:11 -0800189 virtual const char* getTypeId() const { return "Layer"; }
190
Mathias Agopian13127d82013-03-05 17:47:11 -0800191 /*
192 * isOpaque - true if this surface is opaque
Andy McFadden4125a4f2014-01-29 17:17:11 -0800193 *
194 * This takes into account the buffer format (i.e. whether or not the
195 * pixel format includes an alpha channel) and the "opaque" flag set
196 * on the layer. It does not examine the current plane alpha value.
Mathias Agopian13127d82013-03-05 17:47:11 -0800197 */
Andy McFadden4125a4f2014-01-29 17:17:11 -0800198 virtual bool isOpaque(const Layer::State& s) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800199
200 /*
201 * isSecure - true if this surface is secure, that is if it prevents
202 * screenshots or VNC servers.
203 */
Dan Stoza23116082015-06-18 14:58:39 -0700204 virtual bool isSecure() const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800205
206 /*
207 * isProtected - true if the layer may contain protected content in the
208 * GRALLOC_USAGE_PROTECTED sense.
209 */
Jamie Gennis7a4d0df2011-03-09 17:05:02 -0800210 virtual bool isProtected() const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800211
212 /*
213 * isVisible - true if this layer is visible, false otherwise
214 */
Mathias Agopianda27af92012-09-13 18:17:13 -0700215 virtual bool isVisible() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800216
Mathias Agopian13127d82013-03-05 17:47:11 -0800217 /*
218 * isFixedSize - true if content has a fixed size
219 */
220 virtual bool isFixedSize() const;
Jamie Gennis582270d2011-08-17 18:19:00 -0700221
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700222protected:
223 /*
224 * onDraw - draws the surface.
225 */
Dan Stozac7014012014-02-14 15:03:43 -0800226 virtual void onDraw(const sp<const DisplayDevice>& hw, const Region& clip,
227 bool useIdentityTransform) const;
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700228
229public:
230 // -----------------------------------------------------------------------
231
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000232#ifdef USE_HWC2
Dan Stoza9e56aa02015-11-02 13:00:03 -0800233 void setGeometry(const sp<const DisplayDevice>& displayDevice);
234 void forceClientComposition(int32_t hwcId);
235 void setPerFrameData(const sp<const DisplayDevice>& displayDevice);
236
237 // callIntoHwc exists so we can update our local state and call
238 // acceptDisplayChanges without unnecessarily updating the device's state
239 void setCompositionType(int32_t hwcId, HWC2::Composition type,
240 bool callIntoHwc = true);
241 HWC2::Composition getCompositionType(int32_t hwcId) const;
242
243 void setClearClientTarget(int32_t hwcId, bool clear);
244 bool getClearClientTarget(int32_t hwcId) const;
245
246 void updateCursorPosition(const sp<const DisplayDevice>& hw);
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000247#else
248 void setGeometry(const sp<const DisplayDevice>& hw,
249 HWComposer::HWCLayerInterface& layer);
250 void setPerFrameData(const sp<const DisplayDevice>& hw,
251 HWComposer::HWCLayerInterface& layer);
252 void setAcquireFence(const sp<const DisplayDevice>& hw,
253 HWComposer::HWCLayerInterface& layer);
254
255 Rect getPosition(const sp<const DisplayDevice>& hw);
256#endif
Riley Andrews03414a12014-07-01 14:22:59 -0700257
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700258 /*
259 * called after page-flip
260 */
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000261#ifdef USE_HWC2
Dan Stoza9e56aa02015-11-02 13:00:03 -0800262 void onLayerDisplayed(const sp<Fence>& releaseFence);
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000263#else
264 void onLayerDisplayed(const sp<const DisplayDevice>& hw,
265 HWComposer::HWCLayerInterface* layer);
266#endif
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700267
Dan Stoza6b9454d2014-11-07 16:00:59 -0800268 bool shouldPresentNow(const DispSync& dispSync) const;
269
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700270 /*
271 * called before composition.
272 * returns true if the layer has pending updates.
273 */
Brian Andersond6927fb2016-07-23 23:37:30 -0700274 bool onPreComposition(nsecs_t refreshStartTime);
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700275
276 /*
Dan Stozae77c7662016-05-13 11:37:28 -0700277 * called after composition.
278 * returns true if the layer latched a new buffer this frame.
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700279 */
Brian Anderson3d4039d2016-09-23 16:31:30 -0700280 bool onPostComposition(
281 const std::shared_ptr<FenceTime>& glDoneFence,
282 const std::shared_ptr<FenceTime>& presentFence,
283 const std::shared_ptr<FenceTime>& retireFence);
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700284
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000285#ifdef USE_HWC2
Dan Stoza9e56aa02015-11-02 13:00:03 -0800286 // If a buffer was replaced this frame, release the former buffer
287 void releasePendingBuffer();
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000288#endif
Dan Stoza9e56aa02015-11-02 13:00:03 -0800289
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700290 /*
291 * draw - performs some global clipping optimizations
292 * and calls onDraw().
293 */
294 void draw(const sp<const DisplayDevice>& hw, const Region& clip) const;
Dan Stozac7014012014-02-14 15:03:43 -0800295 void draw(const sp<const DisplayDevice>& hw, bool useIdentityTransform) const;
296 void draw(const sp<const DisplayDevice>& hw) const;
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700297
298 /*
299 * doTransaction - process the transaction. This is a good place to figure
300 * out which attributes of the surface have changed.
301 */
302 uint32_t doTransaction(uint32_t transactionFlags);
303
304 /*
305 * setVisibleRegion - called to set the new visible region. This gives
306 * a chance to update the new visible region or record the fact it changed.
307 */
308 void setVisibleRegion(const Region& visibleRegion);
309
310 /*
311 * setCoveredRegion - called when the covered region changes. The covered
312 * region corresponds to any area of the surface that is covered
313 * (transparently or not) by another surface.
314 */
315 void setCoveredRegion(const Region& coveredRegion);
316
317 /*
318 * setVisibleNonTransparentRegion - called when the visible and
319 * non-transparent region changes.
320 */
321 void setVisibleNonTransparentRegion(const Region&
322 visibleNonTransparentRegion);
323
324 /*
325 * latchBuffer - called each time the screen is redrawn and returns whether
326 * the visible regions need to be recomputed (this is a fairly heavy
327 * operation, so this should be set only if needed). Typically this is used
328 * to figure out if the content or size of a surface has changed.
329 */
Brian Andersond6927fb2016-07-23 23:37:30 -0700330 Region latchBuffer(bool& recomputeVisibleRegions, nsecs_t latchTime);
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700331
Riley Andrews03414a12014-07-01 14:22:59 -0700332 bool isPotentialCursor() const { return mPotentialCursor;}
333
Mathias Agopian13127d82013-03-05 17:47:11 -0800334 /*
335 * called with the state lock when the surface is removed from the
336 * current list
337 */
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700338 void onRemoved();
Mathias Agopian13127d82013-03-05 17:47:11 -0800339
340
Andy McFaddenbf974ab2012-12-04 16:51:15 -0800341 // Updates the transform hint in our SurfaceFlingerConsumer to match
Mathias Agopian84300952012-11-21 16:02:13 -0800342 // the current orientation of the display device.
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700343 void updateTransformHint(const sp<const DisplayDevice>& hw) const;
Andy McFadden69052052012-09-14 16:10:11 -0700344
Mathias Agopian13127d82013-03-05 17:47:11 -0800345 /*
346 * returns the rectangle that crops the content of the layer and scales it
347 * to the layer's size.
348 */
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700349 Rect getContentCrop() const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800350
Eric Penner51c59cd2014-07-28 19:51:58 -0700351 /*
352 * Returns if a frame is queued.
353 */
Pablo Ceballos06312182015-10-07 16:32:12 -0700354 bool hasQueuedFrame() const { return mQueuedFrames > 0 ||
Pablo Ceballosff95aab2016-01-13 17:09:58 -0800355 mSidebandStreamChanged || mAutoRefresh; }
Eric Penner51c59cd2014-07-28 19:51:58 -0700356
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000357#ifdef USE_HWC2
Dan Stoza9e56aa02015-11-02 13:00:03 -0800358 // -----------------------------------------------------------------------
359
360 bool hasHwcLayer(int32_t hwcId) {
361 if (mHwcLayers.count(hwcId) == 0) {
362 return false;
363 }
364 if (mHwcLayers[hwcId].layer->isAbandoned()) {
365 ALOGI("Erasing abandoned layer %s on %d", mName.string(), hwcId);
366 mHwcLayers.erase(hwcId);
367 return false;
368 }
369 return true;
370 }
371
372 std::shared_ptr<HWC2::Layer> getHwcLayer(int32_t hwcId) {
373 if (mHwcLayers.count(hwcId) == 0) {
374 return nullptr;
375 }
376 return mHwcLayers[hwcId].layer;
377 }
378
379 void setHwcLayer(int32_t hwcId, std::shared_ptr<HWC2::Layer>&& layer) {
380 if (layer) {
381 mHwcLayers[hwcId].layer = layer;
382 } else {
383 mHwcLayers.erase(hwcId);
384 }
385 }
386
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000387#endif
Mathias Agopian13127d82013-03-05 17:47:11 -0800388 // -----------------------------------------------------------------------
389
Fabien Sanglard17487192016-12-07 13:03:32 -0800390 void clearWithOpenGL(const sp<const DisplayDevice>& hw) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800391 void setFiltering(bool filtering);
392 bool getFiltering() const;
393
394 // only for debugging
395 inline const sp<GraphicBuffer>& getActiveBuffer() const { return mActiveBuffer; }
396
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700397 inline const State& getDrawingState() const { return mDrawingState; }
398 inline const State& getCurrentState() const { return mCurrentState; }
399 inline State& getCurrentState() { return mCurrentState; }
Mathias Agopian13127d82013-03-05 17:47:11 -0800400
401
402 /* always call base class first */
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700403 void dump(String8& result, Colorizer& colorizer) const;
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000404#ifdef USE_HWC2
Dan Stozae22aec72016-08-01 13:20:59 -0700405 static void miniDumpHeader(String8& result);
406 void miniDump(String8& result, int32_t hwcId) const;
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000407#endif
Svetoslavd85084b2014-03-20 10:28:31 -0700408 void dumpFrameStats(String8& result) const;
Brian Andersond6927fb2016-07-23 23:37:30 -0700409 void dumpFrameEvents(String8& result);
Svetoslavd85084b2014-03-20 10:28:31 -0700410 void clearFrameStats();
Jamie Gennis6547ff42013-07-16 20:12:42 -0700411 void logFrameStats();
Svetoslavd85084b2014-03-20 10:28:31 -0700412 void getFrameStats(FrameStats* outStats) const;
Mathias Agopian1b5e1022010-04-20 17:55:49 -0700413
Dan Stozae77c7662016-05-13 11:37:28 -0700414 std::vector<OccupancyTracker::Segment> getOccupancyHistory(bool forceFlush);
415
Brian Anderson3890c392016-07-25 12:48:08 -0700416 void addAndGetFrameTimestamps(const NewFrameEventsEntry* newEntry,
417 FrameEventHistoryDelta* outDelta);
Pablo Ceballosce796e72016-02-04 19:10:51 -0800418
Robert Carr367c5682016-06-20 11:55:28 -0700419 bool getTransformToDisplayInverse() const;
420
Mathias Agopian13127d82013-03-05 17:47:11 -0800421protected:
422 // constant
423 sp<SurfaceFlinger> mFlinger;
Mathias Agopian13127d82013-03-05 17:47:11 -0800424 /*
425 * Trivial class, used to ensure that mFlinger->onLayerDestroyed(mLayer)
426 * is called.
427 */
428 class LayerCleaner {
429 sp<SurfaceFlinger> mFlinger;
430 wp<Layer> mLayer;
431 protected:
Irvel468051e2016-06-13 16:44:44 -0700432 ~LayerCleaner() {
433 // destroy client resources
434 mFlinger->onLayerDestroyed(mLayer);
435 }
Mathias Agopian13127d82013-03-05 17:47:11 -0800436 public:
Irvel468051e2016-06-13 16:44:44 -0700437 LayerCleaner(const sp<SurfaceFlinger>& flinger,
438 const sp<Layer>& layer)
439 : mFlinger(flinger), mLayer(layer) {
440 }
Mathias Agopian13127d82013-03-05 17:47:11 -0800441 };
442
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800443
Irvel468051e2016-06-13 16:44:44 -0700444 virtual void onFirstRef();
445
446
447
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800448private:
Irvel468051e2016-06-13 16:44:44 -0700449 friend class SurfaceInterceptor;
Jesse Hall399184a2014-03-03 15:42:54 -0800450 // Interface implementation for SurfaceFlingerConsumer::ContentsChangedListener
Dan Stozadc13c5b2015-05-11 15:33:01 -0700451 virtual void onFrameAvailable(const BufferItem& item) override;
452 virtual void onFrameReplaced(const BufferItem& item) override;
453 virtual void onSidebandStreamChanged() override;
Mathias Agopian13127d82013-03-05 17:47:11 -0800454
Pablo Ceballos05289c22016-04-14 15:49:55 -0700455 void commitTransaction(const State& stateToCommit);
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700456
457 // needsLinearFiltering - true if this surface's state requires filtering
458 bool needsFiltering(const sp<const DisplayDevice>& hw) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800459
Mathias Agopian3330b202009-10-05 17:07:12 -0700460 uint32_t getEffectiveUsage(uint32_t usage) const;
Dan Stoza71bded52016-10-19 11:10:33 -0700461 gfx::FloatRect computeCrop(const sp<const DisplayDevice>& hw) const;
Mathias Agopiana67932f2011-04-20 14:20:59 -0700462 bool isCropped() const;
463 static bool getOpacityForFormat(uint32_t format);
Mathias Agopian0aa758d2009-04-22 15:23:34 -0700464
Mathias Agopian13127d82013-03-05 17:47:11 -0800465 // drawing
Fabien Sanglard17487192016-12-07 13:03:32 -0800466 void clearWithOpenGL(const sp<const DisplayDevice>& hw,
Mathias Agopian3f844832013-08-07 21:24:32 -0700467 float r, float g, float b, float alpha) const;
Fabien Sanglard85789802016-12-07 13:08:24 -0800468 void drawWithOpenGL(const sp<const DisplayDevice>& hw,
Dan Stozac7014012014-02-14 15:03:43 -0800469 bool useIdentityTransform) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800470
Ruben Brunk1681d952014-06-27 15:51:55 -0700471 // Temporary - Used only for LEGACY camera mode.
472 uint32_t getProducerStickyTransform() const;
473
Dan Stozac5da2712016-07-20 15:38:12 -0700474 // Loads the corresponding system property once per process
475 static bool latchUnsignaledBuffers();
476
Dan Stoza7dde5992015-05-22 09:51:44 -0700477 // -----------------------------------------------------------------------
478
479 class SyncPoint
480 {
481 public:
Chih-Hung Hsieh342b7602016-09-01 11:34:16 -0700482 explicit SyncPoint(uint64_t frameNumber) : mFrameNumber(frameNumber),
Dan Stoza7dde5992015-05-22 09:51:44 -0700483 mFrameIsAvailable(false), mTransactionIsApplied(false) {}
484
485 uint64_t getFrameNumber() const {
486 return mFrameNumber;
487 }
488
489 bool frameIsAvailable() const {
490 return mFrameIsAvailable;
491 }
492
493 void setFrameAvailable() {
494 mFrameIsAvailable = true;
495 }
496
497 bool transactionIsApplied() const {
498 return mTransactionIsApplied;
499 }
500
501 void setTransactionApplied() {
502 mTransactionIsApplied = true;
503 }
504
505 private:
506 const uint64_t mFrameNumber;
507 std::atomic<bool> mFrameIsAvailable;
508 std::atomic<bool> mTransactionIsApplied;
509 };
510
Dan Stozacac35382016-01-27 12:21:06 -0800511 // SyncPoints which will be signaled when the correct frame is at the head
512 // of the queue and dropped after the frame has been latched. Protected by
513 // mLocalSyncPointMutex.
514 Mutex mLocalSyncPointMutex;
Dan Stoza7dde5992015-05-22 09:51:44 -0700515 std::list<std::shared_ptr<SyncPoint>> mLocalSyncPoints;
516
Dan Stozacac35382016-01-27 12:21:06 -0800517 // SyncPoints which will be signaled and then dropped when the transaction
518 // is applied
Dan Stoza7dde5992015-05-22 09:51:44 -0700519 std::list<std::shared_ptr<SyncPoint>> mRemoteSyncPoints;
520
Dan Stozacac35382016-01-27 12:21:06 -0800521 uint64_t getHeadFrameNumber() const;
Dan Stoza1ce65812016-06-15 16:26:27 -0700522 bool headFenceHasSignaled() const;
Dan Stozacac35382016-01-27 12:21:06 -0800523
524 // Returns false if the relevant frame has already been latched
525 bool addSyncPoint(const std::shared_ptr<SyncPoint>& point);
Dan Stoza7dde5992015-05-22 09:51:44 -0700526
527 void pushPendingState();
Pablo Ceballos05289c22016-04-14 15:49:55 -0700528 void popPendingState(State* stateToCommit);
529 bool applyPendingStates(State* stateToCommit);
Robert Carrc3574f72016-03-24 12:19:32 -0700530
531 // Returns mCurrentScaling mode (originating from the
532 // Client) or mOverrideScalingMode mode (originating from
533 // the Surface Controller) if set.
534 uint32_t getEffectiveScalingMode() const;
Dan Stoza7dde5992015-05-22 09:51:44 -0700535public:
Irvel468051e2016-06-13 16:44:44 -0700536 /*
537 * The layer handle is just a BBinder object passed to the client
538 * (remote process) -- we don't keep any reference on our side such that
539 * the dtor is called when the remote side let go of its reference.
540 *
541 * LayerCleaner ensures that mFlinger->onLayerDestroyed() is called for
542 * this layer when the handle is destroyed.
543 */
544 class Handle : public BBinder, public LayerCleaner {
545 public:
546 Handle(const sp<SurfaceFlinger>& flinger, const sp<Layer>& layer)
547 : LayerCleaner(flinger, layer), owner(layer) {}
548
549 wp<Layer> owner;
550 };
551
552 sp<IBinder> getHandle();
553 sp<IGraphicBufferProducer> getProducer() const;
554 const String8& getName() const;
Dan Stoza7dde5992015-05-22 09:51:44 -0700555 void notifyAvailableFrames();
556private:
Igor Murashkina4a31492012-10-29 13:36:11 -0700557
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700558 // -----------------------------------------------------------------------
559
Fabien Sanglardcd6fd542016-10-13 12:47:39 -0700560 // Check all of the local sync points to ensure that all transactions
561 // which need to have been applied prior to the frame which is about to
562 // be latched have signaled
563 bool allTransactionsSignaled();
564
Mathias Agopiana67932f2011-04-20 14:20:59 -0700565 // constants
Andy McFaddenbf974ab2012-12-04 16:51:15 -0800566 sp<SurfaceFlingerConsumer> mSurfaceFlingerConsumer;
Dan Stozab9b08832014-03-13 11:55:57 -0700567 sp<IGraphicBufferProducer> mProducer;
Andy McFadden4df87bd2014-04-21 18:08:54 -0700568 uint32_t mTextureName; // from GLES
Mathias Agopian13127d82013-03-05 17:47:11 -0800569 bool mPremultipliedAlpha;
570 String8 mName;
Mathias Agopian13127d82013-03-05 17:47:11 -0800571 PixelFormat mFormat;
Mathias Agopian13127d82013-03-05 17:47:11 -0800572
573 // these are protected by an external lock
574 State mCurrentState;
575 State mDrawingState;
576 volatile int32_t mTransactionFlags;
Mathias Agopiand606de62010-05-10 20:06:11 -0700577
Dan Stoza7dde5992015-05-22 09:51:44 -0700578 // Accessed from main thread and binder threads
579 Mutex mPendingStateMutex;
580 Vector<State> mPendingStates;
581
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700582 // thread-safe
Mathias Agopiana67932f2011-04-20 14:20:59 -0700583 volatile int32_t mQueuedFrames;
Jesse Hall399184a2014-03-03 15:42:54 -0800584 volatile int32_t mSidebandStreamChanged; // used like an atomic boolean
Brian Andersond6927fb2016-07-23 23:37:30 -0700585
586 // Timestamp history for UIAutomation. Thread safe.
Jamie Gennis4b0eba92013-02-05 13:30:24 -0800587 FrameTracker mFrameTracker;
Mathias Agopiana67932f2011-04-20 14:20:59 -0700588
Brian Andersond6927fb2016-07-23 23:37:30 -0700589 // Timestamp history for the consumer to query.
590 // Accessed by both consumer and producer on main and binder threads.
591 Mutex mFrameEventHistoryMutex;
Brian Anderson3890c392016-07-25 12:48:08 -0700592 ConsumerFrameEventHistory mFrameEventHistory;
Brian Anderson3d4039d2016-09-23 16:31:30 -0700593 FenceTimeline mAcquireTimeline;
594 FenceTimeline mReleaseTimeline;
Brian Andersond6927fb2016-07-23 23:37:30 -0700595
Mathias Agopiana67932f2011-04-20 14:20:59 -0700596 // main thread
597 sp<GraphicBuffer> mActiveBuffer;
Jesse Hall399184a2014-03-03 15:42:54 -0800598 sp<NativeHandle> mSidebandStream;
Mathias Agopiana67932f2011-04-20 14:20:59 -0700599 Rect mCurrentCrop;
600 uint32_t mCurrentTransform;
Mathias Agopian933389f2011-07-18 16:15:08 -0700601 uint32_t mCurrentScalingMode;
Robert Carrc3574f72016-03-24 12:19:32 -0700602 // We encode unset as -1.
603 int32_t mOverrideScalingMode;
Mathias Agopiana67932f2011-04-20 14:20:59 -0700604 bool mCurrentOpacity;
Brian Andersond6927fb2016-07-23 23:37:30 -0700605 bool mBufferLatched = false; // TODO: Use mActiveBuffer?
Dan Stozacac35382016-01-27 12:21:06 -0800606 std::atomic<uint64_t> mCurrentFrameNumber;
Brian Andersond6927fb2016-07-23 23:37:30 -0700607 uint64_t mPreviousFrameNumber; // Only accessed on the main thread.
Mathias Agopian4d143ee2012-02-23 20:05:39 -0800608 bool mRefreshPending;
Jamie Gennise8696a42012-01-15 18:54:57 -0800609 bool mFrameLatencyNeeded;
Mathias Agopian13127d82013-03-05 17:47:11 -0800610 // Whether filtering is forced on or not
611 bool mFiltering;
612 // Whether filtering is needed b/c of the drawingstate
613 bool mNeedsFiltering;
Mathias Agopian5cdc8992013-08-13 20:51:23 -0700614 // The mesh used to draw the layer in GLES composition mode
615 mutable Mesh mMesh;
Andy McFadden4df87bd2014-04-21 18:08:54 -0700616 // The texture used to draw the layer in GLES composition mode
Mathias Agopian49457ac2013-08-14 18:20:17 -0700617 mutable Texture mTexture;
Mathias Agopiand606de62010-05-10 20:06:11 -0700618
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000619#ifdef USE_HWC2
Dan Stoza9e56aa02015-11-02 13:00:03 -0800620 // HWC items, accessed from the main thread
621 struct HWCInfo {
622 HWCInfo()
623 : layer(),
624 forceClientComposition(false),
625 compositionType(HWC2::Composition::Invalid),
626 clearClientTarget(false) {}
627
628 std::shared_ptr<HWC2::Layer> layer;
629 bool forceClientComposition;
630 HWC2::Composition compositionType;
631 bool clearClientTarget;
Dan Stozae22aec72016-08-01 13:20:59 -0700632 Rect displayFrame;
Dan Stoza71bded52016-10-19 11:10:33 -0700633 gfx::FloatRect sourceCrop;
Dan Stoza9e56aa02015-11-02 13:00:03 -0800634 };
635 std::unordered_map<int32_t, HWCInfo> mHwcLayers;
Fabien Sanglard9d96de42016-10-11 00:15:18 +0000636#else
637 bool mIsGlesComposition;
638#endif
Dan Stoza9e56aa02015-11-02 13:00:03 -0800639
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700640 // page-flip thread (currently main thread)
Glenn Kasten16f04532011-01-19 15:27:27 -0800641 bool mProtectedByApp; // application requires protected path to external sink
Mathias Agopian13127d82013-03-05 17:47:11 -0800642
643 // protected by mLock
644 mutable Mutex mLock;
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700645 // Set to true once we've returned this surface's handle
Mathias Agopian13127d82013-03-05 17:47:11 -0800646 mutable bool mHasSurface;
647 const wp<Client> mClientRef;
Riley Andrews03414a12014-07-01 14:22:59 -0700648
649 // This layer can be a cursor on some displays.
650 bool mPotentialCursor;
Dan Stoza6b9454d2014-11-07 16:00:59 -0800651
652 // Local copy of the queued contents of the incoming BufferQueue
653 mutable Mutex mQueueItemLock;
Dan Stozaa4650a52015-05-12 12:56:16 -0700654 Condition mQueueItemCondition;
Dan Stoza6b9454d2014-11-07 16:00:59 -0800655 Vector<BufferItem> mQueueItems;
Dan Stozacac35382016-01-27 12:21:06 -0800656 std::atomic<uint64_t> mLastFrameNumberReceived;
Brian Andersond6927fb2016-07-23 23:37:30 -0700657 bool mUpdateTexImageFailed; // This is only accessed on the main thread.
Pablo Ceballos06312182015-10-07 16:32:12 -0700658
Pablo Ceballosff95aab2016-01-13 17:09:58 -0800659 bool mAutoRefresh;
Robert Carr82364e32016-05-15 11:27:47 -0700660 bool mFreezePositionUpdates;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800661};
662
663// ---------------------------------------------------------------------------
664
665}; // namespace android
666
667#endif // ANDROID_LAYER_H