John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2014 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 | #include "DeferredLayerUpdater.h" |
| 17 | |
Fedor Kudasov | d501e10 | 2019-06-21 10:22:53 +0100 | [diff] [blame] | 18 | #include <GLES2/gl2.h> |
| 19 | #include <GLES2/gl2ext.h> |
| 20 | |
Stan Iliev | 5af5d30 | 2020-01-13 11:29:18 -0500 | [diff] [blame] | 21 | // TODO: Use public SurfaceTexture APIs once available and include public NDK header file instead. |
| 22 | #include <surfacetexture/surface_texture_platform.h> |
Alec Mouri | d0001fe | 2021-11-22 10:09:22 -0800 | [diff] [blame] | 23 | |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 24 | #include "AutoBackendTextureRelease.h" |
bsears | 9df09ccf | 2021-08-06 15:18:26 +0000 | [diff] [blame] | 25 | #include "Matrix.h" |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 26 | #include "Properties.h" |
Alec Mouri | d0001fe | 2021-11-22 10:09:22 -0800 | [diff] [blame] | 27 | #include "android/hdr_metadata.h" |
sergeyv | 3e9999b | 2017-01-19 15:37:02 -0800 | [diff] [blame] | 28 | #include "renderstate/RenderState.h" |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 29 | #include "renderthread/EglManager.h" |
| 30 | #include "renderthread/RenderThread.h" |
| 31 | #include "renderthread/VulkanManager.h" |
| 32 | |
| 33 | using namespace android::uirenderer::renderthread; |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 34 | |
| 35 | namespace android { |
| 36 | namespace uirenderer { |
| 37 | |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 38 | DeferredLayerUpdater::DeferredLayerUpdater(RenderState& renderState) |
sergeyv | 3e9999b | 2017-01-19 15:37:02 -0800 | [diff] [blame] | 39 | : mRenderState(renderState) |
| 40 | , mBlend(false) |
Stan Iliev | 5af5d30 | 2020-01-13 11:29:18 -0500 | [diff] [blame] | 41 | , mSurfaceTexture(nullptr, [](ASurfaceTexture*) {}) |
Chris Craik | d41c4d8 | 2015-01-05 15:51:13 -0800 | [diff] [blame] | 42 | , mTransform(nullptr) |
sergeyv | 00eb43d | 2017-02-13 14:34:15 -0800 | [diff] [blame] | 43 | , mGLContextAttached(false) |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 44 | , mUpdateTexImage(false) |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 45 | , mLayer(nullptr) { |
Derek Sollenberger | 28a4d99 | 2018-09-20 13:37:24 -0400 | [diff] [blame] | 46 | renderState.registerContextCallback(this); |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 47 | } |
| 48 | |
| 49 | DeferredLayerUpdater::~DeferredLayerUpdater() { |
Chris Craik | d41c4d8 | 2015-01-05 15:51:13 -0800 | [diff] [blame] | 50 | setTransform(nullptr); |
Derek Sollenberger | 28a4d99 | 2018-09-20 13:37:24 -0400 | [diff] [blame] | 51 | mRenderState.removeContextCallback(this); |
| 52 | destroyLayer(); |
| 53 | } |
| 54 | |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 55 | void DeferredLayerUpdater::setSurfaceTexture(AutoTextureRelease&& consumer) { |
| 56 | mSurfaceTexture = std::move(consumer); |
Fedor Kudasov | d501e10 | 2019-06-21 10:22:53 +0100 | [diff] [blame] | 57 | |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 58 | GLenum target = ASurfaceTexture_getCurrentTextureTarget(mSurfaceTexture.get()); |
| 59 | LOG_ALWAYS_FATAL_IF(target != GL_TEXTURE_2D && target != GL_TEXTURE_EXTERNAL_OES, |
| 60 | "set unsupported SurfaceTexture with target %x", target); |
Fedor Kudasov | d501e10 | 2019-06-21 10:22:53 +0100 | [diff] [blame] | 61 | } |
| 62 | |
Derek Sollenberger | 28a4d99 | 2018-09-20 13:37:24 -0400 | [diff] [blame] | 63 | void DeferredLayerUpdater::onContextDestroyed() { |
sergeyv | 3e9999b | 2017-01-19 15:37:02 -0800 | [diff] [blame] | 64 | destroyLayer(); |
| 65 | } |
| 66 | |
| 67 | void DeferredLayerUpdater::destroyLayer() { |
sergeyv | 00eb43d | 2017-02-13 14:34:15 -0800 | [diff] [blame] | 68 | if (!mLayer) { |
| 69 | return; |
sergeyv | 3e9999b | 2017-01-19 15:37:02 -0800 | [diff] [blame] | 70 | } |
sergeyv | 00eb43d | 2017-02-13 14:34:15 -0800 | [diff] [blame] | 71 | |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 72 | if (mSurfaceTexture.get() && mGLContextAttached) { |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 73 | ASurfaceTexture_releaseConsumerOwnership(mSurfaceTexture.get()); |
sergeyv | 00eb43d | 2017-02-13 14:34:15 -0800 | [diff] [blame] | 74 | mGLContextAttached = false; |
sergeyv | 00eb43d | 2017-02-13 14:34:15 -0800 | [diff] [blame] | 75 | } |
| 76 | |
| 77 | mLayer->postDecStrong(); |
Stan Iliev | 1a025a7 | 2018-09-05 16:35:11 -0400 | [diff] [blame] | 78 | |
sergeyv | 00eb43d | 2017-02-13 14:34:15 -0800 | [diff] [blame] | 79 | mLayer = nullptr; |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 80 | |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 81 | for (auto& [index, slot] : mImageSlots) { |
| 82 | slot.clear(mRenderState.getRenderThread().getGrContext()); |
| 83 | } |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 84 | mImageSlots.clear(); |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 85 | } |
| 86 | |
Derek Sollenberger | 674554f | 2014-02-19 16:47:32 +0000 | [diff] [blame] | 87 | void DeferredLayerUpdater::setPaint(const SkPaint* paint) { |
Chris Craik | bf6f0f2 | 2015-10-01 12:36:07 -0700 | [diff] [blame] | 88 | mAlpha = PaintUtils::getAlphaDirect(paint); |
Mike Reed | 260ab72 | 2016-10-07 15:59:20 -0400 | [diff] [blame] | 89 | mMode = PaintUtils::getBlendModeDirect(paint); |
Derek Sollenberger | be3876c | 2018-04-20 16:13:31 -0400 | [diff] [blame] | 90 | if (paint) { |
| 91 | mColorFilter = paint->refColorFilter(); |
| 92 | } else { |
| 93 | mColorFilter.reset(); |
| 94 | } |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 95 | } |
| 96 | |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 97 | status_t DeferredLayerUpdater::createReleaseFence(bool useFenceSync, EGLSyncKHR* eglFence, |
| 98 | EGLDisplay* display, int* releaseFence, |
| 99 | void* handle) { |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 100 | *display = EGL_NO_DISPLAY; |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 101 | DeferredLayerUpdater* dlu = (DeferredLayerUpdater*)handle; |
| 102 | RenderState& renderState = dlu->mRenderState; |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 103 | status_t err; |
| 104 | if (Properties::getRenderPipelineType() == RenderPipelineType::SkiaGL) { |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 105 | EglManager& eglManager = renderState.getRenderThread().eglManager(); |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 106 | *display = eglManager.eglDisplay(); |
| 107 | err = eglManager.createReleaseFence(useFenceSync, eglFence, releaseFence); |
| 108 | } else { |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 109 | int previousSlot = dlu->mCurrentSlot; |
| 110 | if (previousSlot != -1) { |
| 111 | dlu->mImageSlots[previousSlot].releaseQueueOwnership( |
| 112 | renderState.getRenderThread().getGrContext()); |
| 113 | } |
| 114 | err = renderState.getRenderThread().vulkanManager().createReleaseFence( |
| 115 | releaseFence, renderState.getRenderThread().getGrContext()); |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 116 | } |
| 117 | return err; |
| 118 | } |
| 119 | |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 120 | status_t DeferredLayerUpdater::fenceWait(int fence, void* handle) { |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 121 | // Wait on the producer fence for the buffer to be ready. |
| 122 | status_t err; |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 123 | DeferredLayerUpdater* dlu = (DeferredLayerUpdater*)handle; |
| 124 | RenderState& renderState = dlu->mRenderState; |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 125 | if (Properties::getRenderPipelineType() == RenderPipelineType::SkiaGL) { |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 126 | err = renderState.getRenderThread().eglManager().fenceWait(fence); |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 127 | } else { |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 128 | err = renderState.getRenderThread().vulkanManager().fenceWait( |
| 129 | fence, renderState.getRenderThread().getGrContext()); |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 130 | } |
| 131 | return err; |
| 132 | } |
| 133 | |
Chris Craik | d2dfd8f | 2015-12-16 14:27:20 -0800 | [diff] [blame] | 134 | void DeferredLayerUpdater::apply() { |
sergeyv | 3e9999b | 2017-01-19 15:37:02 -0800 | [diff] [blame] | 135 | if (!mLayer) { |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 136 | mLayer = new Layer(mRenderState, mColorFilter, mAlpha, mMode); |
sergeyv | 3e9999b | 2017-01-19 15:37:02 -0800 | [diff] [blame] | 137 | } |
| 138 | |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 139 | mLayer->setColorFilter(mColorFilter); |
| 140 | mLayer->setAlpha(mAlpha, mMode); |
| 141 | |
John Reck | 25fbb3f | 2014-06-12 13:46:45 -0700 | [diff] [blame] | 142 | if (mSurfaceTexture.get()) { |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 143 | if (!mGLContextAttached) { |
| 144 | mGLContextAttached = true; |
| 145 | mUpdateTexImage = true; |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 146 | ASurfaceTexture_takeConsumerOwnership(mSurfaceTexture.get()); |
Stan Iliev | 85f9096 | 2018-08-31 18:35:06 +0000 | [diff] [blame] | 147 | } |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 148 | if (mUpdateTexImage) { |
| 149 | mUpdateTexImage = false; |
bsears | 9df09ccf | 2021-08-06 15:18:26 +0000 | [diff] [blame] | 150 | float transformMatrix[16]; |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 151 | android_dataspace dataspace; |
Alec Mouri | d0001fe | 2021-11-22 10:09:22 -0800 | [diff] [blame] | 152 | AHdrMetadataType hdrMetadataType; |
| 153 | android_cta861_3_metadata cta861_3; |
| 154 | android_smpte2086_metadata smpte2086; |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 155 | int slot; |
| 156 | bool newContent = false; |
ramindani | bd4971b | 2021-08-06 22:38:45 +0000 | [diff] [blame] | 157 | ARect currentCrop; |
| 158 | uint32_t outTransform; |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 159 | // Note: ASurfaceTexture_dequeueBuffer discards all but the last frame. This |
| 160 | // is necessary if the SurfaceTexture queue is in synchronous mode, and we |
| 161 | // cannot tell which mode it is in. |
| 162 | AHardwareBuffer* hardwareBuffer = ASurfaceTexture_dequeueBuffer( |
Alec Mouri | d0001fe | 2021-11-22 10:09:22 -0800 | [diff] [blame] | 163 | mSurfaceTexture.get(), &slot, &dataspace, &hdrMetadataType, &cta861_3, |
| 164 | &smpte2086, transformMatrix, &outTransform, &newContent, createReleaseFence, |
| 165 | fenceWait, this, ¤tCrop); |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 166 | |
| 167 | if (hardwareBuffer) { |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 168 | mCurrentSlot = slot; |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 169 | sk_sp<SkImage> layerImage = mImageSlots[slot].createIfNeeded( |
| 170 | hardwareBuffer, dataspace, newContent, |
| 171 | mRenderState.getRenderThread().getGrContext()); |
Stan Iliev | d125b44 | 2020-07-16 17:03:27 -0400 | [diff] [blame] | 172 | // unref to match the ref added by ASurfaceTexture_dequeueBuffer. eglCreateImageKHR |
| 173 | // (invoked by createIfNeeded) will add a ref to the AHardwareBuffer. |
| 174 | AHardwareBuffer_release(hardwareBuffer); |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 175 | if (layerImage.get()) { |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 176 | // force filtration if buffer size != layer size |
| 177 | bool forceFilter = |
| 178 | mWidth != layerImage->width() || mHeight != layerImage->height(); |
ramindani | 3952ed6 | 2021-08-12 15:55:12 +0000 | [diff] [blame] | 179 | SkRect currentCropRect = |
| 180 | SkRect::MakeLTRB(currentCrop.left, currentCrop.top, currentCrop.right, |
| 181 | currentCrop.bottom); |
Alec Mouri | d0001fe | 2021-11-22 10:09:22 -0800 | [diff] [blame] | 182 | |
| 183 | float maxLuminanceNits = -1.f; |
| 184 | if (hdrMetadataType & HDR10_SMPTE2086) { |
| 185 | maxLuminanceNits = std::max(smpte2086.maxLuminance, maxLuminanceNits); |
| 186 | } |
| 187 | |
| 188 | if (hdrMetadataType & HDR10_CTA861_3) { |
| 189 | maxLuminanceNits = |
| 190 | std::max(cta861_3.maxContentLightLevel, maxLuminanceNits); |
| 191 | } |
| 192 | updateLayer(forceFilter, layerImage, outTransform, currentCropRect, |
| 193 | maxLuminanceNits); |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 194 | } |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 195 | } |
| 196 | } |
| 197 | |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 198 | if (mTransform) { |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 199 | mLayer->getTransform() = *mTransform; |
Chris Craik | d41c4d8 | 2015-01-05 15:51:13 -0800 | [diff] [blame] | 200 | setTransform(nullptr); |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 201 | } |
| 202 | } |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 203 | } |
| 204 | |
ramindani | 3952ed6 | 2021-08-12 15:55:12 +0000 | [diff] [blame] | 205 | void DeferredLayerUpdater::updateLayer(bool forceFilter, const sk_sp<SkImage>& layerImage, |
Alec Mouri | d0001fe | 2021-11-22 10:09:22 -0800 | [diff] [blame] | 206 | const uint32_t transform, SkRect currentCrop, |
| 207 | float maxLuminanceNits) { |
Greg Daniel | 45ec62b | 2017-01-04 14:27:00 -0500 | [diff] [blame] | 208 | mLayer->setBlend(mBlend); |
| 209 | mLayer->setForceFilter(forceFilter); |
| 210 | mLayer->setSize(mWidth, mHeight); |
ramindani | 3952ed6 | 2021-08-12 15:55:12 +0000 | [diff] [blame] | 211 | mLayer->setCurrentCropRect(currentCrop); |
| 212 | mLayer->setWindowTransform(transform); |
Stan Iliev | 564ca3e | 2018-09-04 22:00:00 +0000 | [diff] [blame] | 213 | mLayer->setImage(layerImage); |
Alec Mouri | d0001fe | 2021-11-22 10:09:22 -0800 | [diff] [blame] | 214 | mLayer->setMaxLuminanceNits(maxLuminanceNits); |
Greg Daniel | 45ec62b | 2017-01-04 14:27:00 -0500 | [diff] [blame] | 215 | } |
| 216 | |
John Reck | 918ad52 | 2014-06-27 14:45:25 -0700 | [diff] [blame] | 217 | void DeferredLayerUpdater::detachSurfaceTexture() { |
| 218 | if (mSurfaceTexture.get()) { |
sergeyv | 00eb43d | 2017-02-13 14:34:15 -0800 | [diff] [blame] | 219 | destroyLayer(); |
Chris Craik | d41c4d8 | 2015-01-05 15:51:13 -0800 | [diff] [blame] | 220 | mSurfaceTexture = nullptr; |
John Reck | 918ad52 | 2014-06-27 14:45:25 -0700 | [diff] [blame] | 221 | } |
| 222 | } |
| 223 | |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 224 | sk_sp<SkImage> DeferredLayerUpdater::ImageSlot::createIfNeeded(AHardwareBuffer* buffer, |
| 225 | android_dataspace dataspace, |
| 226 | bool forceCreate, |
Adlai Holler | f8c434e | 2020-07-27 11:42:45 -0400 | [diff] [blame] | 227 | GrDirectContext* context) { |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 228 | if (!mTextureRelease || !mTextureRelease->getImage().get() || dataspace != mDataspace || |
| 229 | forceCreate || mBuffer != buffer) { |
| 230 | if (buffer != mBuffer) { |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 231 | clear(context); |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 232 | } |
| 233 | |
| 234 | if (!buffer) { |
| 235 | return nullptr; |
| 236 | } |
| 237 | |
| 238 | if (!mTextureRelease) { |
| 239 | mTextureRelease = new AutoBackendTextureRelease(context, buffer); |
| 240 | } else { |
| 241 | mTextureRelease->newBufferContent(context); |
| 242 | } |
| 243 | |
| 244 | mDataspace = dataspace; |
| 245 | mBuffer = buffer; |
| 246 | mTextureRelease->makeImage(buffer, dataspace, context); |
| 247 | } |
| 248 | return mTextureRelease ? mTextureRelease->getImage() : nullptr; |
| 249 | } |
| 250 | |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 251 | void DeferredLayerUpdater::ImageSlot::clear(GrDirectContext* context) { |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 252 | if (mTextureRelease) { |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 253 | if (Properties::getRenderPipelineType() == RenderPipelineType::SkiaVulkan) { |
| 254 | this->releaseQueueOwnership(context); |
| 255 | } |
Stan Iliev | aaa9e83 | 2019-09-17 14:07:23 -0400 | [diff] [blame] | 256 | // The following unref counteracts the initial mUsageCount of 1, set by default initializer. |
| 257 | mTextureRelease->unref(true); |
| 258 | mTextureRelease = nullptr; |
| 259 | } |
| 260 | |
| 261 | mBuffer = nullptr; |
| 262 | } |
| 263 | |
Greg Daniel | 27e1fa2 | 2021-05-26 09:24:15 -0400 | [diff] [blame] | 264 | void DeferredLayerUpdater::ImageSlot::releaseQueueOwnership(GrDirectContext* context) { |
| 265 | LOG_ALWAYS_FATAL_IF(Properties::getRenderPipelineType() != RenderPipelineType::SkiaVulkan); |
| 266 | if (mTextureRelease) { |
| 267 | mTextureRelease->releaseQueueOwnership(context); |
| 268 | } |
| 269 | } |
| 270 | |
John Reck | 04fc583 | 2014-02-05 16:38:25 -0800 | [diff] [blame] | 271 | } /* namespace uirenderer */ |
| 272 | } /* namespace android */ |