blob: ecbde5a8ea9963041bf1c64211f561140e8f38ac [file] [log] [blame]
Brian Salomoncfe910d2017-07-06 16:40:18 -04001/*
2 * Copyright 2017 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.
6 */
7
Mike Kleinc0bd9f92019-04-23 12:05:21 -05008#include "src/gpu/mock/GrMockBuffer.h"
9#include "src/gpu/mock/GrMockCaps.h"
10#include "src/gpu/mock/GrMockGpu.h"
Greg Daniel2d41d0d2019-08-26 11:08:51 -040011#include "src/gpu/mock/GrMockOpsRenderPass.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050012#include "src/gpu/mock/GrMockStencilAttachment.h"
13#include "src/gpu/mock/GrMockTexture.h"
Mike Kleinde2244c2018-12-04 11:16:08 -050014#include <atomic>
Brian Salomoncfe910d2017-07-06 16:40:18 -040015
Brian Salomon8fe24272017-07-07 12:56:11 -040016int GrMockGpu::NextInternalTextureID() {
Mike Kleinde2244c2018-12-04 11:16:08 -050017 static std::atomic<int> nextID{1};
Chris Dalton351e80c2019-01-06 22:51:00 -070018 int id;
19 do {
20 id = nextID.fetch_add(1);
21 } while (0 == id); // Reserve 0 for an invalid ID.
22 return id;
Brian Salomon8fe24272017-07-07 12:56:11 -040023}
24
25int GrMockGpu::NextExternalTextureID() {
26 // We use negative ints for the "testing only external textures" so they can easily be
27 // identified when debugging.
Mike Kleinde2244c2018-12-04 11:16:08 -050028 static std::atomic<int> nextID{-1};
29 return nextID--;
Brian Salomon8fe24272017-07-07 12:56:11 -040030}
31
Brian Salomon0c51eea2018-03-09 17:02:09 -050032int GrMockGpu::NextInternalRenderTargetID() {
Mike Kleinde2244c2018-12-04 11:16:08 -050033 // We start off with large numbers to differentiate from texture IDs, even though they're
Brian Salomon0c51eea2018-03-09 17:02:09 -050034 // technically in a different space.
Mike Kleinde2244c2018-12-04 11:16:08 -050035 static std::atomic<int> nextID{SK_MaxS32};
36 return nextID--;
Brian Salomon0c51eea2018-03-09 17:02:09 -050037}
38
39int GrMockGpu::NextExternalRenderTargetID() {
40 // We use large negative ints for the "testing only external render targets" so they can easily
41 // be identified when debugging.
Mike Kleinde2244c2018-12-04 11:16:08 -050042 static std::atomic<int> nextID{SK_MinS32};
43 return nextID++;
Brian Salomon0c51eea2018-03-09 17:02:09 -050044}
45
Brian Salomon384fab42017-12-07 12:33:05 -050046sk_sp<GrGpu> GrMockGpu::Make(const GrMockOptions* mockOptions,
Adlai Holler3d0359a2020-07-09 15:35:55 -040047 const GrContextOptions& contextOptions, GrDirectContext* direct) {
Greg Daniel02611d92017-07-25 10:05:01 -040048 static const GrMockOptions kDefaultOptions = GrMockOptions();
49 if (!mockOptions) {
50 mockOptions = &kDefaultOptions;
51 }
Adlai Holler3d0359a2020-07-09 15:35:55 -040052 return sk_sp<GrGpu>(new GrMockGpu(direct, *mockOptions, contextOptions));
Greg Daniel02611d92017-07-25 10:05:01 -040053}
54
Greg Daniel2d41d0d2019-08-26 11:08:51 -040055GrOpsRenderPass* GrMockGpu::getOpsRenderPass(
Robert Phillips96f22372020-05-20 12:31:18 -040056 GrRenderTarget* rt, GrStencilAttachment*,
57 GrSurfaceOrigin origin, const SkIRect& bounds,
Greg Daniel2d41d0d2019-08-26 11:08:51 -040058 const GrOpsRenderPass::LoadAndStoreInfo& colorInfo,
Greg Danielb20d7e52019-09-03 13:54:39 -040059 const GrOpsRenderPass::StencilLoadAndStoreInfo&,
Michael Ludwigfcdd0612019-11-25 08:34:31 -050060 const SkTArray<GrSurfaceProxy*, true>& sampledProxies) {
Greg Daniel2d41d0d2019-08-26 11:08:51 -040061 return new GrMockOpsRenderPass(this, rt, origin, colorInfo);
Brian Salomoncfe910d2017-07-06 16:40:18 -040062}
63
Greg Daniel2d41d0d2019-08-26 11:08:51 -040064void GrMockGpu::submit(GrOpsRenderPass* renderPass) {
65 for (int i = 0; i < static_cast<GrMockOpsRenderPass*>(renderPass)->numDraws(); ++i) {
Brian Salomoncfe910d2017-07-06 16:40:18 -040066 fStats.incNumDraws();
67 }
Greg Daniel2d41d0d2019-08-26 11:08:51 -040068 delete renderPass;
Brian Salomoncfe910d2017-07-06 16:40:18 -040069}
70
Adlai Holler3d0359a2020-07-09 15:35:55 -040071GrMockGpu::GrMockGpu(GrDirectContext* direct, const GrMockOptions& options,
Brian Salomoncfe910d2017-07-06 16:40:18 -040072 const GrContextOptions& contextOptions)
Adlai Holler3d0359a2020-07-09 15:35:55 -040073 : INHERITED(direct)
Chris Dalton91ab1552018-04-18 13:24:25 -060074 , fMockOptions(options) {
Brian Salomoncfe910d2017-07-06 16:40:18 -040075 fCaps.reset(new GrMockCaps(contextOptions, options));
76}
77
Chris Daltonc3318f02019-07-19 14:20:53 -060078void GrMockGpu::querySampleLocations(GrRenderTarget* rt, SkTArray<SkPoint>* sampleLocations) {
79 sampleLocations->reset();
80 int numRemainingSamples = rt->numSamples();
81 while (numRemainingSamples > 0) {
82 // Use standard D3D sample locations.
83 switch (numRemainingSamples) {
84 case 0:
85 case 1:
86 sampleLocations->push_back().set(.5, .5);
87 break;
88 case 2:
89 sampleLocations->push_back().set(.75, .75);
90 sampleLocations->push_back().set(.25, .25);
91 break;
92 case 3:
93 case 4:
94 sampleLocations->push_back().set(.375, .125);
95 sampleLocations->push_back().set(.875, .375);
96 sampleLocations->push_back().set(.125, .625);
97 sampleLocations->push_back().set(.625, .875);
98 break;
99 case 5:
100 case 6:
101 case 7:
102 case 8:
103 sampleLocations->push_back().set(.5625, .3125);
104 sampleLocations->push_back().set(.4375, .6875);
105 sampleLocations->push_back().set(.8125, .5625);
106 sampleLocations->push_back().set(.3125, .1875);
107 sampleLocations->push_back().set(.1875, .8125);
108 sampleLocations->push_back().set(.0625, .4375);
109 sampleLocations->push_back().set(.6875, .4375);
110 sampleLocations->push_back().set(.4375, .0625);
111 break;
112 default:
113 sampleLocations->push_back().set(.5625, .5625);
114 sampleLocations->push_back().set(.4375, .3125);
115 sampleLocations->push_back().set(.3125, .6250);
116 sampleLocations->push_back().set(.2500, .4375);
117 sampleLocations->push_back().set(.1875, .3750);
118 sampleLocations->push_back().set(.6250, .8125);
119 sampleLocations->push_back().set(.8125, .6875);
120 sampleLocations->push_back().set(.6875, .1875);
121 sampleLocations->push_back().set(.3750, .8750);
122 sampleLocations->push_back().set(.5000, .0625);
123 sampleLocations->push_back().set(.2500, .1250);
124 sampleLocations->push_back().set(.1250, .2500);
125 sampleLocations->push_back().set(.0000, .5000);
126 sampleLocations->push_back().set(.4375, .2500);
127 sampleLocations->push_back().set(.8750, .4375);
128 sampleLocations->push_back().set(.0625, .0000);
129 break;
130 }
131 numRemainingSamples = rt->numSamples() - sampleLocations->count();
132 }
133}
134
Brian Salomona56a7462020-02-07 14:17:25 -0500135sk_sp<GrTexture> GrMockGpu::onCreateTexture(SkISize dimensions,
Brian Salomon81536f22019-08-08 16:30:49 -0400136 const GrBackendFormat& format,
137 GrRenderable renderable,
138 int renderTargetSampleCnt,
139 SkBudgeted budgeted,
140 GrProtected isProtected,
Brian Salomond2a8ae22019-09-10 16:03:59 -0400141 int mipLevelCount,
142 uint32_t levelClearMask) {
Chris Dalton91ab1552018-04-18 13:24:25 -0600143 if (fMockOptions.fFailTextureAllocations) {
144 return nullptr;
145 }
146
Robert Phillipsa27d6252019-12-10 14:48:36 -0500147 // Compressed formats should go through onCreateCompressedTexture
148 SkASSERT(format.asMockCompressionType() == SkImage::CompressionType::kNone);
149
Brian Salomon81536f22019-08-08 16:30:49 -0400150 GrColorType ct = format.asMockColorType();
151 SkASSERT(ct != GrColorType::kUnknown);
Robert Phillipsa5e78be2019-07-09 12:34:38 -0400152
Brian Salomond2a8ae22019-09-10 16:03:59 -0400153 GrMipMapsStatus mipMapsStatus =
154 mipLevelCount > 1 ? GrMipMapsStatus::kDirty : GrMipMapsStatus::kNotAllocated;
Robert Phillipsa27d6252019-12-10 14:48:36 -0500155 GrMockTextureInfo texInfo(ct, SkImage::CompressionType::kNone, NextInternalTextureID());
Brian Salomonf2c2ba92019-07-17 09:59:59 -0400156 if (renderable == GrRenderable::kYes) {
Greg Daniele877dce2019-07-11 10:52:43 -0400157 GrMockRenderTargetInfo rtInfo(ct, NextInternalRenderTargetID());
Brian Salomona56a7462020-02-07 14:17:25 -0500158 return sk_sp<GrTexture>(new GrMockTextureRenderTarget(this, budgeted, dimensions,
Brian Salomon27b4d8d2019-07-22 14:23:45 -0400159 renderTargetSampleCnt, isProtected,
Brian Salomone8a766b2019-07-19 14:24:36 -0400160 mipMapsStatus, texInfo, rtInfo));
Brian Salomoncfe910d2017-07-06 16:40:18 -0400161 }
Brian Salomone8a766b2019-07-19 14:24:36 -0400162 return sk_sp<GrTexture>(
Brian Salomona56a7462020-02-07 14:17:25 -0500163 new GrMockTexture(this, budgeted, dimensions, isProtected, mipMapsStatus, texInfo));
Brian Salomoncfe910d2017-07-06 16:40:18 -0400164}
165
Robert Phillipsa27d6252019-12-10 14:48:36 -0500166// TODO: why no 'isProtected' ?!
Robert Phillips9f744f72019-12-19 19:14:33 -0500167sk_sp<GrTexture> GrMockGpu::onCreateCompressedTexture(SkISize dimensions,
Robert Phillipsa27d6252019-12-10 14:48:36 -0500168 const GrBackendFormat& format,
Robert Phillips3a833922020-01-21 15:25:58 -0500169 SkBudgeted budgeted,
170 GrMipMapped mipMapped,
171 GrProtected isProtected,
Robert Phillips9f744f72019-12-19 19:14:33 -0500172 const void* data, size_t dataSize) {
Robert Phillipsa27d6252019-12-10 14:48:36 -0500173 if (fMockOptions.fFailTextureAllocations) {
174 return nullptr;
175 }
176
Greg Danielb58a3c72020-01-23 10:05:14 -0500177#ifdef SK_DEBUG
Robert Phillipsa27d6252019-12-10 14:48:36 -0500178 // Uncompressed formats should go through onCreateTexture
179 SkImage::CompressionType compression = format.asMockCompressionType();
180 SkASSERT(compression != SkImage::CompressionType::kNone);
Greg Danielb58a3c72020-01-23 10:05:14 -0500181#endif
Robert Phillipsa27d6252019-12-10 14:48:36 -0500182
Robert Phillipse4720c62020-01-14 14:33:24 -0500183 GrMipMapsStatus mipMapsStatus = (mipMapped == GrMipMapped::kYes)
184 ? GrMipMapsStatus::kValid
185 : GrMipMapsStatus::kNotAllocated;
Robert Phillipsa27d6252019-12-10 14:48:36 -0500186 GrMockTextureInfo texInfo(GrColorType::kUnknown,
187 format.asMockCompressionType(),
188 NextInternalTextureID());
189
Brian Salomona56a7462020-02-07 14:17:25 -0500190 return sk_sp<GrTexture>(
191 new GrMockTexture(this, budgeted, dimensions, isProtected, mipMapsStatus, texInfo));
Brian Salomonbb8dde82019-06-27 10:52:13 -0400192}
193
Brian Salomon8a78e9c2020-03-27 10:42:15 -0400194sk_sp<GrTexture> GrMockGpu::onWrapBackendTexture(const GrBackendTexture& tex,
Brian Salomonfa2ebea2019-01-24 15:58:58 -0500195 GrWrapOwnership ownership,
Brian Salomon8a78e9c2020-03-27 10:42:15 -0400196 GrWrapCacheable wrapType,
197 GrIOType ioType) {
Robert Phillipsc80b0e92019-07-23 10:27:09 -0400198 GrMockTextureInfo texInfo;
199 SkAssertResult(tex.getMockTextureInfo(&texInfo));
Robert Phillipsa5e78be2019-07-09 12:34:38 -0400200
Robert Phillipsa27d6252019-12-10 14:48:36 -0500201 SkImage::CompressionType compression = texInfo.compressionType();
Robert Phillipsb915c942019-12-17 14:44:37 -0500202 if (compression != SkImage::CompressionType::kNone) {
203 return nullptr;
Robert Phillipsa27d6252019-12-10 14:48:36 -0500204 }
205
Greg Daniel4684f822018-03-08 15:27:36 -0500206 GrMipMapsStatus mipMapsStatus = tex.hasMipMaps() ? GrMipMapsStatus::kValid
207 : GrMipMapsStatus::kNotAllocated;
Brian Salomone8a766b2019-07-19 14:24:36 -0400208 auto isProtected = GrProtected(tex.isProtected());
Brian Salomona56a7462020-02-07 14:17:25 -0500209 return sk_sp<GrTexture>(new GrMockTexture(this, tex.dimensions(), isProtected, mipMapsStatus,
210 texInfo, wrapType, ioType));
Greg Daniel4684f822018-03-08 15:27:36 -0500211}
212
Robert Phillipsb915c942019-12-17 14:44:37 -0500213sk_sp<GrTexture> GrMockGpu::onWrapCompressedBackendTexture(const GrBackendTexture& tex,
214 GrWrapOwnership ownership,
215 GrWrapCacheable wrapType) {
216 return nullptr;
217}
218
Brian Salomon0c51eea2018-03-09 17:02:09 -0500219sk_sp<GrTexture> GrMockGpu::onWrapRenderableBackendTexture(const GrBackendTexture& tex,
220 int sampleCnt,
Brian Salomonaa6ca0a2019-01-24 16:03:07 -0500221 GrWrapOwnership ownership,
222 GrWrapCacheable cacheable) {
Robert Phillipsa5e78be2019-07-09 12:34:38 -0400223 GrMockTextureInfo texInfo;
224 SkAssertResult(tex.getMockTextureInfo(&texInfo));
Robert Phillipsa27d6252019-12-10 14:48:36 -0500225 SkASSERT(texInfo.compressionType() == SkImage::CompressionType::kNone);
Robert Phillipsa5e78be2019-07-09 12:34:38 -0400226
Brian Salomon0c51eea2018-03-09 17:02:09 -0500227 GrMipMapsStatus mipMapsStatus =
228 tex.hasMipMaps() ? GrMipMapsStatus::kValid : GrMipMapsStatus::kNotAllocated;
229
Brian Salomon0c51eea2018-03-09 17:02:09 -0500230 // The client gave us the texture ID but we supply the render target ID.
Robert Phillipsa27d6252019-12-10 14:48:36 -0500231 GrMockRenderTargetInfo rtInfo(texInfo.colorType(), NextInternalRenderTargetID());
Brian Salomon0c51eea2018-03-09 17:02:09 -0500232
Brian Salomone8a766b2019-07-19 14:24:36 -0400233 auto isProtected = GrProtected(tex.isProtected());
Brian Salomona56a7462020-02-07 14:17:25 -0500234 return sk_sp<GrTexture>(new GrMockTextureRenderTarget(this, tex.dimensions(), sampleCnt,
235 isProtected, mipMapsStatus, texInfo,
236 rtInfo, cacheable));
Brian Salomon0c51eea2018-03-09 17:02:09 -0500237}
238
Brian Salomon8a78e9c2020-03-27 10:42:15 -0400239sk_sp<GrRenderTarget> GrMockGpu::onWrapBackendRenderTarget(const GrBackendRenderTarget& rt) {
Robert Phillipsa5e78be2019-07-09 12:34:38 -0400240 GrMockRenderTargetInfo info;
241 SkAssertResult(rt.getMockRenderTargetInfo(&info));
242
Brian Salomone8a766b2019-07-19 14:24:36 -0400243 auto isProtected = GrProtected(rt.isProtected());
Brian Salomona56a7462020-02-07 14:17:25 -0500244 return sk_sp<GrRenderTarget>(new GrMockRenderTarget(this, GrMockRenderTarget::kWrapped,
245 rt.dimensions(), rt.sampleCnt(),
246 isProtected, info));
Brian Salomon0c51eea2018-03-09 17:02:09 -0500247}
248
249sk_sp<GrRenderTarget> GrMockGpu::onWrapBackendTextureAsRenderTarget(const GrBackendTexture& tex,
Brian Salomon8a78e9c2020-03-27 10:42:15 -0400250 int sampleCnt) {
Robert Phillipsa5e78be2019-07-09 12:34:38 -0400251 GrMockTextureInfo texInfo;
252 SkAssertResult(tex.getMockTextureInfo(&texInfo));
Robert Phillipsa27d6252019-12-10 14:48:36 -0500253 SkASSERT(texInfo.compressionType() == SkImage::CompressionType::kNone);
Robert Phillipsa5e78be2019-07-09 12:34:38 -0400254
Brian Salomon0c51eea2018-03-09 17:02:09 -0500255 // The client gave us the texture ID but we supply the render target ID.
Robert Phillipsa27d6252019-12-10 14:48:36 -0500256 GrMockRenderTargetInfo rtInfo(texInfo.colorType(), NextInternalRenderTargetID());
Brian Salomon0c51eea2018-03-09 17:02:09 -0500257
Brian Salomone8a766b2019-07-19 14:24:36 -0400258 auto isProtected = GrProtected(tex.isProtected());
Brian Salomona56a7462020-02-07 14:17:25 -0500259 return sk_sp<GrRenderTarget>(new GrMockRenderTarget(
260 this, GrMockRenderTarget::kWrapped, tex.dimensions(), sampleCnt, isProtected, rtInfo));
Brian Salomon0c51eea2018-03-09 17:02:09 -0500261}
262
Brian Salomondbf70722019-02-07 11:31:24 -0500263sk_sp<GrGpuBuffer> GrMockGpu::onCreateBuffer(size_t sizeInBytes, GrGpuBufferType type,
264 GrAccessPattern accessPattern, const void*) {
265 return sk_sp<GrGpuBuffer>(new GrMockBuffer(this, sizeInBytes, type, accessPattern));
Brian Salomoncfe910d2017-07-06 16:40:18 -0400266}
267
Chris Daltoneffee202019-07-01 22:28:03 -0600268GrStencilAttachment* GrMockGpu::createStencilAttachmentForRenderTarget(
269 const GrRenderTarget* rt, int width, int height, int numStencilSamples) {
270 SkASSERT(numStencilSamples == rt->numSamples());
Brian Salomoncfe910d2017-07-06 16:40:18 -0400271 static constexpr int kBits = 8;
272 fStats.incStencilAttachmentCreates();
Chris Dalton6ce447a2019-06-23 18:07:38 -0600273 return new GrMockStencilAttachment(this, width, height, kBits, rt->numSamples());
Brian Salomoncfe910d2017-07-06 16:40:18 -0400274}
Brian Salomon8fe24272017-07-07 12:56:11 -0400275
Brian Salomon85c3d682019-11-04 15:04:54 -0500276GrBackendTexture GrMockGpu::onCreateBackendTexture(SkISize dimensions,
Robert Phillips57ef6802019-09-23 10:12:47 -0400277 const GrBackendFormat& format,
Brian Salomon85c3d682019-11-04 15:04:54 -0500278 GrRenderable,
Robert Phillips0d7e2f12019-12-18 13:01:04 -0500279 GrMipMapped mipMapped,
Greg Daniel16032b32020-05-06 15:31:10 -0400280 GrProtected) {
Robert Phillipsa27d6252019-12-10 14:48:36 -0500281 SkImage::CompressionType compression = format.asMockCompressionType();
282 if (compression != SkImage::CompressionType::kNone) {
283 return {}; // should go through onCreateCompressedBackendTexture
284 }
285
Brian Salomond4764a12019-08-08 12:08:24 -0400286 auto colorType = format.asMockColorType();
Greg Daniel7bfc9132019-08-14 14:23:53 -0400287 if (!this->caps()->isFormatTexturable(format)) {
Robert Phillips9dbcdcc2019-05-13 10:40:06 -0400288 return GrBackendTexture(); // invalid
289 }
290
Robert Phillipsa27d6252019-12-10 14:48:36 -0500291 GrMockTextureInfo info(colorType, SkImage::CompressionType::kNone, NextExternalTextureID());
Robert Phillips646f6372018-09-25 09:31:10 -0400292
Robert Phillipsa27d6252019-12-10 14:48:36 -0500293 fOutstandingTestingOnlyTextureIDs.add(info.id());
Brian Salomon85c3d682019-11-04 15:04:54 -0500294 return GrBackendTexture(dimensions.width(), dimensions.height(), mipMapped, info);
Robert Phillipsd21b2a52017-12-12 13:01:25 -0500295}
296
Greg Danielc1ad77c2020-05-06 11:40:03 -0400297GrBackendTexture GrMockGpu::onCreateCompressedBackendTexture(
298 SkISize dimensions, const GrBackendFormat& format, GrMipMapped mipMapped,
Greg Danielaaf738c2020-07-10 09:30:33 -0400299 GrProtected) {
Robert Phillipsb915c942019-12-17 14:44:37 -0500300 SkImage::CompressionType compression = format.asMockCompressionType();
301 if (compression == SkImage::CompressionType::kNone) {
302 return {}; // should go through onCreateBackendTexture
303 }
304
305 if (!this->caps()->isFormatTexturable(format)) {
306 return {};
307 }
308
309 GrMockTextureInfo info(GrColorType::kUnknown, compression, NextExternalTextureID());
310
311 fOutstandingTestingOnlyTextureIDs.add(info.id());
312 return GrBackendTexture(dimensions.width(), dimensions.height(), mipMapped, info);
313}
314
Robert Phillipsf0313ee2019-05-21 13:51:11 -0400315void GrMockGpu::deleteBackendTexture(const GrBackendTexture& tex) {
Robert Phillipsf0ced622019-05-16 09:06:25 -0400316 SkASSERT(GrBackendApi::kMock == tex.backend());
317
318 GrMockTextureInfo info;
319 if (tex.getMockTextureInfo(&info)) {
Robert Phillipsa27d6252019-12-10 14:48:36 -0500320 fOutstandingTestingOnlyTextureIDs.remove(info.id());
Robert Phillipsf0ced622019-05-16 09:06:25 -0400321 }
322}
323
324#if GR_TEST_UTILS
Robert Phillipsd21b2a52017-12-12 13:01:25 -0500325bool GrMockGpu::isTestingOnlyBackendTexture(const GrBackendTexture& tex) const {
Greg Danielbdf12ad2018-10-12 09:31:11 -0400326 SkASSERT(GrBackendApi::kMock == tex.backend());
Robert Phillipsd21b2a52017-12-12 13:01:25 -0500327
Greg Daniel52e16d92018-04-10 09:34:07 -0400328 GrMockTextureInfo info;
329 if (!tex.getMockTextureInfo(&info)) {
Robert Phillipsd21b2a52017-12-12 13:01:25 -0500330 return false;
331 }
332
Robert Phillipsa27d6252019-12-10 14:48:36 -0500333 return fOutstandingTestingOnlyTextureIDs.contains(info.id());
Robert Phillipsd21b2a52017-12-12 13:01:25 -0500334}
335
Brian Salomon0c51eea2018-03-09 17:02:09 -0500336GrBackendRenderTarget GrMockGpu::createTestingOnlyBackendRenderTarget(int w, int h,
Brian Osman2d010b62018-08-09 10:55:09 -0400337 GrColorType colorType) {
Greg Daniele877dce2019-07-11 10:52:43 -0400338 GrMockRenderTargetInfo info(colorType, NextExternalRenderTargetID());
Brian Salomon0c51eea2018-03-09 17:02:09 -0500339 static constexpr int kSampleCnt = 1;
340 static constexpr int kStencilBits = 8;
Robert Phillipsa5e78be2019-07-09 12:34:38 -0400341 return GrBackendRenderTarget(w, h, kSampleCnt, kStencilBits, info);
Brian Salomonf865b052018-03-09 09:01:53 -0500342}
343
344void GrMockGpu::deleteTestingOnlyBackendRenderTarget(const GrBackendRenderTarget&) {}
345#endif