blob: 9279ef689559edf2eeb2edaee93f9c4008f3e9ac [file] [log] [blame]
jvanverthfd359ca2016-03-18 11:57:24 -07001/*
2 * Copyright 2016 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
8// This is a GPU-backend specific test. It relies on static intializers to work
9
10#include "SkTypes.h"
11
12#if SK_SUPPORT_GPU && SK_ALLOW_STATIC_GLOBAL_INITIALIZERS && defined(SK_VULKAN)
13
14#include "GrContextFactory.h"
15#include "GrTest.h"
16#include "Test.h"
17#include "vk/GrVkCaps.h"
18#include "vk/GrVkGpu.h"
19#include "vk/GrVkMemory.h"
20#include "vk/GrVkTypes.h"
21
kkinnunen2ae4b2e2016-03-31 08:08:20 -070022using sk_gpu_test::GrContextFactory;
23
jvanverthfd359ca2016-03-18 11:57:24 -070024const int kW = 1024;
25const int kH = 1024;
26const GrPixelConfig kPixelConfig = kRGBA_8888_GrPixelConfig;
27
28void wrap_tex_test(skiatest::Reporter* reporter, GrContext* context) {
29
30 GrVkGpu* gpu = static_cast<GrVkGpu*>(context->getGpu());
31
egdaniel0a3a7f72016-06-24 09:22:31 -070032 GrBackendObject backendObj = gpu->createTestingOnlyBackendTexture(nullptr, kW, kH, kPixelConfig,
33 false);
Stan Iliev7fa5c312017-04-19 00:23:39 +000034 const GrVkImageInfo* backendTex = reinterpret_cast<const GrVkImageInfo*>(backendObj);
jvanverthfd359ca2016-03-18 11:57:24 -070035
Stan Iliev7fa5c312017-04-19 00:23:39 +000036 // check basic borrowed creation
37 GrBackendTextureDesc desc;
38 desc.fConfig = kPixelConfig;
39 desc.fWidth = kW;
40 desc.fHeight = kH;
41 desc.fTextureHandle = backendObj;
42 sk_sp<GrTexture> tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -070043 REPORTER_ASSERT(reporter, tex);
jvanverthfd359ca2016-03-18 11:57:24 -070044
45 // image is null
Stan Iliev7fa5c312017-04-19 00:23:39 +000046 GrVkImageInfo backendCopy = *backendTex;
jvanverthfd359ca2016-03-18 11:57:24 -070047 backendCopy.fImage = VK_NULL_HANDLE;
Stan Iliev7fa5c312017-04-19 00:23:39 +000048 desc.fTextureHandle = (GrBackendObject) &backendCopy;
49 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -070050 REPORTER_ASSERT(reporter, !tex);
Stan Iliev7fa5c312017-04-19 00:23:39 +000051 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -070052 REPORTER_ASSERT(reporter, !tex);
53
54 // alloc is null
Stan Iliev7fa5c312017-04-19 00:23:39 +000055 backendCopy.fImage = backendTex->fImage;
jvanverth65b8cb02016-09-20 13:18:00 -070056 backendCopy.fAlloc = { VK_NULL_HANDLE, 0, 0, 0 };
Stan Iliev7fa5c312017-04-19 00:23:39 +000057 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -070058 REPORTER_ASSERT(reporter, !tex);
Stan Iliev7fa5c312017-04-19 00:23:39 +000059 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -070060 REPORTER_ASSERT(reporter, !tex);
Greg Daniel7da62b92017-04-18 17:12:32 -040061
Stan Iliev7fa5c312017-04-19 00:23:39 +000062 // check adopt creation
63 backendCopy.fAlloc = backendTex->fAlloc;
64 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -070065 REPORTER_ASSERT(reporter, tex);
jvanverthfd359ca2016-03-18 11:57:24 -070066
67 gpu->deleteTestingOnlyBackendTexture(backendObj, true);
68}
69
70void wrap_rt_test(skiatest::Reporter* reporter, GrContext* context) {
71 GrVkGpu* gpu = static_cast<GrVkGpu*>(context->getGpu());
72
egdaniel0a3a7f72016-06-24 09:22:31 -070073 GrBackendObject backendObj = gpu->createTestingOnlyBackendTexture(nullptr, kW, kH, kPixelConfig,
74 true);
egdanielb2df0c22016-05-13 11:30:37 -070075 const GrVkImageInfo* backendTex = reinterpret_cast<const GrVkImageInfo*>(backendObj);
jvanverthfd359ca2016-03-18 11:57:24 -070076
77 // check basic borrowed creation
78 GrBackendRenderTargetDesc desc;
79 desc.fWidth = kW;
80 desc.fHeight = kH;
81 desc.fConfig = kPixelConfig;
82 desc.fOrigin = kTopLeft_GrSurfaceOrigin;
83 desc.fSampleCnt = 0;
84 desc.fStencilBits = 0;
85 desc.fRenderTargetHandle = backendObj;
Brian Osman0b791f52017-03-10 08:30:22 -050086 sk_sp<GrRenderTarget> rt = gpu->wrapBackendRenderTarget(desc);
jvanverthfd359ca2016-03-18 11:57:24 -070087 REPORTER_ASSERT(reporter, rt);
jvanverthfd359ca2016-03-18 11:57:24 -070088
89 // image is null
egdanielb2df0c22016-05-13 11:30:37 -070090 GrVkImageInfo backendCopy = *backendTex;
jvanverthfd359ca2016-03-18 11:57:24 -070091 backendCopy.fImage = VK_NULL_HANDLE;
92 desc.fRenderTargetHandle = (GrBackendObject)&backendCopy;
Brian Osman0b791f52017-03-10 08:30:22 -050093 rt = gpu->wrapBackendRenderTarget(desc);
jvanverthfd359ca2016-03-18 11:57:24 -070094 REPORTER_ASSERT(reporter, !rt);
95
96 // alloc is null
97 backendCopy.fImage = backendTex->fImage;
jvanverth65b8cb02016-09-20 13:18:00 -070098 backendCopy.fAlloc = { VK_NULL_HANDLE, 0, 0, 0 };
Brian Osman0b791f52017-03-10 08:30:22 -050099 // can wrap null alloc
100 rt = gpu->wrapBackendRenderTarget(desc);
jvanverthfd359ca2016-03-18 11:57:24 -0700101 REPORTER_ASSERT(reporter, rt);
jvanverthfd359ca2016-03-18 11:57:24 -0700102
Greg Danielaf401272017-03-27 16:18:03 -0400103 // When we wrapBackendRenderTarget it is always borrowed, so we must make sure to free the
104 // resource when we're done.
105 gpu->deleteTestingOnlyBackendTexture(backendObj, false);
jvanverthfd359ca2016-03-18 11:57:24 -0700106}
107
108void wrap_trt_test(skiatest::Reporter* reporter, GrContext* context) {
109 GrVkGpu* gpu = static_cast<GrVkGpu*>(context->getGpu());
110
egdaniel0a3a7f72016-06-24 09:22:31 -0700111 GrBackendObject backendObj = gpu->createTestingOnlyBackendTexture(nullptr, kW, kH, kPixelConfig,
112 true);
Stan Iliev7fa5c312017-04-19 00:23:39 +0000113 const GrVkImageInfo* backendTex = reinterpret_cast<const GrVkImageInfo*>(backendObj);
jvanverthfd359ca2016-03-18 11:57:24 -0700114
Stan Iliev7fa5c312017-04-19 00:23:39 +0000115 // check basic borrowed creation
116 GrBackendTextureDesc desc;
117 desc.fFlags = kRenderTarget_GrBackendTextureFlag;
118 desc.fConfig = kPixelConfig;
119 desc.fWidth = kW;
120 desc.fHeight = kH;
121 desc.fTextureHandle = backendObj;
122 sk_sp<GrTexture> tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -0700123 REPORTER_ASSERT(reporter, tex);
jvanverthfd359ca2016-03-18 11:57:24 -0700124
125 // image is null
Stan Iliev7fa5c312017-04-19 00:23:39 +0000126 GrVkImageInfo backendCopy = *backendTex;
jvanverthfd359ca2016-03-18 11:57:24 -0700127 backendCopy.fImage = VK_NULL_HANDLE;
Stan Iliev7fa5c312017-04-19 00:23:39 +0000128 desc.fTextureHandle = (GrBackendObject)&backendCopy;
129 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -0700130 REPORTER_ASSERT(reporter, !tex);
Stan Iliev7fa5c312017-04-19 00:23:39 +0000131 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -0700132 REPORTER_ASSERT(reporter, !tex);
133
134 // alloc is null
Stan Iliev7fa5c312017-04-19 00:23:39 +0000135 backendCopy.fImage = backendTex->fImage;
jvanverth65b8cb02016-09-20 13:18:00 -0700136 backendCopy.fAlloc = { VK_NULL_HANDLE, 0, 0, 0 };
Stan Iliev7fa5c312017-04-19 00:23:39 +0000137 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -0700138 REPORTER_ASSERT(reporter, !tex);
Stan Iliev7fa5c312017-04-19 00:23:39 +0000139 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -0700140 REPORTER_ASSERT(reporter, !tex);
141
142 // check adopt creation
Stan Iliev7fa5c312017-04-19 00:23:39 +0000143 backendCopy.fAlloc = backendTex->fAlloc;
144 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -0700145 REPORTER_ASSERT(reporter, tex);
jvanverthfd359ca2016-03-18 11:57:24 -0700146
147 gpu->deleteTestingOnlyBackendTexture(backendObj, true);
148}
149
bsalomondc0fcd42016-04-11 14:21:33 -0700150DEF_GPUTEST_FOR_VULKAN_CONTEXT(VkWrapTests, reporter, ctxInfo) {
bsalomon8b7451a2016-05-11 06:33:06 -0700151 wrap_tex_test(reporter, ctxInfo.grContext());
152 wrap_rt_test(reporter, ctxInfo.grContext());
153 wrap_trt_test(reporter, ctxInfo.grContext());
jvanverthfd359ca2016-03-18 11:57:24 -0700154}
155
156#endif