| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 1 | /* | 
 | 2 |  * Copyright 2019 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 |  | 
| Ady Abraham | b0dbdaa | 2020-01-06 16:19:42 -0800 | [diff] [blame] | 17 | // TODO(b/129481165): remove the #pragma below and fix conversion issues | 
 | 18 | #pragma clang diagnostic push | 
 | 19 | #pragma clang diagnostic ignored "-Wconversion" | 
| Marin Shalamanov | bed7fd3 | 2020-12-21 20:02:20 +0100 | [diff] [blame] | 20 | #pragma clang diagnostic ignored "-Wextra" | 
| Ady Abraham | b0dbdaa | 2020-01-06 16:19:42 -0800 | [diff] [blame] | 21 |  | 
| Marin Shalamanov | f7f6b3c | 2020-12-09 13:19:38 +0100 | [diff] [blame] | 22 | #include <algorithm> | 
 | 23 |  | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 24 | #include "RefreshRateOverlay.h" | 
 | 25 | #include "Client.h" | 
 | 26 | #include "Layer.h" | 
 | 27 |  | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 28 | #include <gui/IProducerListener.h> | 
 | 29 |  | 
 | 30 | #undef LOG_TAG | 
 | 31 | #define LOG_TAG "RefreshRateOverlay" | 
 | 32 |  | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 33 | namespace android { | 
 | 34 |  | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 35 | void RefreshRateOverlay::SevenSegmentDrawer::drawRect(const Rect& r, const half4& color, | 
 | 36 |                                                       const sp<GraphicBuffer>& buffer, | 
 | 37 |                                                       uint8_t* pixels) { | 
 | 38 |     for (int32_t j = r.top; j < r.bottom; j++) { | 
 | 39 |         if (j >= buffer->getHeight()) { | 
 | 40 |             break; | 
 | 41 |         } | 
 | 42 |  | 
 | 43 |         for (int32_t i = r.left; i < r.right; i++) { | 
 | 44 |             if (i >= buffer->getWidth()) { | 
 | 45 |                 break; | 
 | 46 |             } | 
 | 47 |  | 
 | 48 |             uint8_t* iter = pixels + 4 * (i + (buffer->getStride() * j)); | 
 | 49 |             iter[0] = uint8_t(color.r * 255); | 
 | 50 |             iter[1] = uint8_t(color.g * 255); | 
 | 51 |             iter[2] = uint8_t(color.b * 255); | 
 | 52 |             iter[3] = uint8_t(color.a * 255); | 
 | 53 |         } | 
 | 54 |     } | 
 | 55 | } | 
 | 56 |  | 
 | 57 | void RefreshRateOverlay::SevenSegmentDrawer::drawSegment(Segment segment, int left, | 
 | 58 |                                                          const half4& color, | 
 | 59 |                                                          const sp<GraphicBuffer>& buffer, | 
 | 60 |                                                          uint8_t* pixels) { | 
 | 61 |     const Rect rect = [&]() { | 
 | 62 |         switch (segment) { | 
 | 63 |             case Segment::Upper: | 
 | 64 |                 return Rect(left, 0, left + DIGIT_WIDTH, DIGIT_SPACE); | 
 | 65 |             case Segment::UpperLeft: | 
 | 66 |                 return Rect(left, 0, left + DIGIT_SPACE, DIGIT_HEIGHT / 2); | 
 | 67 |             case Segment::UpperRight: | 
 | 68 |                 return Rect(left + DIGIT_WIDTH - DIGIT_SPACE, 0, left + DIGIT_WIDTH, | 
 | 69 |                             DIGIT_HEIGHT / 2); | 
 | 70 |             case Segment::Middle: | 
 | 71 |                 return Rect(left, DIGIT_HEIGHT / 2 - DIGIT_SPACE / 2, left + DIGIT_WIDTH, | 
 | 72 |                             DIGIT_HEIGHT / 2 + DIGIT_SPACE / 2); | 
 | 73 |             case Segment::LowerLeft: | 
 | 74 |                 return Rect(left, DIGIT_HEIGHT / 2, left + DIGIT_SPACE, DIGIT_HEIGHT); | 
 | 75 |             case Segment::LowerRight: | 
 | 76 |                 return Rect(left + DIGIT_WIDTH - DIGIT_SPACE, DIGIT_HEIGHT / 2, left + DIGIT_WIDTH, | 
 | 77 |                             DIGIT_HEIGHT); | 
 | 78 |             case Segment::Buttom: | 
 | 79 |                 return Rect(left, DIGIT_HEIGHT - DIGIT_SPACE, left + DIGIT_WIDTH, DIGIT_HEIGHT); | 
 | 80 |         } | 
 | 81 |     }(); | 
 | 82 |  | 
 | 83 |     drawRect(rect, color, buffer, pixels); | 
 | 84 | } | 
 | 85 |  | 
 | 86 | void RefreshRateOverlay::SevenSegmentDrawer::drawDigit(int digit, int left, const half4& color, | 
 | 87 |                                                        const sp<GraphicBuffer>& buffer, | 
 | 88 |                                                        uint8_t* pixels) { | 
 | 89 |     if (digit < 0 || digit > 9) return; | 
 | 90 |  | 
 | 91 |     if (digit == 0 || digit == 2 || digit == 3 || digit == 5 || digit == 6 || digit == 7 || | 
 | 92 |         digit == 8 || digit == 9) | 
 | 93 |         drawSegment(Segment::Upper, left, color, buffer, pixels); | 
 | 94 |     if (digit == 0 || digit == 4 || digit == 5 || digit == 6 || digit == 8 || digit == 9) | 
 | 95 |         drawSegment(Segment::UpperLeft, left, color, buffer, pixels); | 
 | 96 |     if (digit == 0 || digit == 1 || digit == 2 || digit == 3 || digit == 4 || digit == 7 || | 
 | 97 |         digit == 8 || digit == 9) | 
 | 98 |         drawSegment(Segment::UpperRight, left, color, buffer, pixels); | 
 | 99 |     if (digit == 2 || digit == 3 || digit == 4 || digit == 5 || digit == 6 || digit == 8 || | 
 | 100 |         digit == 9) | 
 | 101 |         drawSegment(Segment::Middle, left, color, buffer, pixels); | 
 | 102 |     if (digit == 0 || digit == 2 || digit == 6 || digit == 8) | 
 | 103 |         drawSegment(Segment::LowerLeft, left, color, buffer, pixels); | 
 | 104 |     if (digit == 0 || digit == 1 || digit == 3 || digit == 4 || digit == 5 || digit == 6 || | 
 | 105 |         digit == 7 || digit == 8 || digit == 9) | 
 | 106 |         drawSegment(Segment::LowerRight, left, color, buffer, pixels); | 
 | 107 |     if (digit == 0 || digit == 2 || digit == 3 || digit == 5 || digit == 6 || digit == 8 || | 
 | 108 |         digit == 9) | 
 | 109 |         drawSegment(Segment::Buttom, left, color, buffer, pixels); | 
 | 110 | } | 
 | 111 |  | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 112 | std::vector<sp<GraphicBuffer>> RefreshRateOverlay::SevenSegmentDrawer::drawNumber( | 
 | 113 |         int number, const half4& color, bool showSpinner) { | 
 | 114 |     if (number < 0 || number > 1000) return {}; | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 115 |  | 
 | 116 |     const auto hundreds = number / 100; | 
 | 117 |     const auto tens = (number / 10) % 10; | 
 | 118 |     const auto ones = number % 10; | 
 | 119 |  | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 120 |     std::vector<sp<GraphicBuffer>> buffers; | 
 | 121 |     const auto loopCount = showSpinner ? 6 : 1; | 
 | 122 |     for (int i = 0; i < loopCount; i++) { | 
 | 123 |         sp<GraphicBuffer> buffer = | 
 | 124 |                 new GraphicBuffer(BUFFER_WIDTH, BUFFER_HEIGHT, HAL_PIXEL_FORMAT_RGBA_8888, 1, | 
 | 125 |                                   GRALLOC_USAGE_SW_WRITE_RARELY | GRALLOC_USAGE_HW_COMPOSER | | 
 | 126 |                                           GRALLOC_USAGE_HW_TEXTURE, | 
 | 127 |                                   "RefreshRateOverlayBuffer"); | 
| Alec Mouri | 7013b6f | 2021-02-12 11:16:54 -0800 | [diff] [blame] | 128 |         const status_t bufferStatus = buffer->initCheck(); | 
 | 129 |         LOG_ALWAYS_FATAL_IF(bufferStatus != OK, "RefreshRateOverlay: Buffer failed to allocate: %d", | 
 | 130 |                             bufferStatus); | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 131 |         uint8_t* pixels; | 
 | 132 |         buffer->lock(GRALLOC_USAGE_SW_WRITE_RARELY, reinterpret_cast<void**>(&pixels)); | 
 | 133 |         // Clear buffer content | 
 | 134 |         drawRect(Rect(BUFFER_WIDTH, BUFFER_HEIGHT), half4(0), buffer, pixels); | 
 | 135 |         int left = 0; | 
 | 136 |         if (hundreds != 0) { | 
 | 137 |             drawDigit(hundreds, left, color, buffer, pixels); | 
 | 138 |         } | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 139 |         left += DIGIT_WIDTH + DIGIT_SPACE; | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 140 |  | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 141 |         if (tens != 0) { | 
 | 142 |             drawDigit(tens, left, color, buffer, pixels); | 
 | 143 |         } | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 144 |         left += DIGIT_WIDTH + DIGIT_SPACE; | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 145 |  | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 146 |         drawDigit(ones, left, color, buffer, pixels); | 
 | 147 |         left += DIGIT_WIDTH + DIGIT_SPACE; | 
 | 148 |  | 
 | 149 |         if (showSpinner) { | 
 | 150 |             switch (i) { | 
 | 151 |                 case 0: | 
 | 152 |                     drawSegment(Segment::Upper, left, color, buffer, pixels); | 
 | 153 |                     break; | 
 | 154 |                 case 1: | 
 | 155 |                     drawSegment(Segment::UpperRight, left, color, buffer, pixels); | 
 | 156 |                     break; | 
 | 157 |                 case 2: | 
 | 158 |                     drawSegment(Segment::LowerRight, left, color, buffer, pixels); | 
 | 159 |                     break; | 
 | 160 |                 case 3: | 
 | 161 |                     drawSegment(Segment::Buttom, left, color, buffer, pixels); | 
 | 162 |                     break; | 
 | 163 |                 case 4: | 
 | 164 |                     drawSegment(Segment::LowerLeft, left, color, buffer, pixels); | 
 | 165 |                     break; | 
 | 166 |                 case 5: | 
 | 167 |                     drawSegment(Segment::UpperLeft, left, color, buffer, pixels); | 
 | 168 |                     break; | 
 | 169 |             } | 
 | 170 |         } | 
 | 171 |  | 
 | 172 |         buffer->unlock(); | 
 | 173 |         buffers.emplace_back(buffer); | 
 | 174 |     } | 
 | 175 |     return buffers; | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 176 | } | 
 | 177 |  | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 178 | RefreshRateOverlay::RefreshRateOverlay(SurfaceFlinger& flinger, bool showSpinner) | 
 | 179 |       : mFlinger(flinger), mClient(new Client(&mFlinger)), mShowSpinner(showSpinner) { | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 180 |     createLayer(); | 
| Marin Shalamanov | f7f6b3c | 2020-12-09 13:19:38 +0100 | [diff] [blame] | 181 |     reset(); | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 182 | } | 
 | 183 |  | 
 | 184 | bool RefreshRateOverlay::createLayer() { | 
| Ady Abraham | 9f0a400 | 2020-10-05 15:47:26 -0700 | [diff] [blame] | 185 |     int32_t layerId; | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 186 |     const status_t ret = | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 187 |             mFlinger.createLayer(String8("RefreshRateOverlay"), mClient, | 
 | 188 |                                  SevenSegmentDrawer::getWidth(), SevenSegmentDrawer::getHeight(), | 
 | 189 |                                  PIXEL_FORMAT_RGBA_8888, | 
 | 190 |                                  ISurfaceComposerClient::eFXSurfaceBufferState, LayerMetadata(), | 
| Ady Abraham | 9f0a400 | 2020-10-05 15:47:26 -0700 | [diff] [blame] | 191 |                                  &mIBinder, &mGbp, nullptr, &layerId); | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 192 |     if (ret) { | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 193 |         ALOGE("failed to create buffer state layer"); | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 194 |         return false; | 
 | 195 |     } | 
 | 196 |  | 
| Ady Abraham | fed164b | 2019-05-10 17:12:54 -0700 | [diff] [blame] | 197 |     Mutex::Autolock _l(mFlinger.mStateLock); | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 198 |     mLayer = mClient->getLayerUser(mIBinder); | 
| Marin Shalamanov | e8a663d | 2020-11-24 17:48:00 +0100 | [diff] [blame] | 199 |     mLayer->setFrameRate(Layer::FrameRate(Fps(0.0f), Layer::FrameRateCompatibility::NoVote)); | 
| Vishnu Nair | 14d218b | 2021-07-13 13:57:39 -0700 | [diff] [blame] | 200 |     mLayer->setIsAtRoot(true); | 
| Ady Abraham | fed164b | 2019-05-10 17:12:54 -0700 | [diff] [blame] | 201 |  | 
 | 202 |     // setting Layer's Z requires resorting layersSortedByZ | 
| Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 203 |     ssize_t idx = mFlinger.mDrawingState.layersSortedByZ.indexOf(mLayer); | 
| Ady Abraham | fed164b | 2019-05-10 17:12:54 -0700 | [diff] [blame] | 204 |     if (mLayer->setLayer(INT32_MAX - 2) && idx >= 0) { | 
| Robert Carr | 6a16031 | 2021-05-17 12:08:20 -0700 | [diff] [blame] | 205 |         mFlinger.mDrawingState.layersSortedByZ.removeAt(idx); | 
 | 206 |         mFlinger.mDrawingState.layersSortedByZ.add(mLayer); | 
| Ady Abraham | fed164b | 2019-05-10 17:12:54 -0700 | [diff] [blame] | 207 |     } | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 208 |  | 
 | 209 |     return true; | 
 | 210 | } | 
 | 211 |  | 
| Alec Mouri | a90a570 | 2021-04-16 16:36:21 +0000 | [diff] [blame] | 212 | const std::vector<std::shared_ptr<renderengine::ExternalTexture>>& | 
 | 213 | RefreshRateOverlay::getOrCreateBuffers(uint32_t fps) { | 
| Marin Shalamanov | f7f6b3c | 2020-12-09 13:19:38 +0100 | [diff] [blame] | 214 |     if (mBufferCache.find(fps) == mBufferCache.end()) { | 
 | 215 |         // Ensure the range is > 0, so we don't divide by 0. | 
 | 216 |         const auto rangeLength = std::max(1u, mHighFps - mLowFps); | 
 | 217 |         // Clip values outside the range [mLowFps, mHighFps]. The current fps may be outside | 
 | 218 |         // of this range if the display has changed its set of supported refresh rates. | 
 | 219 |         fps = std::max(fps, mLowFps); | 
 | 220 |         fps = std::min(fps, mHighFps); | 
 | 221 |         const auto fpsScale = static_cast<float>(fps - mLowFps) / rangeLength; | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 222 |         half4 color; | 
 | 223 |         color.r = HIGH_FPS_COLOR.r * fpsScale + LOW_FPS_COLOR.r * (1 - fpsScale); | 
 | 224 |         color.g = HIGH_FPS_COLOR.g * fpsScale + LOW_FPS_COLOR.g * (1 - fpsScale); | 
 | 225 |         color.b = HIGH_FPS_COLOR.b * fpsScale + LOW_FPS_COLOR.b * (1 - fpsScale); | 
 | 226 |         color.a = ALPHA; | 
| Alec Mouri | a90a570 | 2021-04-16 16:36:21 +0000 | [diff] [blame] | 227 |         auto buffers = SevenSegmentDrawer::drawNumber(fps, color, mShowSpinner); | 
 | 228 |         std::vector<std::shared_ptr<renderengine::ExternalTexture>> textures; | 
 | 229 |         std::transform(buffers.begin(), buffers.end(), std::back_inserter(textures), | 
 | 230 |                        [&](const auto& buffer) -> std::shared_ptr<renderengine::ExternalTexture> { | 
 | 231 |                            return std::make_shared< | 
 | 232 |                                    renderengine::ExternalTexture>(buffer, | 
 | 233 |                                                                   mFlinger.getRenderEngine(), | 
 | 234 |                                                                   renderengine::ExternalTexture:: | 
 | 235 |                                                                           Usage::READABLE); | 
 | 236 |                        }); | 
 | 237 |         mBufferCache.emplace(fps, textures); | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 238 |     } | 
| Marin Shalamanov | f7f6b3c | 2020-12-09 13:19:38 +0100 | [diff] [blame] | 239 |  | 
 | 240 |     return mBufferCache[fps]; | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 241 | } | 
 | 242 |  | 
| Dominik Laskowski | 2013464 | 2020-04-20 22:36:44 -0700 | [diff] [blame] | 243 | void RefreshRateOverlay::setViewport(ui::Size viewport) { | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 244 |     Rect frame((3 * viewport.width) >> 4, viewport.height >> 5); | 
| Dominik Laskowski | 2013464 | 2020-04-20 22:36:44 -0700 | [diff] [blame] | 245 |     frame.offsetBy(viewport.width >> 5, viewport.height >> 4); | 
| Ady Abraham | 2cb8b62 | 2019-12-02 18:55:33 -0800 | [diff] [blame] | 246 |  | 
| Chavi Weingarten | a5aedbd | 2021-04-09 13:37:33 +0000 | [diff] [blame] | 247 |     layer_state_t::matrix22_t matrix; | 
 | 248 |     matrix.dsdx = frame.getWidth() / static_cast<float>(SevenSegmentDrawer::getWidth()); | 
 | 249 |     matrix.dtdx = 0; | 
 | 250 |     matrix.dtdy = 0; | 
 | 251 |     matrix.dsdy = frame.getHeight() / static_cast<float>(SevenSegmentDrawer::getHeight()); | 
 | 252 |     mLayer->setMatrix(matrix, true); | 
 | 253 |     mLayer->setPosition(frame.left, frame.top); | 
| Ady Abraham | fe57b76 | 2019-04-17 20:06:14 -0700 | [diff] [blame] | 254 |     mFlinger.mTransactionFlags.fetch_or(eTransactionMask); | 
| Ady Abraham | 03b02dd | 2019-03-21 15:40:11 -0700 | [diff] [blame] | 255 | } | 
 | 256 |  | 
| Marin Shalamanov | eadf2e7 | 2020-12-10 15:35:28 +0100 | [diff] [blame] | 257 | void RefreshRateOverlay::changeRefreshRate(const Fps& fps) { | 
 | 258 |     mCurrentFps = fps.getIntValue(); | 
| Marin Shalamanov | f7f6b3c | 2020-12-09 13:19:38 +0100 | [diff] [blame] | 259 |     auto buffer = getOrCreateBuffers(*mCurrentFps)[mFrame]; | 
| Ady Abraham | f0c5649 | 2020-12-17 18:04:15 -0800 | [diff] [blame] | 260 |     mLayer->setBuffer(buffer, Fence::NO_FENCE, 0, 0, true, {}, | 
| Vishnu Nair | adf632b | 2021-01-07 14:05:08 -0800 | [diff] [blame] | 261 |                       mLayer->getHeadFrameNumber(-1 /* expectedPresentTime */), | 
| Vishnu Nair | 1506b18 | 2021-02-22 14:35:15 -0800 | [diff] [blame] | 262 |                       std::nullopt /* dequeueTime */, FrameTimelineInfo{}, | 
 | 263 |                       nullptr /* releaseBufferListener */); | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 264 |  | 
 | 265 |     mFlinger.mTransactionFlags.fetch_or(eTransactionMask); | 
 | 266 | } | 
 | 267 |  | 
 | 268 | void RefreshRateOverlay::onInvalidate() { | 
 | 269 |     if (!mCurrentFps.has_value()) return; | 
 | 270 |  | 
| Marin Shalamanov | f7f6b3c | 2020-12-09 13:19:38 +0100 | [diff] [blame] | 271 |     const auto& buffers = getOrCreateBuffers(*mCurrentFps); | 
| Ady Abraham | 29d0da3 | 2020-07-16 18:39:33 -0700 | [diff] [blame] | 272 |     mFrame = (mFrame + 1) % buffers.size(); | 
 | 273 |     auto buffer = buffers[mFrame]; | 
| Ady Abraham | f0c5649 | 2020-12-17 18:04:15 -0800 | [diff] [blame] | 274 |     mLayer->setBuffer(buffer, Fence::NO_FENCE, 0, 0, true, {}, | 
| Vishnu Nair | adf632b | 2021-01-07 14:05:08 -0800 | [diff] [blame] | 275 |                       mLayer->getHeadFrameNumber(-1 /* expectedPresentTime */), | 
| Vishnu Nair | 1506b18 | 2021-02-22 14:35:15 -0800 | [diff] [blame] | 276 |                       std::nullopt /* dequeueTime */, FrameTimelineInfo{}, | 
 | 277 |                       nullptr /* releaseBufferListener */); | 
| Dominik Laskowski | 2013464 | 2020-04-20 22:36:44 -0700 | [diff] [blame] | 278 |  | 
 | 279 |     mFlinger.mTransactionFlags.fetch_or(eTransactionMask); | 
 | 280 | } | 
 | 281 |  | 
