blob: 574b4effdbb60f4282d4ad9c93c4728f66678afc [file] [log] [blame]
bsalomon@google.com27847de2011-02-22 20:59:41 +00001/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00002 * Copyright 2011 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
bsalomon@google.com27847de2011-02-22 20:59:41 +00006 */
7
Brian Salomon9241a6d2019-10-03 13:26:54 -04008#include "include/gpu/GrContext.h"
9
Robert Phillips4d5594d2020-02-21 14:24:40 -050010#include "include/core/SkDeferredDisplayList.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050011#include "include/core/SkTraceMemoryDump.h"
12#include "include/gpu/GrBackendSemaphore.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050013#include "include/private/SkImageInfoPriv.h"
Brian Salomon85c3d682019-11-04 15:04:54 -050014#include "src/core/SkMipMap.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050015#include "src/core/SkTaskGroup.h"
Brian Salomon9241a6d2019-10-03 13:26:54 -040016#include "src/gpu/GrClientMappedBufferManager.h"
Greg Daniel7fd7a8a2019-10-10 16:10:31 -040017#include "src/gpu/GrContextPriv.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050018#include "src/gpu/GrDrawingManager.h"
19#include "src/gpu/GrGpu.h"
20#include "src/gpu/GrMemoryPool.h"
21#include "src/gpu/GrPathRendererChain.h"
22#include "src/gpu/GrProxyProvider.h"
Greg Danielf91aeb22019-06-18 09:58:02 -040023#include "src/gpu/GrRenderTargetProxy.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050024#include "src/gpu/GrResourceCache.h"
25#include "src/gpu/GrResourceProvider.h"
26#include "src/gpu/GrSemaphore.h"
Brian Osman5e7fbfd2019-05-03 13:13:35 -040027#include "src/gpu/GrShaderUtils.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050028#include "src/gpu/GrSoftwarePathRenderer.h"
29#include "src/gpu/GrTracing.h"
30#include "src/gpu/SkGr.h"
31#include "src/gpu/ccpr/GrCoverageCountingPathRenderer.h"
32#include "src/gpu/effects/GrSkSLFP.h"
Robert Phillips41bd97d2020-04-07 14:19:37 -040033#include "src/gpu/text/GrStrikeCache.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050034#include "src/gpu/text/GrTextBlobCache.h"
35#include "src/gpu/text/GrTextContext.h"
Greg Daniel7fd7a8a2019-10-10 16:10:31 -040036#include "src/image/SkImage_GpuBase.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050037#include "src/image/SkSurface_Gpu.h"
Mike Klein0ec1c572018-12-04 11:52:51 -050038#include <atomic>
Greg Danielb76a72a2017-07-13 15:07:54 -040039
Robert Phillipse78b7252017-04-06 07:59:41 -040040#define ASSERT_OWNED_PROXY(P) \
Brian Salomonfd98c2c2018-07-31 17:25:29 -040041 SkASSERT(!(P) || !((P)->peekTexture()) || (P)->peekTexture()->getContext() == this)
Robert Phillips7ee385e2017-03-30 08:02:11 -040042
tfarina@chromium.orgf6de4752013-08-17 00:02:59 +000043#define ASSERT_OWNED_RESOURCE(R) SkASSERT(!(R) || (R)->getContext() == this)
Adlai Holler33dbd652020-06-01 12:35:42 -040044#define ASSERT_SINGLE_OWNER GR_ASSERT_SINGLE_OWNER(this->singleOwner())
Robert Phillipsa9162df2019-02-11 14:12:03 -050045#define RETURN_IF_ABANDONED if (this->abandoned()) { return; }
46#define RETURN_FALSE_IF_ABANDONED if (this->abandoned()) { return false; }
47#define RETURN_NULL_IF_ABANDONED if (this->abandoned()) { return nullptr; }
bsalomon@google.combc4b6542011-11-19 13:56:11 +000048
robertphillipsea461502015-05-26 11:38:03 -070049////////////////////////////////////////////////////////////////////////////////
50
Adlai Hollere219d1c2020-06-02 11:23:16 -040051GrContext::GrContext(sk_sp<GrContextThreadSafeProxy> proxy) : INHERITED(std::move(proxy)) {
halcanary96fcdcc2015-08-27 07:41:13 -070052 fResourceCache = nullptr;
53 fResourceProvider = nullptr;
bsalomon@google.com6e4e6502013-02-25 20:12:45 +000054}
55
Robert Phillips292a6b22019-02-14 14:49:02 -050056GrContext::~GrContext() {
57 ASSERT_SINGLE_OWNER
58
Robert Phillips6a6de562019-02-15 15:19:15 -050059 if (this->drawingManager()) {
60 this->drawingManager()->cleanup();
Robert Phillips292a6b22019-02-14 14:49:02 -050061 }
62 delete fResourceProvider;
63 delete fResourceCache;
Robert Phillips292a6b22019-02-14 14:49:02 -050064}
65
Adlai Hollere219d1c2020-06-02 11:23:16 -040066bool GrContext::init() {
Greg Danielb76a72a2017-07-13 15:07:54 -040067 ASSERT_SINGLE_OWNER
Robert Phillipsa41c6852019-02-07 10:44:10 -050068 SkASSERT(this->proxyProvider());
Robert Phillips88260b52018-01-19 12:56:09 -050069
Adlai Hollere219d1c2020-06-02 11:23:16 -040070 if (!INHERITED::init()) {
Robert Phillipsbb606772019-02-04 17:50:57 -050071 return false;
72 }
73
Robert Phillips2184fb72019-02-21 16:11:41 -050074 SkASSERT(this->getTextBlobCache());
Robert Phillipsbb606772019-02-04 17:50:57 -050075
Robert Phillips88260b52018-01-19 12:56:09 -050076 if (fGpu) {
Robert Phillips4d932d12020-04-09 08:58:52 -040077 fStrikeCache.reset(new GrStrikeCache{});
Robert Phillipsa41c6852019-02-07 10:44:10 -050078 fResourceCache = new GrResourceCache(this->caps(), this->singleOwner(), this->contextID());
Robert Phillips12c46292019-04-23 07:36:17 -040079 fResourceProvider = new GrResourceProvider(fGpu.get(), fResourceCache, this->singleOwner());
Mike Kleinf46d5ca2019-12-11 10:45:01 -050080 fMappedBufferManager = std::make_unique<GrClientMappedBufferManager>(this->contextID());
Robert Phillips88260b52018-01-19 12:56:09 -050081 }
82
Robert Phillips88260b52018-01-19 12:56:09 -050083 if (fResourceCache) {
Robert Phillipsa41c6852019-02-07 10:44:10 -050084 fResourceCache->setProxyProvider(this->proxyProvider());
Robert Phillips88260b52018-01-19 12:56:09 -050085 }
Robert Phillips1afd4cd2018-01-08 13:40:32 -050086
bsalomon@google.com6e4e6502013-02-25 20:12:45 +000087 fDidTestPMConversions = false;
88
Robert Phillipsfde6fa02018-03-02 08:53:14 -050089 // DDL TODO: we need to think through how the task group & persistent cache
90 // get passed on to/shared between all the DDLRecorders created with this context.
Robert Phillipsc1541ae2019-02-04 12:05:37 -050091 if (this->options().fExecutor) {
Mike Kleinf46d5ca2019-12-11 10:45:01 -050092 fTaskGroup = std::make_unique<SkTaskGroup>(*this->options().fExecutor);
Brian Osman51279982017-08-23 10:12:00 -040093 }
94
Robert Phillipsc1541ae2019-02-04 12:05:37 -050095 fPersistentCache = this->options().fPersistentCache;
Brian Osman5e7fbfd2019-05-03 13:13:35 -040096 fShaderErrorHandler = this->options().fShaderErrorHandler;
97 if (!fShaderErrorHandler) {
98 fShaderErrorHandler = GrShaderUtils::DefaultShaderErrorHandler();
99 }
Ethan Nicholasd1b2eec2017-11-01 15:45:43 -0400100
Brian Salomon91a3e522017-06-23 10:58:19 -0400101 return true;
bsalomon@google.comc0af3172012-06-15 14:10:09 +0000102}
103
Robert Phillips4217ea72019-01-30 13:08:28 -0500104sk_sp<GrContextThreadSafeProxy> GrContext::threadSafeProxy() {
Adlai Hollere219d1c2020-06-02 11:23:16 -0400105 return INHERITED::threadSafeProxy();
Robert Phillips4217ea72019-01-30 13:08:28 -0500106}
107
Brian Salomonc7fe0f72018-05-11 10:14:21 -0400108//////////////////////////////////////////////////////////////////////////////
109
bsalomon2354f842014-07-28 13:48:36 -0700110void GrContext::abandonContext() {
Greg Daniel6e35a002020-04-01 13:29:59 -0400111 if (INHERITED::abandoned()) {
Robert Phillipsa9162df2019-02-11 14:12:03 -0500112 return;
113 }
joshualitt1de610a2016-01-06 08:26:09 -0800114
Robert Phillipsa9162df2019-02-11 14:12:03 -0500115 INHERITED::abandonContext();
116
Robert Phillips4d932d12020-04-09 08:58:52 -0400117 fStrikeCache->freeAll();
118
Brian Salomon9241a6d2019-10-03 13:26:54 -0400119 fMappedBufferManager->abandon();
120
bsalomond309e7a2015-04-30 14:18:54 -0700121 fResourceProvider->abandon();
robertphillips0dfa62c2015-11-16 06:23:31 -0800122
Robert Phillipsa9162df2019-02-11 14:12:03 -0500123 // Need to cleanup the drawing manager first so all the render targets
robertphillips0dfa62c2015-11-16 06:23:31 -0800124 // will be released/forgotten before they too are abandoned.
Robert Phillips6a6de562019-02-15 15:19:15 -0500125 this->drawingManager()->cleanup();
robertphillips0dfa62c2015-11-16 06:23:31 -0800126
bsalomon@google.com205d4602011-04-25 12:43:45 +0000127 // abandon first to so destructors
128 // don't try to free the resources in the API.
bsalomon0ea80f42015-02-11 10:49:59 -0800129 fResourceCache->abandonAll();
bsalomonc8dc1f72014-08-21 13:02:13 -0700130
bsalomon6e2aad42016-04-01 11:54:31 -0700131 fGpu->disconnect(GrGpu::DisconnectType::kAbandon);
Brian Salomon9241a6d2019-10-03 13:26:54 -0400132
133 fMappedBufferManager.reset();
Khushalc421ca12018-06-26 14:38:34 -0700134}
135
bsalomon6e2aad42016-04-01 11:54:31 -0700136void GrContext::releaseResourcesAndAbandonContext() {
Greg Daniel6e35a002020-04-01 13:29:59 -0400137 if (INHERITED::abandoned()) {
Brian Salomon614c1a82018-12-19 15:42:06 -0500138 return;
139 }
Robert Phillipsa9162df2019-02-11 14:12:03 -0500140
141 INHERITED::abandonContext();
142
Brian Salomon9241a6d2019-10-03 13:26:54 -0400143 fMappedBufferManager.reset();
144
bsalomon6e2aad42016-04-01 11:54:31 -0700145 fResourceProvider->abandon();
146
Robert Phillipsa9162df2019-02-11 14:12:03 -0500147 // Need to cleanup the drawing manager first so all the render targets
bsalomon6e2aad42016-04-01 11:54:31 -0700148 // will be released/forgotten before they too are abandoned.
Robert Phillips6a6de562019-02-15 15:19:15 -0500149 this->drawingManager()->cleanup();
bsalomon6e2aad42016-04-01 11:54:31 -0700150
151 // Release all resources in the backend 3D API.
152 fResourceCache->releaseAll();
153
154 fGpu->disconnect(GrGpu::DisconnectType::kCleanup);
bsalomon@google.com8fe72472011-03-30 21:26:44 +0000155}
156
Greg Daniel6e35a002020-04-01 13:29:59 -0400157bool GrContext::abandoned() {
158 if (INHERITED::abandoned()) {
159 return true;
160 }
161
162 if (fGpu && fGpu->isDeviceLost()) {
163 this->abandonContext();
164 return true;
165 }
166 return false;
167}
168
Brian Salomon1f05d452019-02-08 12:33:08 -0500169void GrContext::resetGLTextureBindings() {
170 if (this->abandoned() || this->backend() != GrBackendApi::kOpenGL) {
171 return;
172 }
173 fGpu->resetTextureBindings();
174}
175
bsalomon@google.com0a208a12013-06-28 18:57:35 +0000176void GrContext::resetContext(uint32_t state) {
joshualitt1de610a2016-01-06 08:26:09 -0800177 ASSERT_SINGLE_OWNER
bsalomon@google.com0a208a12013-06-28 18:57:35 +0000178 fGpu->markContextDirty(state);
bsalomon@google.com8fe72472011-03-30 21:26:44 +0000179}
180
181void GrContext::freeGpuResources() {
joshualitt1de610a2016-01-06 08:26:09 -0800182 ASSERT_SINGLE_OWNER
183
Robert Phillips2184fb72019-02-21 16:11:41 -0500184 // TODO: the glyph cache doesn't hold any GpuResources so this call should not be needed here.
185 // Some slack in the GrTextBlob's implementation requires it though. That could be fixed.
Robert Phillips4d932d12020-04-09 08:58:52 -0400186 fStrikeCache->freeAll();
robertphillips68737822015-10-29 12:12:21 -0700187
Robert Phillips6a6de562019-02-15 15:19:15 -0500188 this->drawingManager()->freeGpuResources();
bsalomon3033b9f2015-04-13 11:09:56 -0700189
190 fResourceCache->purgeAllUnlocked();
bsalomon@google.com27847de2011-02-22 20:59:41 +0000191}
192
Robert Phillips6eba0632018-03-28 12:25:42 -0400193void GrContext::purgeUnlockedResources(bool scratchResourcesOnly) {
194 ASSERT_SINGLE_OWNER
Robert Phillipsddc21482019-10-16 14:30:09 -0400195
196 if (this->abandoned()) {
197 return;
198 }
199
Robert Phillips6eba0632018-03-28 12:25:42 -0400200 fResourceCache->purgeUnlockedResources(scratchResourcesOnly);
201 fResourceCache->purgeAsNeeded();
Robert Phillips2184fb72019-02-21 16:11:41 -0500202
203 // The textBlob Cache doesn't actually hold any GPU resource but this is a convenient
204 // place to purge stale blobs
205 this->getTextBlobCache()->purgeStaleBlobs();
Robert Phillips6eba0632018-03-28 12:25:42 -0400206}
207
Jim Van Verth76d917c2017-12-13 09:26:37 -0500208void GrContext::performDeferredCleanup(std::chrono::milliseconds msNotUsed) {
Yuqian Li40aa85f2019-07-02 13:45:00 -0700209 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
210
Brian Salomon5e150852017-03-22 14:53:13 -0400211 ASSERT_SINGLE_OWNER
Chris Dalton6c3879d2018-11-01 11:13:19 -0600212
Brian Salomon9241a6d2019-10-03 13:26:54 -0400213 if (this->abandoned()) {
214 return;
215 }
216
217 fMappedBufferManager->process();
Chris Dalton6c3879d2018-11-01 11:13:19 -0600218 auto purgeTime = GrStdSteadyClock::now() - msNotUsed;
219
Jim Van Verth76d917c2017-12-13 09:26:37 -0500220 fResourceCache->purgeAsNeeded();
Chris Dalton6c3879d2018-11-01 11:13:19 -0600221 fResourceCache->purgeResourcesNotUsedSince(purgeTime);
222
Robert Phillips6a6de562019-02-15 15:19:15 -0500223 if (auto ccpr = this->drawingManager()->getCoverageCountingPathRenderer()) {
Robert Phillipsa41c6852019-02-07 10:44:10 -0500224 ccpr->purgeCacheEntriesOlderThan(this->proxyProvider(), purgeTime);
Chris Dalton6c3879d2018-11-01 11:13:19 -0600225 }
Jim Van Verth76d917c2017-12-13 09:26:37 -0500226
Robert Phillips2184fb72019-02-21 16:11:41 -0500227 // The textBlob Cache doesn't actually hold any GPU resource but this is a convenient
228 // place to purge stale blobs
229 this->getTextBlobCache()->purgeStaleBlobs();
Brian Salomon5e150852017-03-22 14:53:13 -0400230}
231
Derek Sollenberger5480a182017-05-25 16:43:59 -0400232void GrContext::purgeUnlockedResources(size_t bytesToPurge, bool preferScratchResources) {
233 ASSERT_SINGLE_OWNER
Robert Phillipsddc21482019-10-16 14:30:09 -0400234
235 if (this->abandoned()) {
236 return;
237 }
238
Derek Sollenberger5480a182017-05-25 16:43:59 -0400239 fResourceCache->purgeUnlockedResources(bytesToPurge, preferScratchResources);
240}
241
commit-bot@chromium.org95c20032014-05-09 14:29:32 +0000242void GrContext::getResourceCacheUsage(int* resourceCount, size_t* resourceBytes) const {
joshualitt1de610a2016-01-06 08:26:09 -0800243 ASSERT_SINGLE_OWNER
244
bsalomon71cb0c22014-11-14 12:10:14 -0800245 if (resourceCount) {
bsalomon0ea80f42015-02-11 10:49:59 -0800246 *resourceCount = fResourceCache->getBudgetedResourceCount();
bsalomon71cb0c22014-11-14 12:10:14 -0800247 }
248 if (resourceBytes) {
bsalomon0ea80f42015-02-11 10:49:59 -0800249 *resourceBytes = fResourceCache->getBudgetedResourceBytes();
bsalomon71cb0c22014-11-14 12:10:14 -0800250 }
commit-bot@chromium.orgd8a57af2014-03-19 21:19:16 +0000251}
252
Derek Sollenbergeree479142017-05-24 11:41:33 -0400253size_t GrContext::getResourceCachePurgeableBytes() const {
254 ASSERT_SINGLE_OWNER
255 return fResourceCache->getPurgeableBytes();
256}
257
Greg Daniel8b666172019-10-09 12:38:22 -0400258size_t GrContext::ComputeImageSize(sk_sp<SkImage> image, GrMipMapped mipMapped, bool useNextPow2) {
259 if (!image->isTextureBacked()) {
260 return 0;
261 }
Greg Daniel7fd7a8a2019-10-10 16:10:31 -0400262 SkImage_GpuBase* gpuImage = static_cast<SkImage_GpuBase*>(as_IB(image.get()));
263 GrTextureProxy* proxy = gpuImage->peekProxy();
264 if (!proxy) {
265 return 0;
266 }
267
268 const GrCaps& caps = *gpuImage->context()->priv().caps();
Greg Daniel8b666172019-10-09 12:38:22 -0400269 int colorSamplesPerPixel = 1;
Brian Salomon9f2b86c2019-10-22 10:37:46 -0400270 return GrSurface::ComputeSize(caps, proxy->backendFormat(), image->dimensions(),
Greg Daniel7fd7a8a2019-10-10 16:10:31 -0400271 colorSamplesPerPixel, mipMapped, useNextPow2);
Greg Daniel8b666172019-10-09 12:38:22 -0400272}
273
bsalomon@google.comfea37b52011-04-25 15:51:06 +0000274////////////////////////////////////////////////////////////////////////////////
275
Robert Phillipsbb606772019-02-04 17:50:57 -0500276int GrContext::maxTextureSize() const { return this->caps()->maxTextureSize(); }
Brian Salomonf932a632018-04-05 12:46:09 -0400277
Robert Phillipsbb606772019-02-04 17:50:57 -0500278int GrContext::maxRenderTargetSize() const { return this->caps()->maxRenderTargetSize(); }
Brian Salomonf932a632018-04-05 12:46:09 -0400279
Brian Salomonbdecacf2018-02-02 20:32:49 -0500280bool GrContext::colorTypeSupportedAsImage(SkColorType colorType) const {
Greg Daniel7bfc9132019-08-14 14:23:53 -0400281 GrBackendFormat format =
282 this->caps()->getDefaultBackendFormat(SkColorTypeToGrColorType(colorType),
283 GrRenderable::kNo);
284 return format.isValid();
Brian Salomonbdecacf2018-02-02 20:32:49 -0500285}
286
287int GrContext::maxSurfaceSampleCountForColorType(SkColorType colorType) const {
Greg Danieleadfac92019-08-02 09:03:53 -0400288 GrBackendFormat format =
289 this->caps()->getDefaultBackendFormat(SkColorTypeToGrColorType(colorType),
290 GrRenderable::kYes);
291 return this->caps()->maxRenderTargetSampleCount(format);
Brian Salomonbdecacf2018-02-02 20:32:49 -0500292}
293
294////////////////////////////////////////////////////////////////////////////////
295
Greg Daniel06be0792019-04-22 15:53:23 -0400296bool GrContext::wait(int numSemaphores, const GrBackendSemaphore waitSemaphores[]) {
Brian Salomon9ff5acb2019-05-08 09:04:47 -0400297 if (!fGpu || fGpu->caps()->semaphoreSupport()) {
Greg Daniel06be0792019-04-22 15:53:23 -0400298 return false;
299 }
300 for (int i = 0; i < numSemaphores; ++i) {
Greg Daniel301015c2019-11-18 14:06:46 -0500301 std::unique_ptr<GrSemaphore> sema = fResourceProvider->wrapBackendSemaphore(
Greg Daniel06be0792019-04-22 15:53:23 -0400302 waitSemaphores[i], GrResourceProvider::SemaphoreWrapType::kWillWait,
303 kAdopt_GrWrapOwnership);
Greg Daniel301015c2019-11-18 14:06:46 -0500304 fGpu->waitSemaphore(sema.get());
Greg Daniel06be0792019-04-22 15:53:23 -0400305 }
306 return true;
307}
308
309////////////////////////////////////////////////////////////////////////////////
310
Greg Daniel797efca2019-05-09 14:04:20 -0400311GrSemaphoresSubmitted GrContext::flush(const GrFlushInfo& info,
312 const GrPrepareForExternalIORequests& externalRequests) {
Greg Daniel51316782017-08-02 15:10:09 +0000313 ASSERT_SINGLE_OWNER
Robert Phillipsa9162df2019-02-11 14:12:03 -0500314 if (this->abandoned()) {
Greg Daniel55822f12020-05-26 11:26:45 -0400315 if (info.fFinishedProc) {
316 info.fFinishedProc(info.fFinishedContext);
317 }
318 if (info.fSubmittedProc) {
319 info.fSubmittedProc(info.fSubmittedContext, false);
320 }
Robert Phillipsa9162df2019-02-11 14:12:03 -0500321 return GrSemaphoresSubmitted::kNo;
322 }
Greg Daniel51316782017-08-02 15:10:09 +0000323
Greg Daniel04283f32020-05-20 13:16:00 -0400324 bool flushed = this->drawingManager()->flush(
325 nullptr, 0, SkSurface::BackendSurfaceAccess::kNoAccess, info, externalRequests);
Greg Danielfe159622020-04-10 17:43:51 +0000326
Greg Daniel04283f32020-05-20 13:16:00 -0400327 if (!flushed || (!this->priv().caps()->semaphoreSupport() && info.fNumSemaphores)) {
Greg Danielfe159622020-04-10 17:43:51 +0000328 return GrSemaphoresSubmitted::kNo;
329 }
330 return GrSemaphoresSubmitted::kYes;
Greg Daniel51316782017-08-02 15:10:09 +0000331}
332
Greg Daniel04283f32020-05-20 13:16:00 -0400333bool GrContext::submit(bool syncCpu) {
334 ASSERT_SINGLE_OWNER
335 if (this->abandoned()) {
336 return false;
337 }
338
339 if (!fGpu) {
340 return false;
341 }
342
343 return fGpu->submitToGpu(syncCpu);
Greg Danielda50cb82020-05-13 14:07:40 -0400344}
345
Greg Daniela870b462019-01-08 15:49:46 -0500346////////////////////////////////////////////////////////////////////////////////
347
Brian Salomonb0d8b762019-05-06 16:58:22 -0400348void GrContext::checkAsyncWorkCompletion() {
349 if (fGpu) {
350 fGpu->checkFinishProcs();
351 }
352}
353
354////////////////////////////////////////////////////////////////////////////////
355
Greg Daniela870b462019-01-08 15:49:46 -0500356void GrContext::storeVkPipelineCacheData() {
357 if (fGpu) {
358 fGpu->storeVkPipelineCacheData();
359 }
360}
361
362////////////////////////////////////////////////////////////////////////////////
363
Khushal3e7548c2018-05-23 15:45:01 -0700364bool GrContext::supportsDistanceFieldText() const {
Robert Phillipsbb606772019-02-04 17:50:57 -0500365 return this->caps()->shaderCaps()->supportsDistanceFieldText();
Khushal3e7548c2018-05-23 15:45:01 -0700366}
367
bsalomon37f9a262015-02-02 13:00:10 -0800368//////////////////////////////////////////////////////////////////////////////
369
Robert Phillips8d1e67e2017-12-04 13:48:14 -0500370void GrContext::getResourceCacheLimits(int* maxResources, size_t* maxResourceBytes) const {
joshualitt1de610a2016-01-06 08:26:09 -0800371 ASSERT_SINGLE_OWNER
Robert Phillips8d1e67e2017-12-04 13:48:14 -0500372 if (maxResources) {
Robert Phillipscf39f372019-09-03 10:29:20 -0400373 *maxResources = -1;
bsalomon37f9a262015-02-02 13:00:10 -0800374 }
Robert Phillips8d1e67e2017-12-04 13:48:14 -0500375 if (maxResourceBytes) {
Robert Phillipscf39f372019-09-03 10:29:20 -0400376 *maxResourceBytes = this->getResourceCacheLimit();
bsalomon37f9a262015-02-02 13:00:10 -0800377 }
378}
379
Robert Phillipscf39f372019-09-03 10:29:20 -0400380size_t GrContext::getResourceCacheLimit() const {
joshualitt1de610a2016-01-06 08:26:09 -0800381 ASSERT_SINGLE_OWNER
Robert Phillipscf39f372019-09-03 10:29:20 -0400382 return fResourceCache->getMaxResourceBytes();
383}
384
385void GrContext::setResourceCacheLimits(int unused, size_t maxResourceBytes) {
386 ASSERT_SINGLE_OWNER
387 this->setResourceCacheLimit(maxResourceBytes);
388}
389
390void GrContext::setResourceCacheLimit(size_t maxResourceBytes) {
391 ASSERT_SINGLE_OWNER
392 fResourceCache->setLimit(maxResourceBytes);
bsalomon37f9a262015-02-02 13:00:10 -0800393}
394
ericrk0a5fa482015-09-15 14:16:10 -0700395//////////////////////////////////////////////////////////////////////////////
ericrk0a5fa482015-09-15 14:16:10 -0700396void GrContext::dumpMemoryStatistics(SkTraceMemoryDump* traceMemoryDump) const {
joshualitt1de610a2016-01-06 08:26:09 -0800397 ASSERT_SINGLE_OWNER
ericrk0a5fa482015-09-15 14:16:10 -0700398 fResourceCache->dumpMemoryStatistics(traceMemoryDump);
Khushal71652e22018-10-29 13:05:36 -0700399 traceMemoryDump->dumpNumericValue("skia/gr_text_blob_cache", "size", "bytes",
Robert Phillips2184fb72019-02-21 16:11:41 -0500400 this->getTextBlobCache()->usedBytes());
ericrk0a5fa482015-09-15 14:16:10 -0700401}
Brian Osman71a18892017-08-10 10:23:25 -0400402
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400403//////////////////////////////////////////////////////////////////////////////
404GrBackendTexture GrContext::createBackendTexture(int width, int height,
Greg Danielf91aeb22019-06-18 09:58:02 -0400405 const GrBackendFormat& backendFormat,
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400406 GrMipMapped mipMapped,
Emircan Uysaler23ca4e72019-06-24 10:53:09 -0400407 GrRenderable renderable,
408 GrProtected isProtected) {
Brian Salomonc42eb662019-06-24 17:13:00 -0400409 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400410 if (!this->asDirectContext()) {
411 return GrBackendTexture();
412 }
413
414 if (this->abandoned()) {
415 return GrBackendTexture();
416 }
417
Robert Phillips4277f012020-01-21 14:28:34 -0500418 return fGpu->createBackendTexture({width, height}, backendFormat, renderable,
Greg Daniel16032b32020-05-06 15:31:10 -0400419 mipMapped, isProtected);
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400420}
421
422GrBackendTexture GrContext::createBackendTexture(int width, int height,
Robert Phillipsd5e80ca2019-07-29 14:11:35 -0400423 SkColorType skColorType,
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400424 GrMipMapped mipMapped,
Emircan Uysaler23ca4e72019-06-24 10:53:09 -0400425 GrRenderable renderable,
426 GrProtected isProtected) {
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400427 if (!this->asDirectContext()) {
428 return GrBackendTexture();
429 }
430
431 if (this->abandoned()) {
432 return GrBackendTexture();
433 }
434
Robert Phillipsd5e80ca2019-07-29 14:11:35 -0400435 const GrBackendFormat format = this->defaultBackendFormat(skColorType, renderable);
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400436
Emircan Uysaler23ca4e72019-06-24 10:53:09 -0400437 return this->createBackendTexture(width, height, format, mipMapped, renderable, isProtected);
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400438}
439
Robert Phillips02dc0302019-07-02 17:58:27 -0400440GrBackendTexture GrContext::createBackendTexture(const SkSurfaceCharacterization& c) {
Robert Phillips02dc0302019-07-02 17:58:27 -0400441 if (!this->asDirectContext() || !c.isValid()) {
442 return GrBackendTexture();
443 }
444
445 if (this->abandoned()) {
446 return GrBackendTexture();
447 }
448
449 if (c.usesGLFBO0()) {
450 // If we are making the surface we will never use FBO0.
451 return GrBackendTexture();
452 }
453
454 if (c.vulkanSecondaryCBCompatible()) {
455 return {};
456 }
457
Robert Phillipsd5e80ca2019-07-29 14:11:35 -0400458 const GrBackendFormat format = this->defaultBackendFormat(c.colorType(), GrRenderable::kYes);
Robert Phillips02dc0302019-07-02 17:58:27 -0400459 if (!format.isValid()) {
460 return GrBackendTexture();
461 }
462
Robert Phillips02dc0302019-07-02 17:58:27 -0400463 GrBackendTexture result = this->createBackendTexture(c.width(), c.height(), format,
464 GrMipMapped(c.isMipMapped()),
465 GrRenderable::kYes,
Robert Phillips3cd54322019-07-10 09:28:59 -0400466 c.isProtected());
Robert Phillips02dc0302019-07-02 17:58:27 -0400467 SkASSERT(c.isCompatible(result));
468 return result;
469}
470
471GrBackendTexture GrContext::createBackendTexture(const SkSurfaceCharacterization& c,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400472 const SkColor4f& color,
473 GrGpuFinishedProc finishedProc,
474 GrGpuFinishedContext finishedContext) {
Robert Phillips02dc0302019-07-02 17:58:27 -0400475 if (!this->asDirectContext() || !c.isValid()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400476 finishedProc(finishedContext);
477 return {};
Robert Phillips02dc0302019-07-02 17:58:27 -0400478 }
479
480 if (this->abandoned()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400481 finishedProc(finishedContext);
482 return {};
Robert Phillips02dc0302019-07-02 17:58:27 -0400483 }
484
485 if (c.usesGLFBO0()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400486 finishedProc(finishedContext);
Robert Phillips02dc0302019-07-02 17:58:27 -0400487 // If we are making the surface we will never use FBO0.
Greg Danielc1ad77c2020-05-06 11:40:03 -0400488 return {};
Robert Phillips02dc0302019-07-02 17:58:27 -0400489 }
490
491 if (c.vulkanSecondaryCBCompatible()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400492 finishedProc(finishedContext);
Robert Phillips02dc0302019-07-02 17:58:27 -0400493 return {};
494 }
495
Robert Phillipsd5e80ca2019-07-29 14:11:35 -0400496 const GrBackendFormat format = this->defaultBackendFormat(c.colorType(), GrRenderable::kYes);
Robert Phillips02dc0302019-07-02 17:58:27 -0400497 if (!format.isValid()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400498 finishedProc(finishedContext);
499 return {};
Robert Phillips02dc0302019-07-02 17:58:27 -0400500 }
501
Robert Phillips02dc0302019-07-02 17:58:27 -0400502 GrBackendTexture result = this->createBackendTexture(c.width(), c.height(), format, color,
503 GrMipMapped(c.isMipMapped()),
504 GrRenderable::kYes,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400505 c.isProtected(), finishedProc,
506 finishedContext);
Robert Phillips02dc0302019-07-02 17:58:27 -0400507 SkASSERT(c.isCompatible(result));
508 return result;
509}
510
Greg Daniel16032b32020-05-06 15:31:10 -0400511static GrBackendTexture create_and_update_backend_texture(GrContext* context,
512 SkISize dimensions,
513 const GrBackendFormat& backendFormat,
514 GrMipMapped mipMapped,
515 GrRenderable renderable,
516 GrProtected isProtected,
517 GrGpuFinishedProc finishedProc,
518 GrGpuFinishedContext finishedContext,
519 const GrGpu::BackendTextureData* data) {
520 GrGpu* gpu = context->priv().getGpu();
521
522 GrBackendTexture beTex = gpu->createBackendTexture(dimensions, backendFormat, renderable,
523 mipMapped, isProtected);
524 if (!beTex.isValid()) {
525 return {};
526 }
527
528 if (!context->priv().getGpu()->updateBackendTexture(beTex, finishedProc, finishedContext,
529 data)) {
530 context->deleteBackendTexture(beTex);
531 return {};
532 }
533 return beTex;
534}
535
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400536GrBackendTexture GrContext::createBackendTexture(int width, int height,
Greg Danielf91aeb22019-06-18 09:58:02 -0400537 const GrBackendFormat& backendFormat,
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400538 const SkColor4f& color,
539 GrMipMapped mipMapped,
Robert Phillipsda2e67a2019-07-01 15:04:06 -0400540 GrRenderable renderable,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400541 GrProtected isProtected,
542 GrGpuFinishedProc finishedProc,
543 GrGpuFinishedContext finishedContext) {
Brian Salomonc42eb662019-06-24 17:13:00 -0400544 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400545 if (!this->asDirectContext()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400546 finishedProc(finishedContext);
547 return {};
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400548 }
549
550 if (this->abandoned()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400551 finishedProc(finishedContext);
552 return {};
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400553 }
554
Brian Salomon85c3d682019-11-04 15:04:54 -0500555 GrGpu::BackendTextureData data(color);
Greg Daniel16032b32020-05-06 15:31:10 -0400556 return create_and_update_backend_texture(this, {width, height}, backendFormat, mipMapped,
557 renderable, isProtected, finishedProc, finishedContext,
558 &data);
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400559}
560
561GrBackendTexture GrContext::createBackendTexture(int width, int height,
Robert Phillipsd5e80ca2019-07-29 14:11:35 -0400562 SkColorType skColorType,
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400563 const SkColor4f& color,
564 GrMipMapped mipMapped,
Robert Phillipsda2e67a2019-07-01 15:04:06 -0400565 GrRenderable renderable,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400566 GrProtected isProtected,
567 GrGpuFinishedProc finishedProc,
568 GrGpuFinishedContext finishedContext) {
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400569 if (!this->asDirectContext()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400570 finishedProc(finishedContext);
571 return {};
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400572 }
573
574 if (this->abandoned()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400575 finishedProc(finishedContext);
576 return {};
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400577 }
578
Robert Phillipsd5e80ca2019-07-29 14:11:35 -0400579 GrBackendFormat format = this->defaultBackendFormat(skColorType, renderable);
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400580 if (!format.isValid()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400581 finishedProc(finishedContext);
582 return {};
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400583 }
Robert Phillipsd5e80ca2019-07-29 14:11:35 -0400584
585 GrColorType grColorType = SkColorTypeToGrColorType(skColorType);
Brian Salomon982f5462020-03-30 12:52:33 -0400586 SkColor4f swizzledColor = this->caps()->getWriteSwizzle(format, grColorType).applyTo(color);
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400587
Brian Salomonb450f3b2019-07-09 09:36:51 -0400588 return this->createBackendTexture(width, height, format, swizzledColor, mipMapped, renderable,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400589 isProtected, finishedProc, finishedContext);
Robert Phillips4bdd36f2019-06-04 11:03:06 -0400590}
591
Robert Phillipsba5c7ad2020-01-24 11:03:33 -0500592GrBackendTexture GrContext::createBackendTexture(const SkPixmap srcData[], int numProvidedLevels,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400593 GrRenderable renderable, GrProtected isProtected,
594 GrGpuFinishedProc finishedProc,
595 GrGpuFinishedContext finishedContext) {
Robert Phillips66944402019-09-30 13:21:25 -0400596 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
597
598 if (!this->asDirectContext()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400599 finishedProc(finishedContext);
Robert Phillips66944402019-09-30 13:21:25 -0400600 return {};
601 }
602
603 if (this->abandoned()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400604 finishedProc(finishedContext);
Robert Phillips66944402019-09-30 13:21:25 -0400605 return {};
606 }
607
Robert Phillipsba5c7ad2020-01-24 11:03:33 -0500608 if (!srcData || numProvidedLevels <= 0) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400609 finishedProc(finishedContext);
Robert Phillips66944402019-09-30 13:21:25 -0400610 return {};
611 }
612
613 int baseWidth = srcData[0].width();
614 int baseHeight = srcData[0].height();
615 SkColorType colorType = srcData[0].colorType();
616
Robert Phillipsba5c7ad2020-01-24 11:03:33 -0500617 GrMipMapped mipMapped = GrMipMapped::kNo;
618 int numExpectedLevels = 1;
619 if (numProvidedLevels > 1) {
620 numExpectedLevels = SkMipMap::ComputeLevelCount(baseWidth, baseHeight) + 1;
621 mipMapped = GrMipMapped::kYes;
622 }
623
624 if (numProvidedLevels != numExpectedLevels) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400625 finishedProc(finishedContext);
Robert Phillipsba5c7ad2020-01-24 11:03:33 -0500626 return {};
627 }
628
Robert Phillips66944402019-09-30 13:21:25 -0400629 GrBackendFormat backendFormat = this->defaultBackendFormat(colorType, renderable);
630
Brian Salomon85c3d682019-11-04 15:04:54 -0500631 GrGpu::BackendTextureData data(srcData);
Greg Daniel16032b32020-05-06 15:31:10 -0400632 return create_and_update_backend_texture(this, {baseWidth, baseHeight}, backendFormat,
633 mipMapped, renderable, isProtected, finishedProc,
634 finishedContext, &data);
Robert Phillips66944402019-09-30 13:21:25 -0400635}
636
Greg Danielb2365d82020-05-13 15:32:04 -0400637bool GrContext::updateBackendTexture(const GrBackendTexture& backendTexture,
638 const SkColor4f& color,
639 GrGpuFinishedProc finishedProc,
640 GrGpuFinishedContext finishedContext) {
641 if (!this->asDirectContext()) {
642 finishedProc(finishedContext);
643 return false;
644 }
645
646 if (this->abandoned()) {
647 finishedProc(finishedContext);
648 return false;
649 }
650
651 GrGpu::BackendTextureData data(color);
652 return fGpu->updateBackendTexture(backendTexture, finishedProc, finishedContext, &data);
653}
654
655bool GrContext::updateBackendTexture(const GrBackendTexture& backendTexture,
656 const SkPixmap srcData[],
657 int numLevels,
658 GrGpuFinishedProc finishedProc,
659 GrGpuFinishedContext finishedContext) {
660 if (!this->asDirectContext()) {
661 finishedProc(finishedContext);
662 return false;
663 }
664
665 if (this->abandoned()) {
666 finishedProc(finishedContext);
667 return false;
668 }
669
670 if (!srcData || numLevels <= 0) {
671 finishedProc(finishedContext);
672 return false;
673 }
674
675 int numExpectedLevels = 1;
676 if (backendTexture.hasMipMaps()) {
677 numExpectedLevels = SkMipMap::ComputeLevelCount(backendTexture.width(),
678 backendTexture.height()) + 1;
679 }
680 if (numLevels != numExpectedLevels) {
681 finishedProc(finishedContext);
682 return false;
683 }
684
685 GrGpu::BackendTextureData data(srcData);
686 return fGpu->updateBackendTexture(backendTexture, finishedProc, finishedContext, &data);
687}
688
Robert Phillipsb915c942019-12-17 14:44:37 -0500689//////////////////////////////////////////////////////////////////////////////
690
691GrBackendTexture GrContext::createCompressedBackendTexture(int width, int height,
692 const GrBackendFormat& backendFormat,
693 const SkColor4f& color,
694 GrMipMapped mipMapped,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400695 GrProtected isProtected,
696 GrGpuFinishedProc finishedProc,
697 GrGpuFinishedContext finishedContext) {
Robert Phillipsb915c942019-12-17 14:44:37 -0500698 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
699 if (!this->asDirectContext()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400700 finishedProc(finishedContext);
701 return {};
Robert Phillipsb915c942019-12-17 14:44:37 -0500702 }
703
704 if (this->abandoned()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400705 finishedProc(finishedContext);
706 return {};
Robert Phillipsb915c942019-12-17 14:44:37 -0500707 }
708
709 GrGpu::BackendTextureData data(color);
Robert Phillips4277f012020-01-21 14:28:34 -0500710 return fGpu->createCompressedBackendTexture({width, height}, backendFormat,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400711 mipMapped, isProtected, finishedProc,
712 finishedContext, &data);
Robert Phillipsb915c942019-12-17 14:44:37 -0500713}
714
715GrBackendTexture GrContext::createCompressedBackendTexture(int width, int height,
716 SkImage::CompressionType compression,
717 const SkColor4f& color,
718 GrMipMapped mipMapped,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400719 GrProtected isProtected,
720 GrGpuFinishedProc finishedProc,
721 GrGpuFinishedContext finishedContext) {
Robert Phillipsb915c942019-12-17 14:44:37 -0500722 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
723 if (!this->asDirectContext()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400724 finishedProc(finishedContext);
725 return {};
Robert Phillipsb915c942019-12-17 14:44:37 -0500726 }
727
728 if (this->abandoned()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400729 finishedProc(finishedContext);
730 return {};
Robert Phillipsb915c942019-12-17 14:44:37 -0500731 }
732
733 GrBackendFormat format = this->compressedBackendFormat(compression);
734 return this->createCompressedBackendTexture(width, height, format, color,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400735 mipMapped, isProtected, finishedProc,
736 finishedContext);
Robert Phillipsb915c942019-12-17 14:44:37 -0500737}
738
739GrBackendTexture GrContext::createCompressedBackendTexture(int width, int height,
740 const GrBackendFormat& backendFormat,
741 const void* compressedData,
742 size_t dataSize,
743 GrMipMapped mipMapped,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400744 GrProtected isProtected,
745 GrGpuFinishedProc finishedProc,
746 GrGpuFinishedContext finishedContext) {
Robert Phillipsb915c942019-12-17 14:44:37 -0500747 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
748 if (!this->asDirectContext()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400749 finishedProc(finishedContext);
750 return {};
Robert Phillipsb915c942019-12-17 14:44:37 -0500751 }
752
753 if (this->abandoned()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400754 finishedProc(finishedContext);
755 return {};
Robert Phillipsb915c942019-12-17 14:44:37 -0500756 }
757
758 GrGpu::BackendTextureData data(compressedData, dataSize);
Robert Phillips4277f012020-01-21 14:28:34 -0500759 return fGpu->createCompressedBackendTexture({width, height}, backendFormat,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400760 mipMapped, isProtected, finishedProc,
761 finishedContext, &data);
Robert Phillipsb915c942019-12-17 14:44:37 -0500762}
763
764GrBackendTexture GrContext::createCompressedBackendTexture(int width, int height,
765 SkImage::CompressionType compression,
766 const void* data, size_t dataSize,
767 GrMipMapped mipMapped,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400768 GrProtected isProtected,
769 GrGpuFinishedProc finishedProc,
770 GrGpuFinishedContext finishedContext) {
Robert Phillipsb915c942019-12-17 14:44:37 -0500771 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
772 if (!this->asDirectContext()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400773 finishedProc(finishedContext);
774 return {};
Robert Phillipsb915c942019-12-17 14:44:37 -0500775 }
776
777 if (this->abandoned()) {
Greg Danielc1ad77c2020-05-06 11:40:03 -0400778 finishedProc(finishedContext);
779 return {};
Robert Phillipsb915c942019-12-17 14:44:37 -0500780 }
781
782 GrBackendFormat format = this->compressedBackendFormat(compression);
783 return this->createCompressedBackendTexture(width, height, format, data, dataSize,
Greg Danielc1ad77c2020-05-06 11:40:03 -0400784 mipMapped, isProtected, finishedProc,
785 finishedContext);
Robert Phillipsb915c942019-12-17 14:44:37 -0500786}
787
Greg Daniel1db8e792020-06-09 17:29:32 -0400788bool GrContext::setBackendTextureState(const GrBackendTexture& backendTexture,
789 const GrBackendSurfaceMutableState& state,
790 GrGpuFinishedProc finishedProc,
791 GrGpuFinishedContext finishedContext) {
792 if (!this->asDirectContext()) {
793 finishedProc(finishedContext);
794 return false;
795 }
796
797 if (this->abandoned()) {
798 finishedProc(finishedContext);
799 return false;
800 }
801
802 sk_sp<GrRefCntedCallback> callback;
803 if (finishedProc) {
804 callback.reset(new GrRefCntedCallback(finishedProc, finishedContext));
805 }
806 return fGpu->setBackendTextureState(backendTexture, state, std::move(callback));
807}
808
809bool GrContext::setBackendRenderTargetState(const GrBackendRenderTarget& backendRenderTarget,
810 const GrBackendSurfaceMutableState& state,
811 GrGpuFinishedProc finishedProc,
812 GrGpuFinishedContext finishedContext) {
813 if (!this->asDirectContext()) {
814 finishedProc(finishedContext);
815 return false;
816 }
817
818 if (this->abandoned()) {
819 finishedProc(finishedContext);
820 return false;
821 }
822
823 sk_sp<GrRefCntedCallback> callback;
824 if (finishedProc) {
825 callback.reset(new GrRefCntedCallback(finishedProc, finishedContext));
826 }
827 return fGpu->setBackendRenderTargetState(backendRenderTarget, state, std::move(callback));
828}
829
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400830void GrContext::deleteBackendTexture(GrBackendTexture backendTex) {
Brian Salomonc42eb662019-06-24 17:13:00 -0400831 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
Greg Danielf0e04f02019-12-04 15:17:54 -0500832 // For the Vulkan backend we still must destroy the backend texture when the context is
833 // abandoned.
834 if ((this->abandoned() && this->backend() != GrBackendApi::kVulkan) || !backendTex.isValid()) {
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400835 return;
836 }
837
Robert Phillipsf0313ee2019-05-21 13:51:11 -0400838 fGpu->deleteBackendTexture(backendTex);
Robert Phillips5c7a25b2019-05-20 08:38:07 -0400839}
840
Greg Daniel1db8e792020-06-09 17:29:32 -0400841//////////////////////////////////////////////////////////////////////////////
842
Brian Osmaned58e002019-09-06 14:42:43 -0400843bool GrContext::precompileShader(const SkData& key, const SkData& data) {
844 return fGpu->precompileShader(key, data);
845}
846
Brian Salomonec22b1a2019-08-09 09:41:48 -0400847#ifdef SK_ENABLE_DUMP_GPU
Michael Ludwigdd205452020-03-30 17:16:34 -0400848#include "include/core/SkString.h"
Brian Salomonec22b1a2019-08-09 09:41:48 -0400849#include "src/utils/SkJSONWriter.h"
850SkString GrContext::dump() const {
851 SkDynamicMemoryWStream stream;
852 SkJSONWriter writer(&stream, SkJSONWriter::Mode::kPretty);
853 writer.beginObject();
854
855 writer.appendString("backend", GrBackendApiToStr(this->backend()));
856
857 writer.appendName("caps");
858 this->caps()->dumpJSON(&writer);
859
860 writer.appendName("gpu");
861 this->fGpu->dumpJSON(&writer);
862
Robert Phillips273f1072020-05-05 13:03:07 -0400863 writer.appendName("context");
864 this->dumpJSON(&writer);
865
Brian Salomonec22b1a2019-08-09 09:41:48 -0400866 // Flush JSON to the memory stream
867 writer.endObject();
868 writer.flush();
869
870 // Null terminate the JSON data in the memory stream
871 stream.write8(0);
872
873 // Allocate a string big enough to hold all the data, then copy out of the stream
874 SkString result(stream.bytesWritten());
875 stream.copyToAndReset(result.writable_str());
876 return result;
877}
878#endif