blob: a3bd725cfe3746134f7e93364e25dbda76609fe4 [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
Vladimir Marko21092702021-10-12 12:43:47 +000045 void onLayerDisplayed(const sp<Fence>& releaseFence) override;
Marissa Wallfd668622018-05-10 10:21:13 -070046
Marissa Wallfd668622018-05-10 10:21:13 -070047 // If a buffer was replaced this frame, release the former buffer
48 void releasePendingBuffer(nsecs_t dequeueReadyTime) override;
49
50 void setDefaultBufferSize(uint32_t w, uint32_t h) override;
51
52 int32_t getQueuedFrameCount() const override;
53
Ady Abraham63a3e592021-01-06 10:47:15 -080054 // Returns true if the next buffer should be presented at the expected present time
55 bool isBufferDue(nsecs_t expectedPresentTime) const override;
Steven Thomas3172e202020-01-06 19:25:30 -080056
Peiyong Linf243e5e2020-08-22 17:40:59 -070057 // Implements BufferLayer.
Marissa Wallfd668622018-05-10 10:21:13 -070058 bool fenceHasSignaled() const override;
Dominik Laskowskia8955dd2019-07-10 10:19:09 -070059 bool framePresentTimeIsCurrent(nsecs_t expectedPresentTime) const override;
Marissa Wallfd668622018-05-10 10:21:13 -070060
Peiyong Linf243e5e2020-08-22 17:40:59 -070061 status_t setDefaultBufferProperties(uint32_t w, uint32_t h, PixelFormat format);
62 sp<IGraphicBufferProducer> getProducer() const;
chaviw2d9a4292019-12-02 16:00:24 -080063
Marissa Wallfd668622018-05-10 10:21:13 -070064protected:
chaviw4244e032019-09-04 11:27:49 -070065 void gatherBufferInfo() override;
66
chaviw2d9a4292019-12-02 16:00:24 -080067 // -----------------------------------------------------------------------
68 // Interface implementation for BufferLayerConsumer::ContentsChangedListener
69 // -----------------------------------------------------------------------
70 class ContentsChangedListener : public BufferLayerConsumer::ContentsChangedListener {
71 public:
72 ContentsChangedListener(BufferQueueLayer* bufferQueueLayer)
73 : mBufferQueueLayer(bufferQueueLayer) {}
74 void abandon();
75
76 protected:
77 void onFrameAvailable(const BufferItem& item) override;
78 void onFrameReplaced(const BufferItem& item) override;
79 void onSidebandStreamChanged() override;
80 void onFrameDequeued(const uint64_t bufferId) override;
81 void onFrameDetached(const uint64_t bufferId) override;
82 void onFrameCancelled(const uint64_t bufferId) override;
83
84 private:
85 BufferQueueLayer* mBufferQueueLayer = nullptr;
86 Mutex mMutex;
87 };
Marissa Wallfd668622018-05-10 10:21:13 -070088
89private:
Peiyong Linf243e5e2020-08-22 17:40:59 -070090
Peiyong Linf243e5e2020-08-22 17:40:59 -070091 bool latchSidebandStream(bool& recomputeVisibleRegions) override;
92 void setTransformHint(ui::Transform::RotationFlags displayTransformHint) override;
93
94 bool hasFrameUpdate() const override;
95
Peiyong Linf243e5e2020-08-22 17:40:59 -070096 status_t updateTexImage(bool& recomputeVisibleRegions, nsecs_t latchTime,
97 nsecs_t expectedPresentTime) override;
98
99 status_t updateActiveBuffer() override;
100 status_t updateFrameNumber(nsecs_t latchTime) override;
Siarhei Vishniakoufc434ac2021-01-13 10:28:00 -1000101 void setFrameTimelineInfoForBuffer(const FrameTimelineInfo& frameTimelineInfo) override;
Peiyong Linf243e5e2020-08-22 17:40:59 -0700102
103 sp<Layer> createClone() override;
Marissa Wallfd668622018-05-10 10:21:13 -0700104
105 void onFirstRef() override;
106
Peiyong Linf243e5e2020-08-22 17:40:59 -0700107 void onFrameAvailable(const BufferItem& item);
108 void onFrameReplaced(const BufferItem& item);
109 void onSidebandStreamChanged();
110 void onFrameDequeued(const uint64_t bufferId);
111 void onFrameDetached(const uint64_t bufferId);
112 void onFrameCancelled(const uint64_t bufferId);
113
114 // Temporary - Used only for LEGACY camera mode.
115 uint32_t getProducerStickyTransform() const;
116
Marissa Wallfd668622018-05-10 10:21:13 -0700117 sp<BufferLayerConsumer> mConsumer;
118 sp<IGraphicBufferProducer> mProducer;
119
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700120 bool mUpdateTexImageFailed{false};
Marissa Wallfd668622018-05-10 10:21:13 -0700121
Mikael Pessa2e1608f2019-07-19 11:25:35 -0700122 uint64_t mPreviousBufferId = 0;
123 uint64_t mPreviousReleasedFrameNumber = 0;
124
Marissa Wallfd668622018-05-10 10:21:13 -0700125 // Local copy of the queued contents of the incoming BufferQueue
126 mutable Mutex mQueueItemLock;
127 Condition mQueueItemCondition;
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -0700128
129 struct BufferData {
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100130 BufferData(BufferItem item, std::shared_ptr<frametimeline::SurfaceFrame> surfaceFrame)
131 : item(item), surfaceFrame(surfaceFrame) {}
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -0700132 BufferItem item;
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100133 std::shared_ptr<frametimeline::SurfaceFrame> surfaceFrame;
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -0700134 };
135 std::vector<BufferData> mQueueItems;
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700136 std::atomic<uint64_t> mLastFrameNumberReceived{0};
Marissa Wallfd668622018-05-10 10:21:13 -0700137
Marissa Wallfd668622018-05-10 10:21:13 -0700138 // thread-safe
Lloyd Piquef1c675b2018-09-12 20:45:39 -0700139 std::atomic<int32_t> mQueuedFrames{0};
chaviw2d9a4292019-12-02 16:00:24 -0800140
141 sp<ContentsChangedListener> mContentsChangedListener;
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700142
Siarhei Vishniakoufc434ac2021-01-13 10:28:00 -1000143 // The last vsync info received on this layer. This will be used when we get
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700144 // a buffer to correlate the buffer with the vsync id. Can only be accessed
145 // with the SF state lock held.
Siarhei Vishniakoufc434ac2021-01-13 10:28:00 -1000146 FrameTimelineInfo mFrameTimelineInfo;
Marissa Wallfd668622018-05-10 10:21:13 -0700147};
148
149} // namespace android