Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 1 | /* |
| 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 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 19 | #include <sys/types.h> |
| 20 | #include <cstdint> |
| 21 | #include <list> |
Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 22 | #include <stack> |
| 23 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 24 | #include <android/gui/ISurfaceComposerClient.h> |
| 25 | #include <gui/LayerState.h> |
| 26 | #include <renderengine/Image.h> |
| 27 | #include <renderengine/Mesh.h> |
| 28 | #include <renderengine/RenderEngine.h> |
| 29 | #include <renderengine/Texture.h> |
| 30 | #include <system/window.h> // For NATIVE_WINDOW_SCALING_MODE_FREEZE |
| 31 | #include <ui/FrameStats.h> |
| 32 | #include <ui/GraphicBuffer.h> |
| 33 | #include <ui/PixelFormat.h> |
| 34 | #include <ui/Region.h> |
| 35 | #include <utils/RefBase.h> |
| 36 | #include <utils/String8.h> |
| 37 | #include <utils/Timers.h> |
| 38 | |
| 39 | #include "Client.h" |
| 40 | #include "DisplayHardware/HWComposer.h" |
| 41 | #include "FrameTimeline.h" |
| 42 | #include "FrameTracker.h" |
| 43 | #include "Layer.h" |
| 44 | #include "LayerVector.h" |
| 45 | #include "SurfaceFlinger.h" |
| 46 | |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 47 | namespace android { |
| 48 | |
Valerie Hau | 6449968 | 2019-04-10 11:04:29 -0700 | [diff] [blame] | 49 | class SlotGenerationTest; |
| 50 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 51 | class BufferStateLayer : public Layer { |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 52 | public: |
Lloyd Pique | 42ab75e | 2018-09-12 20:46:03 -0700 | [diff] [blame] | 53 | explicit BufferStateLayer(const LayerCreationArgs&); |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 54 | |
Alec Mouri | 4545a8a | 2019-08-08 20:05:32 -0700 | [diff] [blame] | 55 | ~BufferStateLayer() override; |
| 56 | |
Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 57 | // Implements Layer. |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 58 | sp<compositionengine::LayerFE> getCompositionEngineLayerFE() const override; |
| 59 | compositionengine::LayerFECompositionState* editCompositionState() override; |
| 60 | |
| 61 | // If we have received a new buffer this frame, we will pass its surface |
| 62 | // damage down to hardware composer. Otherwise, we must send a region with |
| 63 | // one empty rect. |
| 64 | void useSurfaceDamage() override; |
| 65 | void useEmptyDamage() override; |
| 66 | |
| 67 | bool isOpaque(const Layer::State& s) const override; |
| 68 | bool canReceiveInput() const override; |
| 69 | |
| 70 | // isVisible - true if this layer is visible, false otherwise |
| 71 | bool isVisible() const override; |
| 72 | |
| 73 | // isProtected - true if the layer may contain protected content in the |
| 74 | // GRALLOC_USAGE_PROTECTED sense. |
| 75 | bool isProtected() const override; |
| 76 | |
| 77 | // isFixedSize - true if content has a fixed size |
| 78 | bool isFixedSize() const override; |
| 79 | |
| 80 | bool usesSourceCrop() const override; |
| 81 | |
| 82 | bool isHdrY410() const override; |
| 83 | |
| 84 | void onPostComposition(const DisplayDevice*, const std::shared_ptr<FenceTime>& glDoneFence, |
| 85 | const std::shared_ptr<FenceTime>& presentFence, |
| 86 | const CompositorTiming&) override; |
| 87 | |
| 88 | // latchBuffer - called each time the screen is redrawn and returns whether |
| 89 | // the visible regions need to be recomputed (this is a fairly heavy |
| 90 | // operation, so this should be set only if needed). Typically this is used |
| 91 | // to figure out if the content or size of a surface has changed. |
| 92 | bool latchBuffer(bool& recomputeVisibleRegions, nsecs_t latchTime, |
| 93 | nsecs_t expectedPresentTime) override; |
| 94 | bool hasReadyFrame() const override; |
| 95 | |
| 96 | // Returns the current scaling mode |
| 97 | uint32_t getEffectiveScalingMode() const override; |
| 98 | |
| 99 | // Calls latchBuffer if the buffer has a frame queued and then releases the buffer. |
| 100 | // This is used if the buffer is just latched and releases to free up the buffer |
| 101 | // and will not be shown on screen. |
| 102 | // Should only be called on the main thread. |
| 103 | void latchAndReleaseBuffer() override; |
| 104 | |
| 105 | bool getTransformToDisplayInverse() const override; |
| 106 | |
| 107 | Rect getBufferCrop() const override; |
| 108 | |
| 109 | uint32_t getBufferTransform() const override; |
| 110 | |
| 111 | ui::Dataspace getDataSpace() const override; |
| 112 | |
| 113 | sp<GraphicBuffer> getBuffer() const override; |
| 114 | const std::shared_ptr<renderengine::ExternalTexture>& getExternalTexture() const override; |
| 115 | |
| 116 | ui::Transform::RotationFlags getTransformHint() const override { return mTransformHint; } |
| 117 | |
| 118 | // Implements Layer. |
chaviw | 8a01fa4 | 2019-08-19 12:39:31 -0700 | [diff] [blame] | 119 | const char* getType() const override { return "BufferStateLayer"; } |
| 120 | |
Dominik Laskowski | b17c621 | 2022-05-09 09:36:19 -0700 | [diff] [blame] | 121 | void onLayerDisplayed(ftl::SharedFuture<FenceResult>) override; |
Sally Qi | 59a9f50 | 2021-10-12 18:53:23 +0000 | [diff] [blame] | 122 | |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 123 | void releasePendingBuffer(nsecs_t dequeueReadyTime) override; |
| 124 | |
Valerie Hau | 871d635 | 2020-01-29 08:44:02 -0800 | [diff] [blame] | 125 | void finalizeFrameEventHistory(const std::shared_ptr<FenceTime>& glDoneFence, |
| 126 | const CompositorTiming& compositorTiming) override; |
| 127 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 128 | // Returns true if the next buffer should be presented at the expected present time, |
| 129 | // overridden by BufferStateLayer and BufferQueueLayer for implementation |
| 130 | // specific logic |
| 131 | bool isBufferDue(nsecs_t /*expectedPresentTime*/) const { return true; } |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 132 | |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 133 | Region getActiveTransparentRegion(const Layer::State& s) const override { |
| 134 | return s.transparentRegionHint; |
| 135 | } |
| 136 | Rect getCrop(const Layer::State& s) const; |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 137 | |
Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 138 | bool setTransform(uint32_t transform) override; |
| 139 | bool setTransformToDisplayInverse(bool transformToDisplayInverse) override; |
| 140 | bool setCrop(const Rect& crop) override; |
Vishnu Nair | dbbe385 | 2022-01-12 20:22:11 -0800 | [diff] [blame] | 141 | bool setBuffer(std::shared_ptr<renderengine::ExternalTexture>& /* buffer */, |
| 142 | const BufferData& bufferData, nsecs_t postTime, nsecs_t desiredPresentTime, |
chaviw | ba4320c | 2021-09-15 15:20:53 -0500 | [diff] [blame] | 143 | bool isAutoTimestamp, std::optional<nsecs_t> dequeueTime, |
| 144 | const FrameTimelineInfo& info) override; |
Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 145 | bool setDataspace(ui::Dataspace dataspace) override; |
| 146 | bool setHdrMetadata(const HdrMetadata& hdrMetadata) override; |
| 147 | bool setSurfaceDamageRegion(const Region& surfaceDamage) override; |
| 148 | bool setApi(int32_t api) override; |
| 149 | bool setSidebandStream(const sp<NativeHandle>& sidebandStream) override; |
Jiakai Zhang | a5505cb | 2021-11-09 11:46:30 +0000 | [diff] [blame] | 150 | bool setTransactionCompletedListeners(const std::vector<sp<CallbackHandle>>& handles) override; |
Chavi Weingarten | a5aedbd | 2021-04-09 13:37:33 +0000 | [diff] [blame] | 151 | bool setPosition(float /*x*/, float /*y*/) override; |
Robert Carr | de6d7b4 | 2022-01-07 18:23:06 -0800 | [diff] [blame] | 152 | bool setMatrix(const layer_state_t::matrix22_t& /*matrix*/); |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 153 | |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 154 | // Override to ignore legacy layer state properties that are not used by BufferStateLayer |
Marissa Wall | 861616d | 2018-10-22 12:52:23 -0700 | [diff] [blame] | 155 | bool setSize(uint32_t /*w*/, uint32_t /*h*/) override { return false; } |
Marissa Wall | 861616d | 2018-10-22 12:52:23 -0700 | [diff] [blame] | 156 | bool setTransparentRegionHint(const Region& transparent) override; |
Marissa Wall | 861616d | 2018-10-22 12:52:23 -0700 | [diff] [blame] | 157 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 158 | // BufferStateLayers can return Rect::INVALID_RECT if the layer does not have a display frame |
| 159 | // and its parent layer is not bounded |
Lloyd Pique | 0449b0f | 2018-12-20 16:23:45 -0800 | [diff] [blame] | 160 | Rect getBufferSize(const State& s) const override; |
Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 161 | FloatRect computeSourceBounds(const FloatRect& parentBounds) const override; |
Vishnu Nair | cf26a0a | 2020-11-13 12:56:20 -0800 | [diff] [blame] | 162 | void setAutoRefresh(bool autoRefresh) override; |
Valerie Hau | bc6ddb1 | 2019-03-08 11:10:15 -0800 | [diff] [blame] | 163 | |
chaviw | f3f40fe | 2021-04-27 15:54:02 -0500 | [diff] [blame] | 164 | bool setBufferCrop(const Rect& bufferCrop) override; |
Vishnu Nair | 6bdec7d | 2021-05-10 15:01:13 -0700 | [diff] [blame] | 165 | bool setDestinationFrame(const Rect& destinationFrame) override; |
Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 166 | bool updateGeometry() override; |
chaviw | f3f40fe | 2021-04-27 15:54:02 -0500 | [diff] [blame] | 167 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 168 | bool fenceHasSignaled() const; |
| 169 | bool framePresentTimeIsCurrent(nsecs_t expectedPresentTime) const; |
| 170 | bool onPreComposition(nsecs_t) override; |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 171 | |
Robert Carr | 7121caf | 2020-12-15 13:07:32 -0800 | [diff] [blame] | 172 | // See mPendingBufferTransactions |
Robert Carr | 7121caf | 2020-12-15 13:07:32 -0800 | [diff] [blame] | 173 | void decrementPendingBufferCount(); |
Vishnu Nair | 8eda69e | 2021-02-26 10:42:10 -0800 | [diff] [blame] | 174 | std::atomic<int32_t>* getPendingBufferCounter() override { return &mPendingBufferTransactions; } |
| 175 | std::string getPendingBufferCounterName() override { return mBlastTransactionName; } |
Robert Carr | 7121caf | 2020-12-15 13:07:32 -0800 | [diff] [blame] | 176 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 177 | // Returns true if the next buffer should be presented at the expected present time |
Robert Carr | 6a5dc1f | 2021-03-11 12:36:40 -0800 | [diff] [blame] | 178 | bool shouldPresentNow(nsecs_t /*expectedPresentTime*/) const override { return true; } |
| 179 | |
chaviw | 4244e03 | 2019-09-04 11:27:49 -0700 | [diff] [blame] | 180 | protected: |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 181 | void gatherBufferInfo(); |
Jorim Jaggi | 9c03b50 | 2020-11-24 23:51:31 +0100 | [diff] [blame] | 182 | void onSurfaceFrameCreated(const std::shared_ptr<frametimeline::SurfaceFrame>& surfaceFrame); |
chaviw | 39d0147 | 2021-04-08 14:26:24 -0500 | [diff] [blame] | 183 | ui::Transform getInputTransform() const override; |
| 184 | Rect getInputBounds() const override; |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 185 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 186 | struct BufferInfo { |
| 187 | nsecs_t mDesiredPresentTime; |
| 188 | std::shared_ptr<FenceTime> mFenceTime; |
| 189 | sp<Fence> mFence; |
| 190 | uint32_t mTransform{0}; |
| 191 | ui::Dataspace mDataspace{ui::Dataspace::UNKNOWN}; |
| 192 | Rect mCrop; |
| 193 | uint32_t mScaleMode{NATIVE_WINDOW_SCALING_MODE_FREEZE}; |
| 194 | Region mSurfaceDamage; |
| 195 | HdrMetadata mHdrMetadata; |
| 196 | int mApi; |
| 197 | PixelFormat mPixelFormat{PIXEL_FORMAT_NONE}; |
| 198 | bool mTransformToDisplayInverse{false}; |
| 199 | |
| 200 | std::shared_ptr<renderengine::ExternalTexture> mBuffer; |
| 201 | uint64_t mFrameNumber; |
| 202 | int mBufferSlot{BufferQueue::INVALID_BUFFER_SLOT}; |
| 203 | |
| 204 | bool mFrameLatencyNeeded{false}; |
| 205 | }; |
| 206 | |
| 207 | BufferInfo mBufferInfo; |
| 208 | |
| 209 | std::optional<compositionengine::LayerFE::LayerSettings> prepareClientComposition( |
| 210 | compositionengine::LayerFE::ClientCompositionTargetSettings&) override; |
| 211 | |
| 212 | /* |
| 213 | * compositionengine::LayerFE overrides |
| 214 | */ |
| 215 | const compositionengine::LayerFECompositionState* getCompositionState() const override; |
| 216 | void preparePerFrameCompositionState() override; |
| 217 | |
| 218 | static bool getOpacityForFormat(PixelFormat format); |
| 219 | |
| 220 | // from graphics API |
| 221 | const uint32_t mTextureName; |
| 222 | ui::Dataspace translateDataspace(ui::Dataspace dataspace); |
| 223 | void setInitialValuesForClone(const sp<Layer>& clonedFrom); |
| 224 | void updateCloneBufferInfo() override; |
| 225 | uint64_t mPreviousFrameNumber = 0; |
| 226 | |
| 227 | void setTransformHint(ui::Transform::RotationFlags displayTransformHint) override; |
| 228 | |
| 229 | // Transform hint provided to the producer. This must be accessed holding |
| 230 | // the mStateLock. |
| 231 | ui::Transform::RotationFlags mTransformHint = ui::Transform::ROT_0; |
| 232 | |
| 233 | bool getAutoRefresh() const { return mDrawingState.autoRefresh; } |
| 234 | bool getSidebandStreamChanged() const { return mSidebandStreamChanged; } |
| 235 | |
| 236 | std::atomic<bool> mSidebandStreamChanged{false}; |
| 237 | |
chaviw | 4244e03 | 2019-09-04 11:27:49 -0700 | [diff] [blame] | 238 | private: |
Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 239 | friend class SlotGenerationTest; |
Adithya Srinivasan | b238cd5 | 2021-02-04 17:54:05 +0000 | [diff] [blame] | 240 | friend class TransactionFrameTracerTest; |
Adithya Srinivasan | b9a7dab | 2021-01-14 23:49:46 +0000 | [diff] [blame] | 241 | friend class TransactionSurfaceFrameTest; |
| 242 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 243 | // We generate InputWindowHandles for all non-cursor buffered layers regardless of whether they |
| 244 | // have an InputChannel. This is to enable the InputDispatcher to do PID based occlusion |
| 245 | // detection. |
| 246 | bool needsInputInfo() const override { return !mPotentialCursor; } |
| 247 | |
| 248 | // Returns true if this layer requires filtering |
| 249 | bool needsFiltering(const DisplayDevice*) const override; |
| 250 | bool needsFilteringForScreenshots(const DisplayDevice*, |
| 251 | const ui::Transform& inverseParentTransform) const override; |
| 252 | |
| 253 | PixelFormat getPixelFormat() const; |
| 254 | |
| 255 | // Computes the transform matrix using the setFilteringEnabled to determine whether the |
| 256 | // transform matrix should be computed for use with bilinear filtering. |
| 257 | void getDrawingTransformMatrix(bool filteringEnabled, float outMatrix[16]); |
| 258 | |
| 259 | std::unique_ptr<compositionengine::LayerFECompositionState> mCompositionState; |
| 260 | |
Vishnu Nair | 8eda69e | 2021-02-26 10:42:10 -0800 | [diff] [blame] | 261 | inline void tracePendingBufferCount(int32_t pendingBuffers); |
Peiyong Lin | f243e5e | 2020-08-22 17:40:59 -0700 | [diff] [blame] | 262 | |
Valerie Hau | bf78464 | 2020-01-29 07:25:23 -0800 | [diff] [blame] | 263 | bool updateFrameEventHistory(const sp<Fence>& acquireFence, nsecs_t postedTime, |
| 264 | nsecs_t requestedPresentTime); |
| 265 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 266 | // Latch sideband stream and returns true if the dirty region should be updated. |
| 267 | bool latchSidebandStream(bool& recomputeVisibleRegions); |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 268 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 269 | bool hasFrameUpdate() const; |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 270 | |
Dominik Laskowski | a8955dd | 2019-07-10 10:19:09 -0700 | [diff] [blame] | 271 | status_t updateTexImage(bool& recomputeVisibleRegions, nsecs_t latchTime, |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 272 | nsecs_t expectedPresentTime); |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 273 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 274 | status_t updateActiveBuffer(); |
| 275 | status_t updateFrameNumber(); |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 276 | |
chaviw | b4c6e58 | 2019-08-16 14:35:07 -0700 | [diff] [blame] | 277 | sp<Layer> createClone() override; |
Dominik Laskowski | 075d317 | 2018-05-24 15:50:06 -0700 | [diff] [blame] | 278 | |
chaviw | 4244e03 | 2019-09-04 11:27:49 -0700 | [diff] [blame] | 279 | // Crop that applies to the buffer |
Vishnu Nair | 5cc9ac0 | 2021-04-19 13:23:38 -0700 | [diff] [blame] | 280 | Rect computeBufferCrop(const State& s); |
chaviw | 4244e03 | 2019-09-04 11:27:49 -0700 | [diff] [blame] | 281 | |
Marissa Wall | e2ffb42 | 2018-10-12 11:33:52 -0700 | [diff] [blame] | 282 | bool willPresentCurrentTransaction() const; |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 283 | |
Vishnu Nair | a72f6c0 | 2022-07-01 05:33:08 +0000 | [diff] [blame^] | 284 | // Returns true if the transformed buffer size does not match the layer size and we need |
| 285 | // to apply filtering. |
| 286 | bool bufferNeedsFiltering() const; |
Vishnu Nair | e7f79c5 | 2020-10-29 14:45:03 -0700 | [diff] [blame] | 287 | |
Ady Abraham | 9dada82 | 2022-02-03 10:26:59 -0800 | [diff] [blame] | 288 | bool simpleBufferUpdate(const layer_state_t& s) const override; |
| 289 | |
Chavi Weingarten | d00e0f7 | 2022-07-14 15:59:20 +0000 | [diff] [blame] | 290 | void callReleaseBufferCallback(const sp<ITransactionCompletedListener>& listener, |
| 291 | const sp<GraphicBuffer>& buffer, uint64_t framenumber, |
| 292 | const sp<Fence>& releaseFence, |
| 293 | uint32_t currentMaxAcquiredBufferCount); |
| 294 | |
Vishnu Nair | 4ba0c2e | 2021-06-24 11:27:17 -0700 | [diff] [blame] | 295 | ReleaseCallbackId mPreviousReleaseCallbackId = ReleaseCallbackId::INVALID_ID; |
Mikael Pessa | 2e1608f | 2019-07-19 11:25:35 -0700 | [diff] [blame] | 296 | uint64_t mPreviousReleasedFrameNumber = 0; |
Marissa Wall | fda30bb | 2018-10-12 11:34:28 -0700 | [diff] [blame] | 297 | |
Robert Carr | 79dc06a | 2022-02-22 15:28:59 -0800 | [diff] [blame] | 298 | uint64_t mPreviousBarrierFrameNumber = 0; |
| 299 | |
Marissa Wall | fda30bb | 2018-10-12 11:34:28 -0700 | [diff] [blame] | 300 | bool mReleasePreviousBuffer = false; |
Vishnu Nair | 1506b18 | 2021-02-22 14:35:15 -0800 | [diff] [blame] | 301 | |
| 302 | // Stores the last set acquire fence signal time used to populate the callback handle's acquire |
| 303 | // time. |
Ady Abraham | 461296a | 2022-01-21 11:11:31 -0800 | [diff] [blame] | 304 | std::variant<nsecs_t, sp<Fence>> mCallbackHandleAcquireTimeOrFence = -1; |
Marissa Wall | 024a191 | 2018-08-13 13:55:35 -0700 | [diff] [blame] | 305 | |
Jorim Jaggi | 9c03b50 | 2020-11-24 23:51:31 +0100 | [diff] [blame] | 306 | std::deque<std::shared_ptr<android::frametimeline::SurfaceFrame>> mPendingJankClassifications; |
Adithya Srinivasan | d17c7da | 2021-03-05 20:43:32 +0000 | [diff] [blame] | 307 | // An upper bound on the number of SurfaceFrames in the pending classifications deque. |
| 308 | static constexpr int kPendingClassificationMaxSurfaceFrames = 25; |
Jorim Jaggi | 9c03b50 | 2020-11-24 23:51:31 +0100 | [diff] [blame] | 309 | |
Robert Carr | 7121caf | 2020-12-15 13:07:32 -0800 | [diff] [blame] | 310 | const std::string mBlastTransactionName{"BufferTX - " + mName}; |
| 311 | // This integer is incremented everytime a buffer arrives at the server for this layer, |
| 312 | // and decremented when a buffer is dropped or latched. When changed the integer is exported |
| 313 | // to systrace with ATRACE_INT and mBlastTransactionName. This way when debugging perf it is |
| 314 | // possible to see when a buffer arrived at the server, and in which frame it latched. |
| 315 | // |
| 316 | // You can understand the trace this way: |
| 317 | // - If the integer increases, a buffer arrived at the server. |
| 318 | // - If the integer decreases in latchBuffer, that buffer was latched |
| 319 | // - If the integer decreases in setBuffer or doTransaction, a buffer was dropped |
Vishnu Nair | 8eda69e | 2021-02-26 10:42:10 -0800 | [diff] [blame] | 320 | std::atomic<int32_t> mPendingBufferTransactions{0}; |
Robert Carr | 7121caf | 2020-12-15 13:07:32 -0800 | [diff] [blame] | 321 | |
Vishnu Nair | 6bdec7d | 2021-05-10 15:01:13 -0700 | [diff] [blame] | 322 | // Contains requested position and matrix updates. This will be applied if the client does |
| 323 | // not specify a destination frame. |
| 324 | ui::Transform mRequestedTransform; |
| 325 | |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 326 | // TODO(marissaw): support sticky transform for LEGACY camera mode |
Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 327 | |
| 328 | class HwcSlotGenerator : public ClientCache::ErasedRecipient { |
| 329 | public: |
| 330 | HwcSlotGenerator() { |
rnlee | ed20fa4 | 2021-08-10 18:00:03 -0700 | [diff] [blame] | 331 | for (int i = 0; i < BufferQueue::NUM_BUFFER_SLOTS; i++) { |
Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 332 | mFreeHwcCacheSlots.push(i); |
| 333 | } |
| 334 | } |
| 335 | |
| 336 | void bufferErased(const client_cache_t& clientCacheId); |
| 337 | |
rnlee | ed20fa4 | 2021-08-10 18:00:03 -0700 | [diff] [blame] | 338 | int getHwcCacheSlot(const client_cache_t& clientCacheId); |
Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 339 | |
| 340 | private: |
Valerie Hau | 6449968 | 2019-04-10 11:04:29 -0700 | [diff] [blame] | 341 | friend class SlotGenerationTest; |
rnlee | ed20fa4 | 2021-08-10 18:00:03 -0700 | [diff] [blame] | 342 | int addCachedBuffer(const client_cache_t& clientCacheId) REQUIRES(mMutex); |
| 343 | int getFreeHwcCacheSlot() REQUIRES(mMutex); |
Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 344 | void evictLeastRecentlyUsed() REQUIRES(mMutex); |
| 345 | void eraseBufferLocked(const client_cache_t& clientCacheId) REQUIRES(mMutex); |
| 346 | |
| 347 | struct CachedBufferHash { |
| 348 | std::size_t operator()(const client_cache_t& clientCacheId) const { |
| 349 | return std::hash<uint64_t>{}(clientCacheId.id); |
| 350 | } |
| 351 | }; |
| 352 | |
| 353 | std::mutex mMutex; |
| 354 | |
rnlee | ed20fa4 | 2021-08-10 18:00:03 -0700 | [diff] [blame] | 355 | std::unordered_map<client_cache_t, std::pair<int /*HwcCacheSlot*/, uint64_t /*counter*/>, |
Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 356 | CachedBufferHash> |
| 357 | mCachedBuffers GUARDED_BY(mMutex); |
rnlee | ed20fa4 | 2021-08-10 18:00:03 -0700 | [diff] [blame] | 358 | std::stack<int /*HwcCacheSlot*/> mFreeHwcCacheSlots GUARDED_BY(mMutex); |
Marissa Wall | 947d34e | 2019-03-29 14:03:53 -0700 | [diff] [blame] | 359 | |
| 360 | // The cache increments this counter value when a slot is updated or used. |
| 361 | // Used to track the least recently-used buffer |
| 362 | uint64_t mCounter = 0; |
| 363 | }; |
| 364 | |
| 365 | sp<HwcSlotGenerator> mHwcSlotGenerator; |
Marissa Wall | 61c5862 | 2018-07-18 10:12:20 -0700 | [diff] [blame] | 366 | }; |
| 367 | |
| 368 | } // namespace android |