blob: 282dfe7abea1844dc9656a9bb188533ae1bbedb8 [file] [log] [blame]
Nolan Scobiefc125ec2024-03-11 20:08:27 -04001/*
2 * Copyright 2024 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
19#undef LOG_TAG
20#define LOG_TAG "RenderEngine"
21
22#include <include/core/SkSurface.h>
23#include <include/gpu/GrDirectContext.h>
24#include <include/gpu/gl/GrGLInterface.h>
Nolan Scobie609e5972024-03-20 14:47:34 -040025#include <include/gpu/graphite/Context.h>
Nolan Scobiefc125ec2024-03-11 20:08:27 -040026#include <include/gpu/vk/GrVkBackendContext.h>
Nolan Scobie609e5972024-03-20 14:47:34 -040027#include "include/gpu/vk/VulkanBackendContext.h"
Nolan Scobiefc125ec2024-03-11 20:08:27 -040028
Nolan Scobieca050282024-03-15 13:27:06 -040029#include "SkiaBackendTexture.h"
30
Nolan Scobiefc125ec2024-03-11 20:08:27 -040031#include <log/log.h>
32
Nolan Scobieca050282024-03-15 13:27:06 -040033#include <memory>
34
Nolan Scobiefc125ec2024-03-11 20:08:27 -040035namespace android::renderengine::skia {
36
37/**
38 * Abstraction over Ganesh and Graphite's underlying context-like objects.
Nolan Scobie2526b2f2024-04-16 15:12:22 -040039 *
40 * On destruction, subclasses will submit any pending work before destroying their internal Skia
41 * context(s). Any unused cached SkiaBackendTextures created from a SkiaGpuContext that are awaiting
42 * cleanup must be deleted before destroying that SkiaGpuContext, and any textures that are released
43 * during ~SkiaGpuContext must be configured to be deleted immediately.
Nolan Scobiefc125ec2024-03-11 20:08:27 -040044 */
45class SkiaGpuContext {
46public:
Nolan Scobie2526b2f2024-04-16 15:12:22 -040047 /**
48 * glInterface must remain valid until after SkiaGpuContext is destroyed.
49 */
Nolan Scobiefc125ec2024-03-11 20:08:27 -040050 static std::unique_ptr<SkiaGpuContext> MakeGL_Ganesh(
51 sk_sp<const GrGLInterface> glInterface,
52 GrContextOptions::PersistentCache& skSLCacheMonitor);
53
Nolan Scobie2526b2f2024-04-16 15:12:22 -040054 /**
55 * grVkBackendContext must remain valid until after SkiaGpuContext is destroyed.
56 */
Nolan Scobiefc125ec2024-03-11 20:08:27 -040057 static std::unique_ptr<SkiaGpuContext> MakeVulkan_Ganesh(
58 const GrVkBackendContext& grVkBackendContext,
59 GrContextOptions::PersistentCache& skSLCacheMonitor);
60
Nolan Scobie609e5972024-03-20 14:47:34 -040061 // TODO: b/293371537 - Need shader / pipeline monitoring support in Graphite.
Nolan Scobie2526b2f2024-04-16 15:12:22 -040062 /**
63 * vulkanBackendContext must remain valid until after SkiaGpuContext is destroyed.
64 */
Nolan Scobie609e5972024-03-20 14:47:34 -040065 static std::unique_ptr<SkiaGpuContext> MakeVulkan_Graphite(
66 const skgpu::VulkanBackendContext& vulkanBackendContext);
67
Nolan Scobiefc125ec2024-03-11 20:08:27 -040068 virtual ~SkiaGpuContext() = default;
69
Nolan Scobiefc125ec2024-03-11 20:08:27 -040070 /**
71 * Only callable on Ganesh-backed instances of SkiaGpuContext, otherwise fatal.
72 */
73 virtual sk_sp<GrDirectContext> grDirectContext() {
74 LOG_ALWAYS_FATAL("grDirectContext() called on a non-Ganesh instance of SkiaGpuContext!");
75 }
76
Nolan Scobie609e5972024-03-20 14:47:34 -040077 /**
78 * Only callable on Graphite-backed instances of SkiaGpuContext, otherwise fatal.
79 */
80 virtual std::shared_ptr<skgpu::graphite::Context> graphiteContext() {
81 LOG_ALWAYS_FATAL("graphiteContext() called on a non-Graphite instance of SkiaGpuContext!");
82 }
83
84 /**
85 * Only callable on Graphite-backed instances of SkiaGpuContext, otherwise fatal.
86 */
87 virtual std::shared_ptr<skgpu::graphite::Recorder> graphiteRecorder() {
88 LOG_ALWAYS_FATAL("graphiteRecorder() called on a non-Graphite instance of SkiaGpuContext!");
89 }
90
Nolan Scobieca050282024-03-15 13:27:06 -040091 virtual std::unique_ptr<SkiaBackendTexture> makeBackendTexture(AHardwareBuffer* buffer,
92 bool isOutputBuffer) = 0;
93
Nolan Scobiefc125ec2024-03-11 20:08:27 -040094 /**
95 * Notes:
96 * - The surface doesn't count against Skia's caching budgets.
97 * - Protected status is set to match the implementation's underlying context.
98 * - The origin of the surface in texture space corresponds to the top-left content pixel.
99 * - AA is always enabled.
100 */
101 virtual sk_sp<SkSurface> createRenderTarget(SkImageInfo imageInfo) = 0;
102
Nolan Scobie17ffe902024-03-25 11:07:30 -0400103 virtual bool isAbandonedOrDeviceLost() = 0;
Nolan Scobiefc125ec2024-03-11 20:08:27 -0400104 virtual size_t getMaxRenderTargetSize() const = 0;
105 virtual size_t getMaxTextureSize() const = 0;
106 virtual void setResourceCacheLimit(size_t maxResourceBytes) = 0;
107
Nolan Scobiefc125ec2024-03-11 20:08:27 -0400108 virtual void purgeUnlockedScratchResources() = 0;
109 virtual void resetContextIfApplicable() = 0; // No-op outside of GL (&& Ganesh at this point.)
110
111 virtual void dumpMemoryStatistics(SkTraceMemoryDump* traceMemoryDump) const = 0;
112};
113
114} // namespace android::renderengine::skia