blob: 3551026f171e86e83fac67bae2e96fdcbb99edf6 [file] [log] [blame]
Marissa Wallfd668622018-05-10 10:21:13 -07001/*
2 * Copyright (C) 2018 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#pragma once
18
19#include "BufferLayer.h"
20
21#include <utils/String8.h>
22
23namespace android {
24
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -070025namespace frametimeline {
26class SurfaceFrame;
27}
28
Marissa Wallfd668622018-05-10 10:21:13 -070029/*
30 * A new BufferQueue and a new BufferLayerConsumer are created when the
31 * BufferLayer is first referenced.
32 *
33 * This also implements onFrameAvailable(), which notifies SurfaceFlinger
34 * that new data has arrived.
35 */
chaviw2d9a4292019-12-02 16:00:24 -080036class BufferQueueLayer : public BufferLayer {
Marissa Wallfd668622018-05-10 10:21:13 -070037public:
chaviwb4c6e582019-08-16 14:35:07 -070038 // Only call while mStateLock is held
Lloyd Pique42ab75e2018-09-12 20:46:03 -070039 explicit BufferQueueLayer(const LayerCreationArgs&);
40 ~BufferQueueLayer() override;
Marissa Wallfd668622018-05-10 10:21:13 -070041
Peiyong Linf243e5e2020-08-22 17:40:59 -070042 // Implements Layer.
chaviw8a01fa42019-08-19 12:39:31 -070043 const char* getType() const override { return "BufferQueueLayer"; }
44
Marissa Wallfd668622018-05-10 10:21:13 -070045 void onLayerDisplayed(const sp<Fence>& releaseFence) override;
46
Marissa Wallfd668622018-05-10 10:21:13 -070047 std::vector<OccupancyTracker::Segment> getOccupancyHistory(bool forceFlush) override;
48
Marissa Wallfd668622018-05-10 10:21:13 -070049 // If a buffer was replaced this frame, release the former buffer
50 void releasePendingBuffer(nsecs_t dequeueReadyTime) override;
51
52 void setDefaultBufferSize(uint32_t w, uint32_t h) override;
53
54 int32_t getQueuedFrameCount() const override;
55
Ana Krulec010d2192018-10-08 06:29:54 -070056 bool shouldPresentNow(nsecs_t expectedPresentTime) const override;
Steven Thomas3172e202020-01-06 19:25:30 -080057
Peiyong Linf243e5e2020-08-22 17:40:59 -070058 // Implements BufferLayer.
Marissa Wallfd668622018-05-10 10:21:13 -070059 bool fenceHasSignaled() const override;
Dominik Laskowskia8955dd2019-07-10 10:19:09 -070060 bool framePresentTimeIsCurrent(nsecs_t expectedPresentTime) const override;
Marissa Wallfd668622018-05-10 10:21:13 -070061
Peiyong Linf243e5e2020-08-22 17:40:59 -070062 status_t setDefaultBufferProperties(uint32_t w, uint32_t h, PixelFormat format);
63 sp<IGraphicBufferProducer> getProducer() const;
chaviw2d9a4292019-12-02 16:00:24 -080064
Marissa Wallfd668622018-05-10 10:21:13 -070065protected:
chaviw4244e032019-09-04 11:27:49 -070066 void gatherBufferInfo() override;
67
chaviw2d9a4292019-12-02 16:00:24 -080068 // -----------------------------------------------------------------------
69 // Interface implementation for BufferLayerConsumer::ContentsChangedListener
70 // -----------------------------------------------------------------------
71 class ContentsChangedListener : public BufferLayerConsumer::ContentsChangedListener {
72 public:
73 ContentsChangedListener(BufferQueueLayer* bufferQueueLayer)
74 : mBufferQueueLayer(bufferQueueLayer) {}
75 void abandon();
76
77 protected:
78 void onFrameAvailable(const BufferItem& item) override;
79 void onFrameReplaced(const BufferItem& item) override;
80 void onSidebandStreamChanged() override;
81 void onFrameDequeued(const uint64_t bufferId) override;
82 void onFrameDetached(const uint64_t bufferId) override;
83 void onFrameCancelled(const uint64_t bufferId) override;
84
85 private:
86 BufferQueueLayer* mBufferQueueLayer = nullptr;
87 Mutex mMutex;
88 };
Marissa Wallfd668622018-05-10 10:21:13 -070089
90private:
Peiyong Linf243e5e2020-08-22 17:40:59 -070091 uint64_t getFrameNumber(nsecs_t expectedPresentTime) const override;
92
Peiyong Linf243e5e2020-08-22 17:40:59 -070093 bool latchSidebandStream(bool& recomputeVisibleRegions) override;
94 void setTransformHint(ui::Transform::RotationFlags displayTransformHint) override;
95
96 bool hasFrameUpdate() const override;
97
Peiyong Linf243e5e2020-08-22 17:40:59 -070098 status_t updateTexImage(bool& recomputeVisibleRegions, nsecs_t latchTime,
99 nsecs_t expectedPresentTime) override;
100
101 status_t updateActiveBuffer() override;
102 status_t updateFrameNumber(nsecs_t latchTime) override;
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700103 void setFrameTimelineVsyncForBuffer(int64_t frameTimelineVsyncId) override;
Peiyong Linf243e5e2020-08-22 17:40:59 -0700104
105 sp<Layer> createClone() override;
Marissa Wallfd668622018-05-10 10:21:13 -0700106
107 void onFirstRef() override;
108
Peiyong Linf243e5e2020-08-22 17:40:59 -0700109 void onFrameAvailable(const BufferItem& item);
110 void onFrameReplaced(const BufferItem& item);
111 void onSidebandStreamChanged();
112 void onFrameDequeued(const uint64_t bufferId);
113 void onFrameDetached(const uint64_t bufferId);
114 void onFrameCancelled(const uint64_t bufferId);
115
116 // Temporary - Used only for LEGACY camera mode.
117 uint32_t getProducerStickyTransform() const;
118
Marissa Wallfd668622018-05-10 10:21:13 -0700119 sp<BufferLayerConsumer> mConsumer;
120 sp<IGraphicBufferProducer> mProducer;
121
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700122 bool mUpdateTexImageFailed{false};
Marissa Wallfd668622018-05-10 10:21:13 -0700123
Mikael Pessa2e1608f2019-07-19 11:25:35 -0700124 uint64_t mPreviousBufferId = 0;
125 uint64_t mPreviousReleasedFrameNumber = 0;
126
Marissa Wallfd668622018-05-10 10:21:13 -0700127 // Local copy of the queued contents of the incoming BufferQueue
128 mutable Mutex mQueueItemLock;
129 Condition mQueueItemCondition;
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -0700130
131 struct BufferData {
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100132 BufferData(BufferItem item, std::shared_ptr<frametimeline::SurfaceFrame> surfaceFrame)
133 : item(item), surfaceFrame(surfaceFrame) {}
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -0700134 BufferItem item;
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100135 std::shared_ptr<frametimeline::SurfaceFrame> surfaceFrame;
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -0700136 };
137 std::vector<BufferData> mQueueItems;
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700138 std::atomic<uint64_t> mLastFrameNumberReceived{0};
Marissa Wallfd668622018-05-10 10:21:13 -0700139
Marissa Wallfd668622018-05-10 10:21:13 -0700140 // thread-safe
Lloyd Piquef1c675b2018-09-12 20:45:39 -0700141 std::atomic<int32_t> mQueuedFrames{0};
chaviw2d9a4292019-12-02 16:00:24 -0800142
143 sp<ContentsChangedListener> mContentsChangedListener;
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700144
145 // The last vsync id received on this layer. This will be used when we get
146 // a buffer to correlate the buffer with the vsync id. Can only be accessed
147 // with the SF state lock held.
148 std::optional<int64_t> mFrameTimelineVsyncId;
Adithya Srinivasan9b2ca3e2020-11-10 10:14:17 -0800149
150 // Keeps track of the time SF latched the last buffer from this layer.
151 // Used in buffer stuffing analysis in FrameTimeline.
152 // TODO(b/176106798): Find a way to do this for BLASTBufferQueue as well.
153 nsecs_t mLastLatchTime = 0;
Marissa Wallfd668622018-05-10 10:21:13 -0700154};
155
156} // namespace android