| Marin Shalamanov | f7f6b3c | 2020-12-09 13:19:38 +0100 | [diff] [blame] | 282 | void RefreshRateOverlay::reset() { | 
 | 283 |     mBufferCache.clear(); | 
| Marin Shalamanov | eadf2e7 | 2020-12-10 15:35:28 +0100 | [diff] [blame] | 284 |     const auto range = mFlinger.mRefreshRateConfigs->getSupportedRefreshRateRange(); | 
 | 285 |     mLowFps = range.min.getIntValue(); | 
 | 286 |     mHighFps = range.max.getIntValue(); | 
| Marin Shalamanov | f7f6b3c | 2020-12-09 13:19:38 +0100 | [diff] [blame] | 287 | } | 
 | 288 |  | 
| Dominik Laskowski | 2013464 | 2020-04-20 22:36:44 -0700 | [diff] [blame] | 289 | } // namespace android | 
| Ady Abraham | b0dbdaa | 2020-01-06 16:19:42 -0800 | [diff] [blame] | 290 |  | 
 | 291 | // TODO(b/129481165): remove the #pragma below and fix conversion issues | 
| Marin Shalamanov | bed7fd3 | 2020-12-21 20:02:20 +0100 | [diff] [blame] | 292 | #pragma clang diagnostic pop // ignored "-Wconversion -Wextra" |