blob: 85f0d14a3644cff8f2bd7f17992682e7a19a06ab [file] [log] [blame]
commit-bot@chromium.org78a10782013-08-21 19:27:48 +00001
2/*
3 * Copyright 2013 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
8
9#include "GrTest.h"
10
bsalomon3582d3e2015-02-13 14:20:05 -080011#include "GrGpuResourceCacheAccess.h"
joshualitt50408ad2014-11-03 12:31:14 -080012#include "GrInOrderDrawBuffer.h"
bsalomon0ea80f42015-02-11 10:49:59 -080013#include "GrResourceCache.h"
mtkleinb9eb4ac2015-02-02 18:26:03 -080014#include "SkString.h"
commit-bot@chromium.org78a10782013-08-21 19:27:48 +000015
16void GrTestTarget::init(GrContext* ctx, GrDrawTarget* target) {
17 SkASSERT(!fContext);
18
19 fContext.reset(SkRef(ctx));
20 fDrawTarget.reset(SkRef(target));
21
commit-bot@chromium.org78a10782013-08-21 19:27:48 +000022 SkNEW_IN_TLAZY(&fACR, GrDrawTarget::AutoClipRestore, (target));
23 SkNEW_IN_TLAZY(&fAGP, GrDrawTarget::AutoGeometryPush, (target));
24}
25
26void GrContext::getTestTarget(GrTestTarget* tar) {
27 this->flush();
28 // We could create a proxy GrDrawTarget that passes through to fGpu until ~GrTextTarget() and
29 // then disconnects. This would help prevent test writers from mixing using the returned
30 // GrDrawTarget and regular drawing. We could also assert or fail in GrContext drawing methods
31 // until ~GrTestTarget().
joshualitt50408ad2014-11-03 12:31:14 -080032 tar->init(this, fDrawBuffer);
commit-bot@chromium.org78a10782013-08-21 19:27:48 +000033}
34
35///////////////////////////////////////////////////////////////////////////////
36
37void GrContext::setMaxTextureSizeOverride(int maxTextureSizeOverride) {
38 fMaxTextureSizeOverride = maxTextureSizeOverride;
39}
robertphillips@google.com94d8f1e2013-12-18 17:25:33 +000040
41void GrContext::purgeAllUnlockedResources() {
bsalomon0ea80f42015-02-11 10:49:59 -080042 fResourceCache->purgeAllUnlocked();
robertphillips@google.com94d8f1e2013-12-18 17:25:33 +000043}
bsalomon33435572014-11-05 14:47:41 -080044
mtkleinb9eb4ac2015-02-02 18:26:03 -080045void GrContext::dumpCacheStats(SkString* out) const {
46#if GR_CACHE_STATS
bsalomon0ea80f42015-02-11 10:49:59 -080047 fResourceCache->dumpStats(out);
mtkleinb9eb4ac2015-02-02 18:26:03 -080048#endif
49}
50
51void GrContext::printCacheStats() const {
52 SkString out;
53 this->dumpCacheStats(&out);
kkinnunen297aaf92015-02-19 06:32:12 -080054 SkDebugf("%s", out.c_str());
mtkleinb9eb4ac2015-02-02 18:26:03 -080055}
56
57void GrContext::dumpGpuStats(SkString* out) const {
58#if GR_GPU_STATS
59 return fGpu->stats()->dump(out);
60#endif
61}
62
63void GrContext::printGpuStats() const {
64 SkString out;
65 this->dumpGpuStats(&out);
kkinnunen297aaf92015-02-19 06:32:12 -080066 SkDebugf("%s", out.c_str());
mtkleinb9eb4ac2015-02-02 18:26:03 -080067}
68
69#if GR_GPU_STATS
70void GrGpu::Stats::dump(SkString* out) {
71 out->appendf("Render Target Binds: %d\n", fRenderTargetBinds);
72 out->appendf("Shader Compilations: %d\n", fShaderCompilations);
bsalomonb12ea412015-02-02 21:19:50 -080073 out->appendf("Textures Created: %d\n", fTextureCreates);
74 out->appendf("Texture Uploads: %d\n", fTextureUploads);
bsalomon9e5fc722015-02-23 10:01:36 -080075 out->appendf("Stencil Buffer Creates: %d\n", fStencilBufferCreates);
mtkleinb9eb4ac2015-02-02 18:26:03 -080076}
77#endif
78
79#if GR_CACHE_STATS
bsalomon0ea80f42015-02-11 10:49:59 -080080void GrResourceCache::dumpStats(SkString* out) const {
mtkleinb9eb4ac2015-02-02 18:26:03 -080081 this->validate();
82
bsalomonf320e042015-02-17 15:09:34 -080083 int locked = fNonpurgeableResources.count();
mtkleinb9eb4ac2015-02-02 18:26:03 -080084
bsalomonf320e042015-02-17 15:09:34 -080085 struct Stats {
86 int fScratch;
87 int fWrapped;
88 size_t fUnbudgetedSize;
mtkleinb9eb4ac2015-02-02 18:26:03 -080089
bsalomonf320e042015-02-17 15:09:34 -080090 Stats() : fScratch(0), fWrapped(0), fUnbudgetedSize(0) {}
91
92 void update(GrGpuResource* resource) {
93 if (resource->cacheAccess().isScratch()) {
94 ++fScratch;
95 }
96 if (resource->cacheAccess().isWrapped()) {
97 ++fWrapped;
98 }
99 if (!resource->resourcePriv().isBudgeted()) {
100 fUnbudgetedSize += resource->gpuMemorySize();
101 }
mtkleinb9eb4ac2015-02-02 18:26:03 -0800102 }
bsalomonf320e042015-02-17 15:09:34 -0800103 };
104
105 Stats stats;
106
107 for (int i = 0; i < fNonpurgeableResources.count(); ++i) {
108 stats.update(fNonpurgeableResources[i]);
109 }
110 for (int i = 0; i < fPurgeableQueue.count(); ++i) {
111 stats.update(fPurgeableQueue.at(i));
mtkleinb9eb4ac2015-02-02 18:26:03 -0800112 }
113
114 float countUtilization = (100.f * fBudgetedCount) / fMaxCount;
115 float byteUtilization = (100.f * fBudgetedBytes) / fMaxBytes;
116
117 out->appendf("Budget: %d items %d bytes\n", fMaxCount, (int)fMaxBytes);
118 out->appendf("\t\tEntry Count: current %d"
119 " (%d budgeted, %d wrapped, %d locked, %d scratch %.2g%% full), high %d\n",
bsalomon52057c82015-02-23 12:12:59 -0800120 this->getResourceCount(), fBudgetedCount, stats.fWrapped, locked, stats.fScratch,
121 countUtilization, fHighWaterCount);
mtkleinb9eb4ac2015-02-02 18:26:03 -0800122 out->appendf("\t\tEntry Bytes: current %d (budgeted %d, %.2g%% full, %d unbudgeted) high %d\n",
bsalomonf320e042015-02-17 15:09:34 -0800123 SkToInt(fBytes), SkToInt(fBudgetedBytes), byteUtilization,
124 SkToInt(stats.fUnbudgetedSize), SkToInt(fHighWaterBytes));
mtkleinb9eb4ac2015-02-02 18:26:03 -0800125}
126
127#endif
128
bsalomonddf30e62015-02-19 11:38:44 -0800129///////////////////////////////////////////////////////////////////////////////
130
131void GrResourceCache::changeTimestamp(uint32_t newTimestamp) { fTimestamp = newTimestamp; }
mtkleinb9eb4ac2015-02-02 18:26:03 -0800132
bsalomon33435572014-11-05 14:47:41 -0800133///////////////////////////////////////////////////////////////////////////////
134// Code for the mock context. It's built on a mock GrGpu class that does nothing.
135////
136
137#include "GrBufferAllocPool.h"
138#include "GrInOrderDrawBuffer.h"
139#include "GrGpu.h"
140
egdaniel8dd688b2015-01-22 10:16:09 -0800141class GrPipeline;
joshualittd53a8272014-11-10 16:03:14 -0800142
bsalomon33435572014-11-05 14:47:41 -0800143class MockGpu : public GrGpu {
144public:
145 MockGpu(GrContext* context) : INHERITED(context) { fCaps.reset(SkNEW(GrDrawTargetCaps)); }
bsalomonf90a02b2014-11-26 12:28:00 -0800146 ~MockGpu() SK_OVERRIDE {}
147 bool canWriteTexturePixels(const GrTexture*, GrPixelConfig srcConfig) const SK_OVERRIDE {
bsalomon33435572014-11-05 14:47:41 -0800148 return true;
149 }
150
bsalomonf90a02b2014-11-26 12:28:00 -0800151 bool readPixelsWillPayForYFlip(GrRenderTarget* renderTarget,
152 int left, int top,
153 int width, int height,
154 GrPixelConfig config,
155 size_t rowBytes) const SK_OVERRIDE { return false; }
joshualitt873ad0e2015-01-20 09:08:51 -0800156 void buildProgramDesc(GrProgramDesc*,const GrPrimitiveProcessor&,
egdaniel8dd688b2015-01-22 10:16:09 -0800157 const GrPipeline&,
joshualitt873ad0e2015-01-20 09:08:51 -0800158 const GrBatchTracker&) const SK_OVERRIDE {}
bsalomon33435572014-11-05 14:47:41 -0800159
bsalomonf90a02b2014-11-26 12:28:00 -0800160 void discard(GrRenderTarget*) SK_OVERRIDE {}
bsalomon33435572014-11-05 14:47:41 -0800161
bsalomonf90a02b2014-11-26 12:28:00 -0800162 bool canCopySurface(const GrSurface* dst,
163 const GrSurface* src,
164 const SkIRect& srcRect,
165 const SkIPoint& dstPoint) SK_OVERRIDE { return false; };
joshualitt3322fa42014-11-07 08:48:51 -0800166
bsalomonf90a02b2014-11-26 12:28:00 -0800167 bool copySurface(GrSurface* dst,
168 GrSurface* src,
169 const SkIRect& srcRect,
170 const SkIPoint& dstPoint) SK_OVERRIDE { return false; };
171
172 bool initCopySurfaceDstDesc(const GrSurface* src, GrSurfaceDesc* desc) SK_OVERRIDE {
173 return false;
174 }
joshualitt3322fa42014-11-07 08:48:51 -0800175
bsalomon33435572014-11-05 14:47:41 -0800176private:
bsalomonf90a02b2014-11-26 12:28:00 -0800177 void onResetContext(uint32_t resetBits) SK_OVERRIDE {}
178
bsalomon5236cf42015-01-14 10:42:08 -0800179 GrTexture* onCreateTexture(const GrSurfaceDesc& desc, bool budgeted, const void* srcData,
bsalomonf90a02b2014-11-26 12:28:00 -0800180 size_t rowBytes) SK_OVERRIDE {
bsalomon33435572014-11-05 14:47:41 -0800181 return NULL;
182 }
183
bsalomon5236cf42015-01-14 10:42:08 -0800184 GrTexture* onCreateCompressedTexture(const GrSurfaceDesc& desc, bool budgeted,
bsalomonf90a02b2014-11-26 12:28:00 -0800185 const void* srcData) SK_OVERRIDE {
bsalomon33435572014-11-05 14:47:41 -0800186 return NULL;
187 }
188
bsalomonf90a02b2014-11-26 12:28:00 -0800189 GrTexture* onWrapBackendTexture(const GrBackendTextureDesc&) SK_OVERRIDE { return NULL; }
190
191 GrRenderTarget* onWrapBackendRenderTarget(const GrBackendRenderTargetDesc&) SK_OVERRIDE {
bsalomon33435572014-11-05 14:47:41 -0800192 return NULL;
193 }
194
bsalomonf90a02b2014-11-26 12:28:00 -0800195 GrVertexBuffer* onCreateVertexBuffer(size_t size, bool dynamic) SK_OVERRIDE { return NULL; }
196
197 GrIndexBuffer* onCreateIndexBuffer(size_t size, bool dynamic) SK_OVERRIDE { return NULL; }
198
199 void onClear(GrRenderTarget*, const SkIRect* rect, GrColor color,
200 bool canIgnoreRect) SK_OVERRIDE {}
201
202 void onClearStencilClip(GrRenderTarget*, const SkIRect& rect, bool insideClip) SK_OVERRIDE {}
203
joshualitt873ad0e2015-01-20 09:08:51 -0800204 void onDraw(const DrawArgs&, const GrDrawTarget::DrawInfo&) SK_OVERRIDE {}
bsalomonf90a02b2014-11-26 12:28:00 -0800205
bsalomon3e791242014-12-17 13:43:13 -0800206 void onStencilPath(const GrPath* path, const StencilPathState& state) SK_OVERRIDE {}
bsalomond95263c2014-12-16 13:05:12 -0800207
joshualitt873ad0e2015-01-20 09:08:51 -0800208 void onDrawPath(const DrawArgs&, const GrPath*, const GrStencilSettings&) SK_OVERRIDE {}
bsalomond95263c2014-12-16 13:05:12 -0800209
joshualitt873ad0e2015-01-20 09:08:51 -0800210 void onDrawPaths(const DrawArgs&,
bsalomond95263c2014-12-16 13:05:12 -0800211 const GrPathRange*,
212 const void* indices,
213 GrDrawTarget::PathIndexType,
214 const float transformValues[],
215 GrDrawTarget::PathTransformType,
216 int count,
217 const GrStencilSettings&) SK_OVERRIDE {}
218
bsalomonf90a02b2014-11-26 12:28:00 -0800219 bool onReadPixels(GrRenderTarget* target,
220 int left, int top, int width, int height,
221 GrPixelConfig,
222 void* buffer,
223 size_t rowBytes) SK_OVERRIDE {
224 return false;
bsalomon33435572014-11-05 14:47:41 -0800225 }
226
bsalomonf90a02b2014-11-26 12:28:00 -0800227 bool onWriteTexturePixels(GrTexture* texture,
bsalomon33435572014-11-05 14:47:41 -0800228 int left, int top, int width, int height,
bsalomonf90a02b2014-11-26 12:28:00 -0800229 GrPixelConfig config, const void* buffer,
230 size_t rowBytes) SK_OVERRIDE {
bsalomon33435572014-11-05 14:47:41 -0800231 return false;
232 }
233
bsalomonf90a02b2014-11-26 12:28:00 -0800234 void onResolveRenderTarget(GrRenderTarget* target) SK_OVERRIDE { return; }
235
bsalomon02a44a42015-02-19 09:09:00 -0800236 bool createStencilBufferForRenderTarget(GrRenderTarget*, int width, int height) SK_OVERRIDE {
bsalomon33435572014-11-05 14:47:41 -0800237 return false;
238 }
239
bsalomonf90a02b2014-11-26 12:28:00 -0800240 bool attachStencilBufferToRenderTarget(GrStencilBuffer*, GrRenderTarget*) SK_OVERRIDE {
bsalomon33435572014-11-05 14:47:41 -0800241 return false;
242 }
243
bsalomonf90a02b2014-11-26 12:28:00 -0800244 void clearStencil(GrRenderTarget* target) SK_OVERRIDE {}
bsalomon33435572014-11-05 14:47:41 -0800245
bsalomond95263c2014-12-16 13:05:12 -0800246 void didAddGpuTraceMarker() SK_OVERRIDE {}
bsalomon33435572014-11-05 14:47:41 -0800247
bsalomond95263c2014-12-16 13:05:12 -0800248 void didRemoveGpuTraceMarker() SK_OVERRIDE {}
bsalomon33435572014-11-05 14:47:41 -0800249
250 typedef GrGpu INHERITED;
251};
252
253GrContext* GrContext::CreateMockContext() {
254 GrContext* context = SkNEW_ARGS(GrContext, (Options()));
255
256 context->initMockContext();
257 return context;
258}
259
260void GrContext::initMockContext() {
261 SkASSERT(NULL == fGpu);
262 fGpu = SkNEW_ARGS(MockGpu, (this));
263 SkASSERT(fGpu);
264 this->initCommon();
265
266 // We delete these because we want to test the cache starting with zero resources. Also, none of
267 // these objects are required for any of tests that use this context. TODO: make stop allocating
268 // resources in the buffer pools.
269 SkDELETE(fDrawBuffer);
270 SkDELETE(fDrawBufferVBAllocPool);
271 SkDELETE(fDrawBufferIBAllocPool);
272
273 fDrawBuffer = NULL;
274 fDrawBufferVBAllocPool = NULL;
275 fDrawBufferIBAllocPool = NULL;
276}