Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a2ac4d0f authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Automerger Merge Worker
Browse files

Merge "Skip fp16 buffers for GPUs that don't support fp16 textures." into sc-dev am: 06c3b638

Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/native/+/15177201

Change-Id: Id4a9b9a7731e36cf68a7567d33fe1a83d2c97310
parents c681aad9 06c3b638
Loading
Loading
Loading
Loading
+7 −1
Original line number Diff line number Diff line
@@ -313,7 +313,13 @@ void Cache::primeShaderCache(SkiaRenderEngine* renderengine) {

        // The majority of shaders are related to sampling images.
        // These need to be generated with various source textures
        for (auto texture : {srcTexture, externalTexture, f16ExternalTexture}) {
        // The F16 texture may not be usable on all devices, so check first that it was created with
        // the requested usage bit.
        auto textures = {srcTexture, externalTexture};
        auto texturesWithF16 = {srcTexture, externalTexture, f16ExternalTexture};
        bool canUsef16 = f16ExternalBuffer->getUsage() & GRALLOC_USAGE_HW_TEXTURE;

        for (auto texture : canUsef16 ? texturesWithF16 : textures) {
            drawImageLayers(renderengine, display, dstTexture, texture);
            // Draw layers for b/185569240.
            drawClippedLayers(renderengine, display, dstTexture, texture);