blob: 1d73b43bb2447222448f12eecf470e0985d95097 [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
Svetoslavd85084b2014-03-20 10:28:31 -070030#include <ui/FrameStats.h>
Mathias Agopian13127d82013-03-05 17:47:11 -080031#include <ui/GraphicBuffer.h>
32#include <ui/PixelFormat.h>
33#include <ui/Region.h>
34
35#include <gui/ISurfaceComposerClient.h>
36
37#include <private/gui/LayerState.h>
38
Dan Stoza7dde5992015-05-22 09:51:44 -070039#include <list>
40
Jamie Gennis82dbc742012-11-08 19:23:28 -080041#include "FrameTracker.h"
Mathias Agopian13127d82013-03-05 17:47:11 -080042#include "Client.h"
Dan Stozab9b08832014-03-13 11:55:57 -070043#include "MonitoredProducer.h"
Mathias Agopian13127d82013-03-05 17:47:11 -080044#include "SurfaceFlinger.h"
45#include "SurfaceFlingerConsumer.h"
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080046#include "Transform.h"
47
Mathias Agopian13127d82013-03-05 17:47:11 -080048#include "DisplayHardware/HWComposer.h"
Mathias Agopian6b442672013-07-09 21:24:52 -070049#include "DisplayHardware/FloatRect.h"
Mathias Agopian3f844832013-08-07 21:24:32 -070050#include "RenderEngine/Mesh.h"
Mathias Agopian49457ac2013-08-14 18:20:17 -070051#include "RenderEngine/Texture.h"
Mathias Agopian13127d82013-03-05 17:47:11 -080052
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080053namespace android {
54
55// ---------------------------------------------------------------------------
56
Mathias Agopian1f7bec62010-06-25 18:02:21 -070057class Client;
Mathias Agopian3e25fd82013-04-22 17:52:16 +020058class Colorizer;
Mathias Agopian13127d82013-03-05 17:47:11 -080059class DisplayDevice;
60class GraphicBuffer;
61class SurfaceFlinger;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080062
63// ---------------------------------------------------------------------------
64
Andy McFadden882e3a32013-01-08 16:06:15 -080065/*
Andy McFadden882e3a32013-01-08 16:06:15 -080066 * A new BufferQueue and a new SurfaceFlingerConsumer are created when the
67 * Layer is first referenced.
68 *
69 * This also implements onFrameAvailable(), which notifies SurfaceFlinger
70 * that new data has arrived.
71 */
Jesse Hall399184a2014-03-03 15:42:54 -080072class Layer : public SurfaceFlingerConsumer::ContentsChangedListener {
Mathias Agopian13127d82013-03-05 17:47:11 -080073 static int32_t sSequence;
74
Mathias Agopiand606de62010-05-10 20:06:11 -070075public:
Mathias Agopian13127d82013-03-05 17:47:11 -080076 mutable bool contentDirty;
77 // regions below are in window-manager space
78 Region visibleRegion;
79 Region coveredRegion;
80 Region visibleNonTransparentRegion;
Dan Stozaee44edd2015-03-23 15:50:23 -070081 Region surfaceDamageRegion;
Andy McFadden4df87bd2014-04-21 18:08:54 -070082
83 // Layer serial number. This gives layers an explicit ordering, so we
84 // have a stable sort order when their layer stack and Z-order are
85 // the same.
Mathias Agopian13127d82013-03-05 17:47:11 -080086 int32_t sequence;
87
88 enum { // flags for doTransaction()
89 eDontUpdateGeometryState = 0x00000001,
90 eVisibleRegion = 0x00000002,
91 };
92
93 struct Geometry {
94 uint32_t w;
95 uint32_t h;
Robert Carr3dcabfa2016-03-01 18:36:58 -080096 Transform transform;
97
Mathias Agopian13127d82013-03-05 17:47:11 -080098 inline bool operator ==(const Geometry& rhs) const {
Robert Carrb5d3d262016-03-25 15:08:13 -070099 return (w == rhs.w && h == rhs.h);
Mathias Agopian13127d82013-03-05 17:47:11 -0800100 }
101 inline bool operator !=(const Geometry& rhs) const {
102 return !operator ==(rhs);
103 }
104 };
105
106 struct State {
107 Geometry active;
108 Geometry requested;
109 uint32_t z;
110 uint32_t layerStack;
Dan Stoza9e56aa02015-11-02 13:00:03 -0800111#ifdef USE_HWC2
112 float alpha;
113#else
Mathias Agopian13127d82013-03-05 17:47:11 -0800114 uint8_t alpha;
Dan Stoza9e56aa02015-11-02 13:00:03 -0800115#endif
Mathias Agopian13127d82013-03-05 17:47:11 -0800116 uint8_t flags;
Dan Stoza7dde5992015-05-22 09:51:44 -0700117 uint8_t mask;
Mathias Agopian13127d82013-03-05 17:47:11 -0800118 uint8_t reserved[2];
119 int32_t sequence; // changes when visible regions can change
Dan Stoza7dde5992015-05-22 09:51:44 -0700120 bool modified;
121
Robert Carrb5d3d262016-03-25 15:08:13 -0700122 Rect crop;
123 Rect finalCrop;
124
Dan Stoza7dde5992015-05-22 09:51:44 -0700125 // If set, defers this state update until the Layer identified by handle
126 // receives a frame with the given frameNumber
127 sp<IBinder> handle;
128 uint64_t frameNumber;
129
Mathias Agopian2ca79392013-04-02 18:30:32 -0700130 // the transparentRegion hint is a bit special, it's latched only
131 // when we receive a buffer -- this is because it's "content"
132 // dependent.
133 Region activeTransparentRegion;
134 Region requestedTransparentRegion;
Mathias Agopian13127d82013-03-05 17:47:11 -0800135 };
136
Mathias Agopian13127d82013-03-05 17:47:11 -0800137 // -----------------------------------------------------------------------
138
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700139 Layer(SurfaceFlinger* flinger, const sp<Client>& client,
140 const String8& name, uint32_t w, uint32_t h, uint32_t flags);
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700141
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700142 virtual ~Layer();
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800143
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700144 // the this layer's size and format
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700145 status_t setBuffers(uint32_t w, uint32_t h, PixelFormat format, uint32_t flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800146
Mathias Agopian13127d82013-03-05 17:47:11 -0800147 // modify current state
148 bool setPosition(float x, float y);
149 bool setLayer(uint32_t z);
150 bool setSize(uint32_t w, uint32_t h);
Dan Stoza9e56aa02015-11-02 13:00:03 -0800151#ifdef USE_HWC2
152 bool setAlpha(float alpha);
153#else
Mathias Agopian13127d82013-03-05 17:47:11 -0800154 bool setAlpha(uint8_t alpha);
Dan Stoza9e56aa02015-11-02 13:00:03 -0800155#endif
Mathias Agopian13127d82013-03-05 17:47:11 -0800156 bool setMatrix(const layer_state_t::matrix22_t& matrix);
157 bool setTransparentRegionHint(const Region& transparent);
158 bool setFlags(uint8_t flags, uint8_t mask);
159 bool setCrop(const Rect& crop);
Pablo Ceballosacbe6782016-03-04 17:54:21 +0000160 bool setFinalCrop(const Rect& crop);
Mathias Agopian13127d82013-03-05 17:47:11 -0800161 bool setLayerStack(uint32_t layerStack);
Dan Stoza7dde5992015-05-22 09:51:44 -0700162 void deferTransactionUntil(const sp<IBinder>& handle, uint64_t frameNumber);
Mathias Agopian13127d82013-03-05 17:47:11 -0800163
Dan Stozaee44edd2015-03-23 15:50:23 -0700164 // If we have received a new buffer this frame, we will pass its surface
165 // damage down to hardware composer. Otherwise, we must send a region with
166 // one empty rect.
167 void useSurfaceDamage();
168 void useEmptyDamage();
169
Mathias Agopian13127d82013-03-05 17:47:11 -0800170 uint32_t getTransactionFlags(uint32_t flags);
171 uint32_t setTransactionFlags(uint32_t flags);
172
Dan Stozac7014012014-02-14 15:03:43 -0800173 void computeGeometry(const sp<const DisplayDevice>& hw, Mesh& mesh,
174 bool useIdentityTransform) const;
Michael Lentine6c925ed2014-09-26 17:55:01 -0700175 Rect computeBounds(const Region& activeTransparentRegion) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800176 Rect computeBounds() const;
177
Dan Stoza7dde5992015-05-22 09:51:44 -0700178 class Handle;
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700179 sp<IBinder> getHandle();
Dan Stozab9b08832014-03-13 11:55:57 -0700180 sp<IGraphicBufferProducer> getProducer() const;
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700181 const String8& getName() const;
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700182
Pablo Ceballos40845df2016-01-25 17:41:15 -0800183 int32_t getSequence() const { return sequence; }
184
Mathias Agopian13127d82013-03-05 17:47:11 -0800185 // -----------------------------------------------------------------------
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700186 // Virtuals
Mathias Agopian13127d82013-03-05 17:47:11 -0800187
Mathias Agopian13127d82013-03-05 17:47:11 -0800188 virtual const char* getTypeId() const { return "Layer"; }
189
Mathias Agopian13127d82013-03-05 17:47:11 -0800190 /*
191 * isOpaque - true if this surface is opaque
Andy McFadden4125a4f2014-01-29 17:17:11 -0800192 *
193 * This takes into account the buffer format (i.e. whether or not the
194 * pixel format includes an alpha channel) and the "opaque" flag set
195 * on the layer. It does not examine the current plane alpha value.
Mathias Agopian13127d82013-03-05 17:47:11 -0800196 */
Andy McFadden4125a4f2014-01-29 17:17:11 -0800197 virtual bool isOpaque(const Layer::State& s) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800198
199 /*
200 * isSecure - true if this surface is secure, that is if it prevents
201 * screenshots or VNC servers.
202 */
Dan Stoza23116082015-06-18 14:58:39 -0700203 virtual bool isSecure() const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800204
205 /*
206 * isProtected - true if the layer may contain protected content in the
207 * GRALLOC_USAGE_PROTECTED sense.
208 */
Jamie Gennis7a4d0df2011-03-09 17:05:02 -0800209 virtual bool isProtected() const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800210
211 /*
212 * isVisible - true if this layer is visible, false otherwise
213 */
Mathias Agopianda27af92012-09-13 18:17:13 -0700214 virtual bool isVisible() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800215
Mathias Agopian13127d82013-03-05 17:47:11 -0800216 /*
217 * isFixedSize - true if content has a fixed size
218 */
219 virtual bool isFixedSize() const;
Jamie Gennis582270d2011-08-17 18:19:00 -0700220
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700221protected:
222 /*
223 * onDraw - draws the surface.
224 */
Dan Stozac7014012014-02-14 15:03:43 -0800225 virtual void onDraw(const sp<const DisplayDevice>& hw, const Region& clip,
226 bool useIdentityTransform) const;
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700227
228public:
229 // -----------------------------------------------------------------------
230
Dan Stoza9e56aa02015-11-02 13:00:03 -0800231#ifdef USE_HWC2
232 void setGeometry(const sp<const DisplayDevice>& displayDevice);
233 void forceClientComposition(int32_t hwcId);
234 void setPerFrameData(const sp<const DisplayDevice>& displayDevice);
235
236 // callIntoHwc exists so we can update our local state and call
237 // acceptDisplayChanges without unnecessarily updating the device's state
238 void setCompositionType(int32_t hwcId, HWC2::Composition type,
239 bool callIntoHwc = true);
240 HWC2::Composition getCompositionType(int32_t hwcId) const;
241
242 void setClearClientTarget(int32_t hwcId, bool clear);
243 bool getClearClientTarget(int32_t hwcId) const;
244
245 void updateCursorPosition(const sp<const DisplayDevice>& hw);
246#else
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700247 void setGeometry(const sp<const DisplayDevice>& hw,
248 HWComposer::HWCLayerInterface& layer);
249 void setPerFrameData(const sp<const DisplayDevice>& hw,
250 HWComposer::HWCLayerInterface& layer);
251 void setAcquireFence(const sp<const DisplayDevice>& hw,
252 HWComposer::HWCLayerInterface& layer);
253
Riley Andrews03414a12014-07-01 14:22:59 -0700254 Rect getPosition(const sp<const DisplayDevice>& hw);
Dan Stoza9e56aa02015-11-02 13:00:03 -0800255#endif
Riley Andrews03414a12014-07-01 14:22:59 -0700256
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700257 /*
258 * called after page-flip
259 */
Dan Stoza9e56aa02015-11-02 13:00:03 -0800260#ifdef USE_HWC2
261 void onLayerDisplayed(const sp<Fence>& releaseFence);
262#else
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700263 void onLayerDisplayed(const sp<const DisplayDevice>& hw,
264 HWComposer::HWCLayerInterface* layer);
Dan Stoza9e56aa02015-11-02 13:00:03 -0800265#endif
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700266
Dan Stoza6b9454d2014-11-07 16:00:59 -0800267 bool shouldPresentNow(const DispSync& dispSync) const;
268
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700269 /*
270 * called before composition.
271 * returns true if the layer has pending updates.
272 */
273 bool onPreComposition();
274
275 /*
276 * called after composition.
277 */
278 void onPostComposition();
279
Dan Stoza9e56aa02015-11-02 13:00:03 -0800280#ifdef USE_HWC2
281 // If a buffer was replaced this frame, release the former buffer
282 void releasePendingBuffer();
283#endif
284
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700285 /*
286 * draw - performs some global clipping optimizations
287 * and calls onDraw().
288 */
289 void draw(const sp<const DisplayDevice>& hw, const Region& clip) const;
Dan Stozac7014012014-02-14 15:03:43 -0800290 void draw(const sp<const DisplayDevice>& hw, bool useIdentityTransform) const;
291 void draw(const sp<const DisplayDevice>& hw) const;
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700292
293 /*
294 * doTransaction - process the transaction. This is a good place to figure
295 * out which attributes of the surface have changed.
296 */
297 uint32_t doTransaction(uint32_t transactionFlags);
298
299 /*
300 * setVisibleRegion - called to set the new visible region. This gives
301 * a chance to update the new visible region or record the fact it changed.
302 */
303 void setVisibleRegion(const Region& visibleRegion);
304
305 /*
306 * setCoveredRegion - called when the covered region changes. The covered
307 * region corresponds to any area of the surface that is covered
308 * (transparently or not) by another surface.
309 */
310 void setCoveredRegion(const Region& coveredRegion);
311
312 /*
313 * setVisibleNonTransparentRegion - called when the visible and
314 * non-transparent region changes.
315 */
316 void setVisibleNonTransparentRegion(const Region&
317 visibleNonTransparentRegion);
318
319 /*
320 * latchBuffer - called each time the screen is redrawn and returns whether
321 * the visible regions need to be recomputed (this is a fairly heavy
322 * operation, so this should be set only if needed). Typically this is used
323 * to figure out if the content or size of a surface has changed.
324 */
325 Region latchBuffer(bool& recomputeVisibleRegions);
326
Riley Andrews03414a12014-07-01 14:22:59 -0700327 bool isPotentialCursor() const { return mPotentialCursor;}
328
Mathias Agopian13127d82013-03-05 17:47:11 -0800329 /*
330 * called with the state lock when the surface is removed from the
331 * current list
332 */
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700333 void onRemoved();
Mathias Agopian13127d82013-03-05 17:47:11 -0800334
335
Andy McFaddenbf974ab2012-12-04 16:51:15 -0800336 // Updates the transform hint in our SurfaceFlingerConsumer to match
Mathias Agopian84300952012-11-21 16:02:13 -0800337 // the current orientation of the display device.
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700338 void updateTransformHint(const sp<const DisplayDevice>& hw) const;
Andy McFadden69052052012-09-14 16:10:11 -0700339
Mathias Agopian13127d82013-03-05 17:47:11 -0800340 /*
341 * returns the rectangle that crops the content of the layer and scales it
342 * to the layer's size.
343 */
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700344 Rect getContentCrop() const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800345
Eric Penner51c59cd2014-07-28 19:51:58 -0700346 /*
347 * Returns if a frame is queued.
348 */
Pablo Ceballos06312182015-10-07 16:32:12 -0700349 bool hasQueuedFrame() const { return mQueuedFrames > 0 ||
Pablo Ceballosff95aab2016-01-13 17:09:58 -0800350 mSidebandStreamChanged || mAutoRefresh; }
Eric Penner51c59cd2014-07-28 19:51:58 -0700351
Dan Stoza9e56aa02015-11-02 13:00:03 -0800352#ifdef USE_HWC2
353 // -----------------------------------------------------------------------
354
355 bool hasHwcLayer(int32_t hwcId) {
356 if (mHwcLayers.count(hwcId) == 0) {
357 return false;
358 }
359 if (mHwcLayers[hwcId].layer->isAbandoned()) {
360 ALOGI("Erasing abandoned layer %s on %d", mName.string(), hwcId);
361 mHwcLayers.erase(hwcId);
362 return false;
363 }
364 return true;
365 }
366
367 std::shared_ptr<HWC2::Layer> getHwcLayer(int32_t hwcId) {
368 if (mHwcLayers.count(hwcId) == 0) {
369 return nullptr;
370 }
371 return mHwcLayers[hwcId].layer;
372 }
373
374 void setHwcLayer(int32_t hwcId, std::shared_ptr<HWC2::Layer>&& layer) {
375 if (layer) {
376 mHwcLayers[hwcId].layer = layer;
377 } else {
378 mHwcLayers.erase(hwcId);
379 }
380 }
381
382#endif
Mathias Agopian13127d82013-03-05 17:47:11 -0800383 // -----------------------------------------------------------------------
384
385 void clearWithOpenGL(const sp<const DisplayDevice>& hw, const Region& clip) const;
386 void setFiltering(bool filtering);
387 bool getFiltering() const;
388
389 // only for debugging
390 inline const sp<GraphicBuffer>& getActiveBuffer() const { return mActiveBuffer; }
391
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700392 inline const State& getDrawingState() const { return mDrawingState; }
393 inline const State& getCurrentState() const { return mCurrentState; }
394 inline State& getCurrentState() { return mCurrentState; }
Mathias Agopian13127d82013-03-05 17:47:11 -0800395
396
397 /* always call base class first */
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700398 void dump(String8& result, Colorizer& colorizer) const;
Svetoslavd85084b2014-03-20 10:28:31 -0700399 void dumpFrameStats(String8& result) const;
400 void clearFrameStats();
Jamie Gennis6547ff42013-07-16 20:12:42 -0700401 void logFrameStats();
Svetoslavd85084b2014-03-20 10:28:31 -0700402 void getFrameStats(FrameStats* outStats) const;
Mathias Agopian1b5e1022010-04-20 17:55:49 -0700403
Pablo Ceballos40845df2016-01-25 17:41:15 -0800404 void getFenceData(String8* outName, uint64_t* outFrameNumber,
405 bool* outIsGlesComposition, nsecs_t* outPostedTime,
406 sp<Fence>* outAcquireFence, sp<Fence>* outPrevReleaseFence) const;
407
Mathias Agopian13127d82013-03-05 17:47:11 -0800408protected:
409 // constant
410 sp<SurfaceFlinger> mFlinger;
411
412 virtual void onFirstRef();
413
414 /*
415 * Trivial class, used to ensure that mFlinger->onLayerDestroyed(mLayer)
416 * is called.
417 */
418 class LayerCleaner {
419 sp<SurfaceFlinger> mFlinger;
420 wp<Layer> mLayer;
421 protected:
422 ~LayerCleaner();
423 public:
424 LayerCleaner(const sp<SurfaceFlinger>& flinger, const sp<Layer>& layer);
425 };
426
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800427
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800428private:
Jesse Hall399184a2014-03-03 15:42:54 -0800429 // Interface implementation for SurfaceFlingerConsumer::ContentsChangedListener
Dan Stozadc13c5b2015-05-11 15:33:01 -0700430 virtual void onFrameAvailable(const BufferItem& item) override;
431 virtual void onFrameReplaced(const BufferItem& item) override;
432 virtual void onSidebandStreamChanged() override;
Mathias Agopian13127d82013-03-05 17:47:11 -0800433
Mathias Agopian1eae0ee2013-06-05 16:59:15 -0700434 void commitTransaction();
435
436 // needsLinearFiltering - true if this surface's state requires filtering
437 bool needsFiltering(const sp<const DisplayDevice>& hw) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800438
Mathias Agopian3330b202009-10-05 17:07:12 -0700439 uint32_t getEffectiveUsage(uint32_t usage) const;
Mathias Agopian6b442672013-07-09 21:24:52 -0700440 FloatRect computeCrop(const sp<const DisplayDevice>& hw) const;
Mathias Agopiana67932f2011-04-20 14:20:59 -0700441 bool isCropped() const;
442 static bool getOpacityForFormat(uint32_t format);
Mathias Agopian0aa758d2009-04-22 15:23:34 -0700443
Mathias Agopian13127d82013-03-05 17:47:11 -0800444 // drawing
445 void clearWithOpenGL(const sp<const DisplayDevice>& hw, const Region& clip,
Mathias Agopian3f844832013-08-07 21:24:32 -0700446 float r, float g, float b, float alpha) const;
Dan Stozac7014012014-02-14 15:03:43 -0800447 void drawWithOpenGL(const sp<const DisplayDevice>& hw, const Region& clip,
448 bool useIdentityTransform) const;
Mathias Agopian13127d82013-03-05 17:47:11 -0800449
Ruben Brunk1681d952014-06-27 15:51:55 -0700450 // Temporary - Used only for LEGACY camera mode.
451 uint32_t getProducerStickyTransform() const;
452
Dan Stoza7dde5992015-05-22 09:51:44 -0700453 // -----------------------------------------------------------------------
454
455 class SyncPoint
456 {
457 public:
458 SyncPoint(uint64_t frameNumber) : mFrameNumber(frameNumber),
459 mFrameIsAvailable(false), mTransactionIsApplied(false) {}
460
461 uint64_t getFrameNumber() const {
462 return mFrameNumber;
463 }
464
465 bool frameIsAvailable() const {
466 return mFrameIsAvailable;
467 }
468
469 void setFrameAvailable() {
470 mFrameIsAvailable = true;
471 }
472
473 bool transactionIsApplied() const {
474 return mTransactionIsApplied;
475 }
476
477 void setTransactionApplied() {
478 mTransactionIsApplied = true;
479 }
480
481 private:
482 const uint64_t mFrameNumber;
483 std::atomic<bool> mFrameIsAvailable;
484 std::atomic<bool> mTransactionIsApplied;
485 };
486
Dan Stozacac35382016-01-27 12:21:06 -0800487 // SyncPoints which will be signaled when the correct frame is at the head
488 // of the queue and dropped after the frame has been latched. Protected by
489 // mLocalSyncPointMutex.
490 Mutex mLocalSyncPointMutex;
Dan Stoza7dde5992015-05-22 09:51:44 -0700491 std::list<std::shared_ptr<SyncPoint>> mLocalSyncPoints;
492
Dan Stozacac35382016-01-27 12:21:06 -0800493 // SyncPoints which will be signaled and then dropped when the transaction
494 // is applied
Dan Stoza7dde5992015-05-22 09:51:44 -0700495 std::list<std::shared_ptr<SyncPoint>> mRemoteSyncPoints;
496
Dan Stozacac35382016-01-27 12:21:06 -0800497 uint64_t getHeadFrameNumber() const;
498
499 // Returns false if the relevant frame has already been latched
500 bool addSyncPoint(const std::shared_ptr<SyncPoint>& point);
Dan Stoza7dde5992015-05-22 09:51:44 -0700501
502 void pushPendingState();
503 void popPendingState();
504 bool applyPendingStates();
Dan Stoza7dde5992015-05-22 09:51:44 -0700505public:
506 void notifyAvailableFrames();
507private:
Igor Murashkina4a31492012-10-29 13:36:11 -0700508
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700509 // -----------------------------------------------------------------------
510
Mathias Agopiana67932f2011-04-20 14:20:59 -0700511 // constants
Andy McFaddenbf974ab2012-12-04 16:51:15 -0800512 sp<SurfaceFlingerConsumer> mSurfaceFlingerConsumer;
Dan Stozab9b08832014-03-13 11:55:57 -0700513 sp<IGraphicBufferProducer> mProducer;
Andy McFadden4df87bd2014-04-21 18:08:54 -0700514 uint32_t mTextureName; // from GLES
Mathias Agopian13127d82013-03-05 17:47:11 -0800515 bool mPremultipliedAlpha;
516 String8 mName;
Mathias Agopian13127d82013-03-05 17:47:11 -0800517 PixelFormat mFormat;
Mathias Agopian13127d82013-03-05 17:47:11 -0800518
519 // these are protected by an external lock
520 State mCurrentState;
521 State mDrawingState;
522 volatile int32_t mTransactionFlags;
Mathias Agopiand606de62010-05-10 20:06:11 -0700523
Dan Stoza7dde5992015-05-22 09:51:44 -0700524 // Accessed from main thread and binder threads
525 Mutex mPendingStateMutex;
526 Vector<State> mPendingStates;
527
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700528 // thread-safe
Mathias Agopiana67932f2011-04-20 14:20:59 -0700529 volatile int32_t mQueuedFrames;
Jesse Hall399184a2014-03-03 15:42:54 -0800530 volatile int32_t mSidebandStreamChanged; // used like an atomic boolean
Jamie Gennis4b0eba92013-02-05 13:30:24 -0800531 FrameTracker mFrameTracker;
Mathias Agopiana67932f2011-04-20 14:20:59 -0700532
533 // main thread
534 sp<GraphicBuffer> mActiveBuffer;
Jesse Hall399184a2014-03-03 15:42:54 -0800535 sp<NativeHandle> mSidebandStream;
Mathias Agopiana67932f2011-04-20 14:20:59 -0700536 Rect mCurrentCrop;
537 uint32_t mCurrentTransform;
Mathias Agopian933389f2011-07-18 16:15:08 -0700538 uint32_t mCurrentScalingMode;
Mathias Agopiana67932f2011-04-20 14:20:59 -0700539 bool mCurrentOpacity;
Dan Stozacac35382016-01-27 12:21:06 -0800540 std::atomic<uint64_t> mCurrentFrameNumber;
Mathias Agopian4d143ee2012-02-23 20:05:39 -0800541 bool mRefreshPending;
Jamie Gennise8696a42012-01-15 18:54:57 -0800542 bool mFrameLatencyNeeded;
Mathias Agopian13127d82013-03-05 17:47:11 -0800543 // Whether filtering is forced on or not
544 bool mFiltering;
545 // Whether filtering is needed b/c of the drawingstate
546 bool mNeedsFiltering;
Mathias Agopian5cdc8992013-08-13 20:51:23 -0700547 // The mesh used to draw the layer in GLES composition mode
548 mutable Mesh mMesh;
Andy McFadden4df87bd2014-04-21 18:08:54 -0700549 // The texture used to draw the layer in GLES composition mode
Mathias Agopian49457ac2013-08-14 18:20:17 -0700550 mutable Texture mTexture;
Mathias Agopiand606de62010-05-10 20:06:11 -0700551
Dan Stoza9e56aa02015-11-02 13:00:03 -0800552#ifdef USE_HWC2
553 // HWC items, accessed from the main thread
554 struct HWCInfo {
555 HWCInfo()
556 : layer(),
557 forceClientComposition(false),
558 compositionType(HWC2::Composition::Invalid),
559 clearClientTarget(false) {}
560
561 std::shared_ptr<HWC2::Layer> layer;
562 bool forceClientComposition;
563 HWC2::Composition compositionType;
564 bool clearClientTarget;
565 };
566 std::unordered_map<int32_t, HWCInfo> mHwcLayers;
Pablo Ceballos40845df2016-01-25 17:41:15 -0800567#else
568 bool mIsGlesComposition;
Dan Stoza9e56aa02015-11-02 13:00:03 -0800569#endif
570
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700571 // page-flip thread (currently main thread)
Glenn Kasten16f04532011-01-19 15:27:27 -0800572 bool mProtectedByApp; // application requires protected path to external sink
Mathias Agopian13127d82013-03-05 17:47:11 -0800573
574 // protected by mLock
575 mutable Mutex mLock;
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700576 // Set to true once we've returned this surface's handle
Mathias Agopian13127d82013-03-05 17:47:11 -0800577 mutable bool mHasSurface;
578 const wp<Client> mClientRef;
Riley Andrews03414a12014-07-01 14:22:59 -0700579
580 // This layer can be a cursor on some displays.
581 bool mPotentialCursor;
Dan Stoza6b9454d2014-11-07 16:00:59 -0800582
583 // Local copy of the queued contents of the incoming BufferQueue
584 mutable Mutex mQueueItemLock;
Dan Stozaa4650a52015-05-12 12:56:16 -0700585 Condition mQueueItemCondition;
Dan Stoza6b9454d2014-11-07 16:00:59 -0800586 Vector<BufferItem> mQueueItems;
Dan Stozacac35382016-01-27 12:21:06 -0800587 std::atomic<uint64_t> mLastFrameNumberReceived;
Dan Stoza65476f32015-05-14 09:27:25 -0700588 bool mUpdateTexImageFailed; // This is only modified from the main thread
Pablo Ceballos06312182015-10-07 16:32:12 -0700589
Pablo Ceballosff95aab2016-01-13 17:09:58 -0800590 bool mAutoRefresh;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800591};
592
593// ---------------------------------------------------------------------------
594
595}; // namespace android
596
597#endif // ANDROID_LAYER_H