blob: 32ac0c71e6b4205ed47b9531a478927d7c529ded [file] [log] [blame]
bsalomon@google.com686bcb82013-04-09 15:04:12 +00001/*
2 * Copyright 2013 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
bsalomona2c23232014-11-25 07:41:12 -08008#include "SkTypes.h"
9
bsalomon@google.com686bcb82013-04-09 15:04:12 +000010#if SK_SUPPORT_GPU
11
bsalomon@google.com686bcb82013-04-09 15:04:12 +000012#include "GrContext.h"
Greg Daniel7ef28f32017-04-20 16:41:55 +000013#include "GrContextPriv.h"
bsalomon091f60c2015-11-10 11:54:56 -080014#include "GrGpu.h"
Robert Phillips0bd24dc2018-01-16 08:06:32 -050015#include "GrProxyProvider.h"
Robert Phillips2890fbf2017-07-26 15:48:41 -040016#include "GrRenderTarget.h"
Brian Osman32342f02017-03-04 08:12:46 -050017#include "GrResourceProvider.h"
Greg Daniel7ef28f32017-04-20 16:41:55 +000018#include "GrTest.h"
bsalomon@google.com686bcb82013-04-09 15:04:12 +000019#include "GrTexture.h"
Brian Osman48c99192017-06-02 08:45:06 -040020#include "SkMipMap.h"
tfarina@chromium.org4ee16bf2014-01-10 22:08:27 +000021#include "Test.h"
bsalomon@google.com686bcb82013-04-09 15:04:12 +000022
bsalomona2c23232014-11-25 07:41:12 -080023// Tests that GrSurface::asTexture(), GrSurface::asRenderTarget(), and static upcasting of texture
24// and render targets to GrSurface all work as expected.
bsalomon758586c2016-04-06 14:02:39 -070025DEF_GPUTEST_FOR_NULLGL_CONTEXT(GrSurface, reporter, ctxInfo) {
bsalomon8b7451a2016-05-11 06:33:06 -070026 GrContext* context = ctxInfo.grContext();
Robert Phillips6be756b2018-01-16 15:07:54 -050027 auto resourceProvider = context->contextPriv().resourceProvider();
Robert Phillipsf35fd8d2018-01-22 10:48:15 -050028 GrGpu* gpu = context->contextPriv().getGpu();
Robert Phillips6be756b2018-01-16 15:07:54 -050029
kkinnunen15302832015-12-01 04:35:26 -080030 GrSurfaceDesc desc;
kkinnunen15302832015-12-01 04:35:26 -080031 desc.fFlags = kRenderTarget_GrSurfaceFlag;
Robert Phillips16d8ec62017-07-27 16:16:25 -040032 desc.fOrigin = kBottomLeft_GrSurfaceOrigin;
kkinnunen15302832015-12-01 04:35:26 -080033 desc.fWidth = 256;
34 desc.fHeight = 256;
Robert Phillips16d8ec62017-07-27 16:16:25 -040035 desc.fConfig = kRGBA_8888_GrPixelConfig;
Brian Salomonbdecacf2018-02-02 20:32:49 -050036 desc.fSampleCnt = 1;
Robert Phillips6be756b2018-01-16 15:07:54 -050037 sk_sp<GrSurface> texRT1 = resourceProvider->createTexture(desc, SkBudgeted::kNo);
bsalomona2c23232014-11-25 07:41:12 -080038
Robert Phillipse78b7252017-04-06 07:59:41 -040039 REPORTER_ASSERT(reporter, texRT1.get() == texRT1->asRenderTarget());
40 REPORTER_ASSERT(reporter, texRT1.get() == texRT1->asTexture());
kkinnunen15302832015-12-01 04:35:26 -080041 REPORTER_ASSERT(reporter, static_cast<GrSurface*>(texRT1->asRenderTarget()) ==
42 texRT1->asTexture());
43 REPORTER_ASSERT(reporter, texRT1->asRenderTarget() ==
44 static_cast<GrSurface*>(texRT1->asTexture()));
45 REPORTER_ASSERT(reporter, static_cast<GrSurface*>(texRT1->asRenderTarget()) ==
46 static_cast<GrSurface*>(texRT1->asTexture()));
bsalomona2c23232014-11-25 07:41:12 -080047
kkinnunen15302832015-12-01 04:35:26 -080048 desc.fFlags = kNone_GrSurfaceFlags;
Robert Phillips16d8ec62017-07-27 16:16:25 -040049 desc.fOrigin = kTopLeft_GrSurfaceOrigin;
Robert Phillips6be756b2018-01-16 15:07:54 -050050 sk_sp<GrTexture> tex1 = resourceProvider->createTexture(desc, SkBudgeted::kNo);
kkinnunen15302832015-12-01 04:35:26 -080051 REPORTER_ASSERT(reporter, nullptr == tex1->asRenderTarget());
Robert Phillipse78b7252017-04-06 07:59:41 -040052 REPORTER_ASSERT(reporter, tex1.get() == tex1->asTexture());
53 REPORTER_ASSERT(reporter, static_cast<GrSurface*>(tex1.get()) == tex1->asTexture());
bsalomon@google.com686bcb82013-04-09 15:04:12 +000054
Robert Phillipsf35fd8d2018-01-22 10:48:15 -050055 GrBackendTexture backendTex = gpu->createTestingOnlyBackendTexture(
Robert Phillipsd21b2a52017-12-12 13:01:25 -050056 nullptr, 256, 256, kRGBA_8888_GrPixelConfig, false, GrMipMapped::kNo);
bsalomon091f60c2015-11-10 11:54:56 -080057
Brian Salomonbdecacf2018-02-02 20:32:49 -050058 sk_sp<GrSurface> texRT2 =
59 resourceProvider->wrapRenderableBackendTexture(backendTex, 1, kBorrow_GrWrapOwnership);
Greg Daniel7ef28f32017-04-20 16:41:55 +000060
bungeman6bd52842016-10-27 09:30:08 -070061 REPORTER_ASSERT(reporter, texRT2.get() == texRT2->asRenderTarget());
62 REPORTER_ASSERT(reporter, texRT2.get() == texRT2->asTexture());
kkinnunen15302832015-12-01 04:35:26 -080063 REPORTER_ASSERT(reporter, static_cast<GrSurface*>(texRT2->asRenderTarget()) ==
64 texRT2->asTexture());
65 REPORTER_ASSERT(reporter, texRT2->asRenderTarget() ==
66 static_cast<GrSurface*>(texRT2->asTexture()));
67 REPORTER_ASSERT(reporter, static_cast<GrSurface*>(texRT2->asRenderTarget()) ==
68 static_cast<GrSurface*>(texRT2->asTexture()));
bsalomon@google.com686bcb82013-04-09 15:04:12 +000069
Robert Phillipsf35fd8d2018-01-22 10:48:15 -050070 gpu->deleteTestingOnlyBackendTexture(&backendTex);
bsalomon@google.com686bcb82013-04-09 15:04:12 +000071}
72
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -040073// This test checks that the isConfigTexturable and isConfigRenderable are
74// consistent with createTexture's result.
75DEF_GPUTEST_FOR_ALL_CONTEXTS(GrSurfaceRenderability, reporter, ctxInfo) {
76 GrContext* context = ctxInfo.grContext();
Robert Phillips1afd4cd2018-01-08 13:40:32 -050077 GrProxyProvider* proxyProvider = context->contextPriv().proxyProvider();
Robert Phillips6be756b2018-01-16 15:07:54 -050078 GrResourceProvider* resourceProvider = context->contextPriv().resourceProvider();
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -040079 const GrCaps* caps = context->caps();
80
81 GrPixelConfig configs[] = {
82 kUnknown_GrPixelConfig,
83 kAlpha_8_GrPixelConfig,
Greg Danielef59d872017-11-17 16:47:21 -050084 kAlpha_8_as_Alpha_GrPixelConfig,
85 kAlpha_8_as_Red_GrPixelConfig,
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -040086 kGray_8_GrPixelConfig,
Greg Daniel7af060a2017-12-05 16:27:11 -050087 kGray_8_as_Lum_GrPixelConfig,
88 kGray_8_as_Red_GrPixelConfig,
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -040089 kRGB_565_GrPixelConfig,
90 kRGBA_4444_GrPixelConfig,
91 kRGBA_8888_GrPixelConfig,
92 kBGRA_8888_GrPixelConfig,
93 kSRGBA_8888_GrPixelConfig,
94 kSBGRA_8888_GrPixelConfig,
95 kRGBA_8888_sint_GrPixelConfig,
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -040096 kRGBA_float_GrPixelConfig,
97 kRG_float_GrPixelConfig,
98 kAlpha_half_GrPixelConfig,
Greg Danielef59d872017-11-17 16:47:21 -050099 kAlpha_half_as_Red_GrPixelConfig,
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400100 kRGBA_half_GrPixelConfig,
101 };
102 SkASSERT(kGrPixelConfigCnt == SK_ARRAY_COUNT(configs));
103
104 GrSurfaceDesc desc;
105 desc.fWidth = 64;
106 desc.fHeight = 64;
107
Brian Osman48c99192017-06-02 08:45:06 -0400108 // Enough space for the first mip of our largest pixel config
109 const size_t pixelBufferSize = desc.fWidth * desc.fHeight *
110 GrBytesPerPixel(kRGBA_float_GrPixelConfig);
111 std::unique_ptr<char[]> pixelData(new char[pixelBufferSize]);
112 memset(pixelData.get(), 0, pixelBufferSize);
113
114 // We re-use the same mip level objects (with updated pointers and rowBytes) for each config
115 const int levelCount = SkMipMap::ComputeLevelCount(desc.fWidth, desc.fHeight) + 1;
116 std::unique_ptr<GrMipLevel[]> texels(new GrMipLevel[levelCount]);
117
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400118 for (GrPixelConfig config : configs) {
119 for (GrSurfaceOrigin origin : { kTopLeft_GrSurfaceOrigin, kBottomLeft_GrSurfaceOrigin }) {
120 desc.fFlags = kNone_GrSurfaceFlags;
121 desc.fOrigin = origin;
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400122 desc.fConfig = config;
Brian Salomonbdecacf2018-02-02 20:32:49 -0500123 desc.fSampleCnt = 1;
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400124
Robert Phillips3b3307f2017-05-24 07:44:02 -0400125 sk_sp<GrSurface> tex = resourceProvider->createTexture(desc, SkBudgeted::kNo);
Brian Salomon1c80e992018-01-29 09:50:47 -0500126 bool ict = caps->isConfigTexturable(desc.fConfig);
127 REPORTER_ASSERT(reporter, SkToBool(tex) == ict,
128 "config:%d, tex:%d, isConfigTexturable:%d", config, SkToBool(tex), ict);
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400129
Brian Osman48c99192017-06-02 08:45:06 -0400130 size_t rowBytes = desc.fWidth * GrBytesPerPixel(desc.fConfig);
131 for (int i = 0; i < levelCount; ++i) {
132 texels[i].fPixels = pixelData.get();
133 texels[i].fRowBytes = rowBytes >> i;
134 }
Robert Phillips0bd24dc2018-01-16 08:06:32 -0500135
136 sk_sp<GrTextureProxy> proxy = proxyProvider->createMipMapProxy(
137 desc, SkBudgeted::kNo,
138 texels.get(), levelCount);
Brian Osman48c99192017-06-02 08:45:06 -0400139 REPORTER_ASSERT(reporter, SkToBool(proxy.get()) ==
140 (caps->isConfigTexturable(desc.fConfig) &&
141 caps->mipMapSupport() &&
142 !GrPixelConfigIsSint(desc.fConfig)));
143
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400144 desc.fFlags = kRenderTarget_GrSurfaceFlag;
Robert Phillips3b3307f2017-05-24 07:44:02 -0400145 tex = resourceProvider->createTexture(desc, SkBudgeted::kNo);
Brian Salomonbdecacf2018-02-02 20:32:49 -0500146 bool isRenderable = caps->isConfigRenderable(config);
147 REPORTER_ASSERT(reporter, SkToBool(tex) == isRenderable,
148 "config:%d, tex:%d, isRenderable:%d", config, SkToBool(tex),
149 isRenderable);
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400150
Brian Salomonbdecacf2018-02-02 20:32:49 -0500151 desc.fSampleCnt = 2;
Robert Phillips3b3307f2017-05-24 07:44:02 -0400152 tex = resourceProvider->createTexture(desc, SkBudgeted::kNo);
Brian Salomonbdecacf2018-02-02 20:32:49 -0500153 isRenderable = SkToBool(caps->getRenderTargetSampleCount(2, config));
154 REPORTER_ASSERT(reporter, SkToBool(tex) == isRenderable,
155 "config:%d, tex:%d, isRenderable:%d", config, SkToBool(tex),
156 isRenderable);
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400157 }
158 }
159}
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400160
Brian Salomond17b4a62017-05-23 16:53:47 -0400161#include "GrDrawingManager.h"
162#include "GrSurfaceProxy.h"
163#include "GrTextureContext.h"
164
165DEF_GPUTEST_FOR_RENDERING_CONTEXTS(InitialTextureClear, reporter, context_info) {
166 static constexpr int kSize = 100;
167 GrSurfaceDesc desc;
168 desc.fWidth = desc.fHeight = kSize;
169 std::unique_ptr<uint32_t[]> data(new uint32_t[kSize * kSize]);
Robert Phillips0bd24dc2018-01-16 08:06:32 -0500170
Brian Salomond17b4a62017-05-23 16:53:47 -0400171 GrContext* context = context_info.grContext();
Robert Phillips0bd24dc2018-01-16 08:06:32 -0500172 GrProxyProvider* proxyProvider = context->contextPriv().proxyProvider();
173
Brian Salomond17b4a62017-05-23 16:53:47 -0400174 for (int c = 0; c <= kLast_GrPixelConfig; ++c) {
175 desc.fConfig = static_cast<GrPixelConfig>(c);
176 if (!context_info.grContext()->caps()->isConfigTexturable(desc.fConfig)) {
177 continue;
178 }
179 desc.fFlags = kPerformInitialClear_GrSurfaceFlag;
180 for (bool rt : {false, true}) {
Brian Salomonbdecacf2018-02-02 20:32:49 -0500181 if (rt && !context->caps()->isConfigRenderable(desc.fConfig)) {
Brian Salomond17b4a62017-05-23 16:53:47 -0400182 continue;
183 }
184 desc.fFlags |= rt ? kRenderTarget_GrSurfaceFlag : kNone_GrSurfaceFlags;
Greg Daniel90f28ec2017-09-25 12:26:58 -0400185 for (GrSurfaceOrigin origin :
186 {kTopLeft_GrSurfaceOrigin, kBottomLeft_GrSurfaceOrigin}) {
187 desc.fOrigin = origin;
Robert Phillips0bd24dc2018-01-16 08:06:32 -0500188 for (auto fit : { SkBackingFit::kApprox, SkBackingFit::kExact }) {
Greg Daniel90f28ec2017-09-25 12:26:58 -0400189 // Try directly creating the texture.
190 // Do this twice in an attempt to hit the cache on the second time through.
191 for (int i = 0; i < 2; ++i) {
Robert Phillips0bd24dc2018-01-16 08:06:32 -0500192 sk_sp<GrTextureProxy> proxy = proxyProvider->createInstantiatedProxy(
193 desc, fit, SkBudgeted::kYes);
194 if (!proxy) {
Greg Daniel90f28ec2017-09-25 12:26:58 -0400195 continue;
196 }
Robert Phillips0bd24dc2018-01-16 08:06:32 -0500197
Greg Daniel90f28ec2017-09-25 12:26:58 -0400198 auto texCtx = context->contextPriv().makeWrappedSurfaceContext(
Robert Phillipsd5f9cdd2018-01-31 09:29:48 -0500199 std::move(proxy));
Greg Daniel90f28ec2017-09-25 12:26:58 -0400200 SkImageInfo info = SkImageInfo::Make(
201 kSize, kSize, kRGBA_8888_SkColorType, kPremul_SkAlphaType);
202 memset(data.get(), 0xAB, kSize * kSize * sizeof(uint32_t));
203 if (texCtx->readPixels(info, data.get(), 0, 0, 0)) {
204 uint32_t cmp = GrPixelConfigIsOpaque(desc.fConfig) ? 0xFF000000 : 0;
205 for (int i = 0; i < kSize * kSize; ++i) {
206 if (cmp != data.get()[i]) {
207 ERRORF(reporter, "Failed on config %d", desc.fConfig);
208 break;
Brian Salomond17b4a62017-05-23 16:53:47 -0400209 }
210 }
Brian Salomond17b4a62017-05-23 16:53:47 -0400211 }
Greg Daniel90f28ec2017-09-25 12:26:58 -0400212 memset(data.get(), 0xBC, kSize * kSize * sizeof(uint32_t));
213 // Here we overwrite the texture so that the second time through we
214 // test against recycling without reclearing.
215 if (0 == i) {
216 texCtx->writePixels(info, data.get(), 0, 0, 0);
Greg Daniel52cb5fe2017-09-05 15:45:15 -0400217 }
Greg Daniel52cb5fe2017-09-05 15:45:15 -0400218 }
Greg Daniel90f28ec2017-09-25 12:26:58 -0400219 context->purgeAllUnlockedResources();
220
221 // Try creating the texture as a deferred proxy.
222 for (int i = 0; i < 2; ++i) {
223 auto surfCtx = context->contextPriv().makeDeferredSurfaceContext(
Robert Phillips0bd24dc2018-01-16 08:06:32 -0500224 desc, GrMipMapped::kNo, fit, SkBudgeted::kYes);
Greg Daniel90f28ec2017-09-25 12:26:58 -0400225 if (!surfCtx) {
226 continue;
227 }
228 SkImageInfo info = SkImageInfo::Make(
229 kSize, kSize, kRGBA_8888_SkColorType, kPremul_SkAlphaType);
230 memset(data.get(), 0xAB, kSize * kSize * sizeof(uint32_t));
231 if (surfCtx->readPixels(info, data.get(), 0, 0, 0)) {
232 uint32_t cmp = GrPixelConfigIsOpaque(desc.fConfig) ? 0xFF000000 : 0;
233 for (int i = 0; i < kSize * kSize; ++i) {
234 if (cmp != data.get()[i]) {
235 ERRORF(reporter, "Failed on config %d", desc.fConfig);
236 break;
237 }
238 }
239 }
240 // Here we overwrite the texture so that the second time through we
241 // test against recycling without reclearing.
242 if (0 == i) {
243 surfCtx->writePixels(info, data.get(), 0, 0, 0);
244 }
245 }
246 context->purgeAllUnlockedResources();
Brian Salomond17b4a62017-05-23 16:53:47 -0400247 }
248 }
249 }
250 }
251}
bsalomon@google.com686bcb82013-04-09 15:04:12 +0000252#endif