blob: 8ce3e1f55bc43c7a62c1cf2b086363a12f42b731 [file] [log] [blame]
Marissa Wall61c58622018-07-18 10:12:20 -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
Marissa Wall61c58622018-07-18 10:12:20 -070019#include "BufferLayer.h"
20#include "Layer.h"
21
Peiyong Lincbc184f2018-08-22 13:24:10 -070022#include <renderengine/Image.h>
23#include <renderengine/RenderEngine.h>
Marissa Wall61c58622018-07-18 10:12:20 -070024#include <system/window.h>
25#include <utils/String8.h>
26
Marissa Wall947d34e2019-03-29 14:03:53 -070027#include <stack>
28
Marissa Wall61c58622018-07-18 10:12:20 -070029namespace android {
30
Valerie Hau64499682019-04-10 11:04:29 -070031class SlotGenerationTest;
32
Marissa Wall61c58622018-07-18 10:12:20 -070033class BufferStateLayer : public BufferLayer {
34public:
Lloyd Pique42ab75e2018-09-12 20:46:03 -070035 explicit BufferStateLayer(const LayerCreationArgs&);
Marissa Wall61c58622018-07-18 10:12:20 -070036
Alec Mouri4545a8a2019-08-08 20:05:32 -070037 ~BufferStateLayer() override;
38
Peiyong Linf243e5e2020-08-22 17:40:59 -070039 // Implements Layer.
chaviw8a01fa42019-08-19 12:39:31 -070040 const char* getType() const override { return "BufferStateLayer"; }
41
Marissa Wall61c58622018-07-18 10:12:20 -070042 void onLayerDisplayed(const sp<Fence>& releaseFence) override;
Marissa Wall61c58622018-07-18 10:12:20 -070043 void releasePendingBuffer(nsecs_t dequeueReadyTime) override;
44
Valerie Hau871d6352020-01-29 08:44:02 -080045 void finalizeFrameEventHistory(const std::shared_ptr<FenceTime>& glDoneFence,
46 const CompositorTiming& compositorTiming) override;
47
Ady Abraham63a3e592021-01-06 10:47:15 -080048 bool isBufferDue(nsecs_t /*expectedPresentTime*/) const override { return true; }
Marissa Wall61c58622018-07-18 10:12:20 -070049
Marissa Wall61c58622018-07-18 10:12:20 -070050 uint32_t doTransactionResize(uint32_t flags, Layer::State* /*stateToCommit*/) override {
51 return flags;
52 }
Valerie Hau3282b3c2020-02-03 15:37:27 -080053 /*TODO:vhau return to using BufferStateLayer override once WM
54 * has removed deferred transactions!
55 void pushPendingState() override;*/
Lloyd Pique0449b0f2018-12-20 16:23:45 -080056 bool applyPendingStates(Layer::State* stateToCommit) override;
Marissa Wall61c58622018-07-18 10:12:20 -070057
chaviw766c9c52021-02-10 17:36:47 -080058 uint32_t getActiveWidth(const Layer::State& s) const override { return s.width; }
59 uint32_t getActiveHeight(const Layer::State& s) const override { return s.height; }
60 ui::Transform getActiveTransform(const Layer::State& s) const override { return s.transform; }
Marissa Wall61c58622018-07-18 10:12:20 -070061 Region getActiveTransparentRegion(const Layer::State& s) const override {
62 return s.transparentRegionHint;
63 }
64 Rect getCrop(const Layer::State& s) const;
Marissa Wall61c58622018-07-18 10:12:20 -070065
Lloyd Pique0449b0f2018-12-20 16:23:45 -080066 bool setTransform(uint32_t transform) override;
67 bool setTransformToDisplayInverse(bool transformToDisplayInverse) override;
68 bool setCrop(const Rect& crop) override;
Valerie Haubf784642020-01-29 07:25:23 -080069 bool setBuffer(const sp<GraphicBuffer>& buffer, const sp<Fence>& acquireFence, nsecs_t postTime,
Ady Abrahamf0c56492020-12-17 18:04:15 -080070 nsecs_t desiredPresentTime, bool isAutoTimestamp,
Vishnu Nairadf632b2021-01-07 14:05:08 -080071 const client_cache_t& clientCacheId, uint64_t frameNumber,
Vishnu Nair1506b182021-02-22 14:35:15 -080072 std::optional<nsecs_t> dequeueTime, const FrameTimelineInfo& info,
73 const sp<ITransactionCompletedListener>& transactionListener) override;
Lloyd Pique0449b0f2018-12-20 16:23:45 -080074 bool setAcquireFence(const sp<Fence>& fence) override;
75 bool setDataspace(ui::Dataspace dataspace) override;
76 bool setHdrMetadata(const HdrMetadata& hdrMetadata) override;
77 bool setSurfaceDamageRegion(const Region& surfaceDamage) override;
78 bool setApi(int32_t api) override;
79 bool setSidebandStream(const sp<NativeHandle>& sidebandStream) override;
80 bool setTransactionCompletedListeners(const std::vector<sp<CallbackHandle>>& handles) override;
Valerie Hau871d6352020-01-29 08:44:02 -080081 bool addFrameEvent(const sp<Fence>& acquireFence, nsecs_t postedTime,
82 nsecs_t requestedPresentTime) override;
Chavi Weingartena5aedbd2021-04-09 13:37:33 +000083 bool setPosition(float /*x*/, float /*y*/) override;
84 bool setMatrix(const layer_state_t::matrix22_t& /*matrix*/,
85 bool /*allowNonRectPreservingTransforms*/);
Marissa Wall61c58622018-07-18 10:12:20 -070086
Marissa Wall61c58622018-07-18 10:12:20 -070087 // Override to ignore legacy layer state properties that are not used by BufferStateLayer
Marissa Wall861616d2018-10-22 12:52:23 -070088 bool setSize(uint32_t /*w*/, uint32_t /*h*/) override { return false; }
Marissa Wall861616d2018-10-22 12:52:23 -070089 bool setTransparentRegionHint(const Region& transparent) override;
Marissa Wall61c58622018-07-18 10:12:20 -070090 void deferTransactionUntil_legacy(const sp<IBinder>& /*barrierHandle*/,
91 uint64_t /*frameNumber*/) override {}
92 void deferTransactionUntil_legacy(const sp<Layer>& /*barrierLayer*/,
93 uint64_t /*frameNumber*/) override {}
Marissa Wall861616d2018-10-22 12:52:23 -070094
Lloyd Pique0449b0f2018-12-20 16:23:45 -080095 Rect getBufferSize(const State& s) const override;
Vishnu Nair4351ad52019-02-11 14:13:02 -080096 FloatRect computeSourceBounds(const FloatRect& parentBounds) const override;
Vishnu Naircf26a0a2020-11-13 12:56:20 -080097 void setAutoRefresh(bool autoRefresh) override;
Valerie Haubc6ddb12019-03-08 11:10:15 -080098
Marissa Wall61c58622018-07-18 10:12:20 -070099 // -----------------------------------------------------------------------
100
101 // -----------------------------------------------------------------------
102 // Interface implementation for BufferLayer
103 // -----------------------------------------------------------------------
Lloyd Pique0449b0f2018-12-20 16:23:45 -0800104 bool fenceHasSignaled() const override;
Dominik Laskowskia8955dd2019-07-10 10:19:09 -0700105 bool framePresentTimeIsCurrent(nsecs_t expectedPresentTime) const override;
Valerie Hau871d6352020-01-29 08:44:02 -0800106 bool onPreComposition(nsecs_t refreshStartTime) override;
Robert Carr916b0362020-10-06 13:53:03 -0700107 uint32_t getEffectiveScalingMode() const override;
Marissa Wall61c58622018-07-18 10:12:20 -0700108
Robert Carr7121caf2020-12-15 13:07:32 -0800109 // See mPendingBufferTransactions
Robert Carr7121caf2020-12-15 13:07:32 -0800110 void decrementPendingBufferCount();
Vishnu Nair1506b182021-02-22 14:35:15 -0800111 void bufferMayChange(sp<GraphicBuffer>& newBuffer) override;
Vishnu Nair8eda69e2021-02-26 10:42:10 -0800112 std::atomic<int32_t>* getPendingBufferCounter() override { return &mPendingBufferTransactions; }
113 std::string getPendingBufferCounterName() override { return mBlastTransactionName; }
Robert Carr7121caf2020-12-15 13:07:32 -0800114
Robert Carr6a5dc1f2021-03-11 12:36:40 -0800115 bool shouldPresentNow(nsecs_t /*expectedPresentTime*/) const override { return true; }
116
chaviw4244e032019-09-04 11:27:49 -0700117protected:
118 void gatherBufferInfo() override;
Robert Carrfe1209c2020-02-11 12:25:35 -0800119 uint64_t getHeadFrameNumber(nsecs_t expectedPresentTime) const;
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100120 void onSurfaceFrameCreated(const std::shared_ptr<frametimeline::SurfaceFrame>& surfaceFrame);
chaviw39d01472021-04-08 14:26:24 -0500121 ui::Transform getInputTransform() const override;
122 Rect getInputBounds() const override;
Marissa Wall61c58622018-07-18 10:12:20 -0700123
chaviw4244e032019-09-04 11:27:49 -0700124private:
Peiyong Linf243e5e2020-08-22 17:40:59 -0700125 friend class SlotGenerationTest;
Adithya Srinivasanb238cd52021-02-04 17:54:05 +0000126 friend class TransactionFrameTracerTest;
Adithya Srinivasanb9a7dab2021-01-14 23:49:46 +0000127 friend class TransactionSurfaceFrameTest;
128
Vishnu Nair8eda69e2021-02-26 10:42:10 -0800129 inline void tracePendingBufferCount(int32_t pendingBuffers);
Peiyong Linf243e5e2020-08-22 17:40:59 -0700130
Valerie Haubf784642020-01-29 07:25:23 -0800131 bool updateFrameEventHistory(const sp<Fence>& acquireFence, nsecs_t postedTime,
132 nsecs_t requestedPresentTime);
133
Robert Carr8d958532020-11-10 14:09:16 -0800134 status_t addReleaseFence(const sp<CallbackHandle>& ch, const sp<Fence>& releaseFence);
135
Dominik Laskowskia8955dd2019-07-10 10:19:09 -0700136 uint64_t getFrameNumber(nsecs_t expectedPresentTime) const override;
Marissa Wall61c58622018-07-18 10:12:20 -0700137
Vishnu Nair6194e2e2019-02-06 12:58:39 -0800138 bool latchSidebandStream(bool& recomputeVisibleRegions) override;
Marissa Wall61c58622018-07-18 10:12:20 -0700139
Lloyd Pique0449b0f2018-12-20 16:23:45 -0800140 bool hasFrameUpdate() const override;
Marissa Wall61c58622018-07-18 10:12:20 -0700141
Dominik Laskowskia8955dd2019-07-10 10:19:09 -0700142 status_t updateTexImage(bool& recomputeVisibleRegions, nsecs_t latchTime,
143 nsecs_t expectedPresentTime) override;
Marissa Wall61c58622018-07-18 10:12:20 -0700144
Lloyd Pique0449b0f2018-12-20 16:23:45 -0800145 status_t updateActiveBuffer() override;
Marissa Wall61c58622018-07-18 10:12:20 -0700146 status_t updateFrameNumber(nsecs_t latchTime) override;
147
chaviwb4c6e582019-08-16 14:35:07 -0700148 sp<Layer> createClone() override;
Dominik Laskowski075d3172018-05-24 15:50:06 -0700149
chaviw4244e032019-09-04 11:27:49 -0700150 // Crop that applies to the buffer
151 Rect computeCrop(const State& s);
152
Marissa Walle2ffb422018-10-12 11:33:52 -0700153 bool willPresentCurrentTransaction() const;
Marissa Wall61c58622018-07-18 10:12:20 -0700154
Vishnu Naire7f79c52020-10-29 14:45:03 -0700155 bool bufferNeedsFiltering() const override;
156
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700157 static const std::array<float, 16> IDENTITY_MATRIX;
158
Peiyong Lin833074a2018-08-28 11:53:54 -0700159 std::unique_ptr<renderengine::Image> mTextureImage;
Marissa Wall61c58622018-07-18 10:12:20 -0700160
Valerie Hauda032562020-01-22 12:22:57 -0800161 mutable uint64_t mFrameNumber{0};
Valerie Hau2f54d642020-01-22 09:37:03 -0800162 uint64_t mFrameCounter{0};
Marissa Wall61c58622018-07-18 10:12:20 -0700163
Marissa Wallfda30bb2018-10-12 11:34:28 -0700164 sp<Fence> mPreviousReleaseFence;
Mikael Pessa2e1608f2019-07-19 11:25:35 -0700165 uint64_t mPreviousBufferId = 0;
Mikael Pessa2e1608f2019-07-19 11:25:35 -0700166 uint64_t mPreviousReleasedFrameNumber = 0;
Marissa Wallfda30bb2018-10-12 11:34:28 -0700167
Lloyd Piquef5275482019-01-29 18:42:42 -0800168 mutable bool mCurrentStateModified = false;
Marissa Wallfda30bb2018-10-12 11:34:28 -0700169 bool mReleasePreviousBuffer = false;
Vishnu Nair1506b182021-02-22 14:35:15 -0800170
171 // Stores the last set acquire fence signal time used to populate the callback handle's acquire
172 // time.
Marissa Wallfda30bb2018-10-12 11:34:28 -0700173 nsecs_t mCallbackHandleAcquireTime = -1;
Marissa Wall024a1912018-08-13 13:55:35 -0700174
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100175 std::deque<std::shared_ptr<android::frametimeline::SurfaceFrame>> mPendingJankClassifications;
Adithya Srinivasand17c7da2021-03-05 20:43:32 +0000176 // An upper bound on the number of SurfaceFrames in the pending classifications deque.
177 static constexpr int kPendingClassificationMaxSurfaceFrames = 25;
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100178
Robert Carr7121caf2020-12-15 13:07:32 -0800179 const std::string mBlastTransactionName{"BufferTX - " + mName};
180 // This integer is incremented everytime a buffer arrives at the server for this layer,
181 // and decremented when a buffer is dropped or latched. When changed the integer is exported
182 // to systrace with ATRACE_INT and mBlastTransactionName. This way when debugging perf it is
183 // possible to see when a buffer arrived at the server, and in which frame it latched.
184 //
185 // You can understand the trace this way:
186 // - If the integer increases, a buffer arrived at the server.
187 // - If the integer decreases in latchBuffer, that buffer was latched
188 // - If the integer decreases in setBuffer or doTransaction, a buffer was dropped
Vishnu Nair8eda69e2021-02-26 10:42:10 -0800189 std::atomic<int32_t> mPendingBufferTransactions{0};
Robert Carr7121caf2020-12-15 13:07:32 -0800190
Marissa Wall61c58622018-07-18 10:12:20 -0700191 // TODO(marissaw): support sticky transform for LEGACY camera mode
Marissa Wall947d34e2019-03-29 14:03:53 -0700192
193 class HwcSlotGenerator : public ClientCache::ErasedRecipient {
194 public:
195 HwcSlotGenerator() {
196 for (uint32_t i = 0; i < BufferQueue::NUM_BUFFER_SLOTS; i++) {
197 mFreeHwcCacheSlots.push(i);
198 }
199 }
200
201 void bufferErased(const client_cache_t& clientCacheId);
202
203 uint32_t getHwcCacheSlot(const client_cache_t& clientCacheId);
204
205 private:
Valerie Hau64499682019-04-10 11:04:29 -0700206 friend class SlotGenerationTest;
Marissa Wall947d34e2019-03-29 14:03:53 -0700207 uint32_t addCachedBuffer(const client_cache_t& clientCacheId) REQUIRES(mMutex);
208 uint32_t getFreeHwcCacheSlot() REQUIRES(mMutex);
209 void evictLeastRecentlyUsed() REQUIRES(mMutex);
210 void eraseBufferLocked(const client_cache_t& clientCacheId) REQUIRES(mMutex);
211
212 struct CachedBufferHash {
213 std::size_t operator()(const client_cache_t& clientCacheId) const {
214 return std::hash<uint64_t>{}(clientCacheId.id);
215 }
216 };
217
218 std::mutex mMutex;
219
220 std::unordered_map<client_cache_t,
221 std::pair<uint32_t /*HwcCacheSlot*/, uint32_t /*counter*/>,
222 CachedBufferHash>
223 mCachedBuffers GUARDED_BY(mMutex);
224 std::stack<uint32_t /*HwcCacheSlot*/> mFreeHwcCacheSlots GUARDED_BY(mMutex);
225
226 // The cache increments this counter value when a slot is updated or used.
227 // Used to track the least recently-used buffer
228 uint64_t mCounter = 0;
229 };
230
231 sp<HwcSlotGenerator> mHwcSlotGenerator;
Marissa Wall61c58622018-07-18 10:12:20 -0700232};
233
234} // namespace android