blob: 58c4b356c62230e065a3393eb75d2e3439cd67dd [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);
egdanielb2df0c22016-05-13 11:30:37 -070034 const GrVkImageInfo* backendTex = reinterpret_cast<const GrVkImageInfo*>(backendObj);
jvanverthfd359ca2016-03-18 11:57:24 -070035
36 // check basic borrowed creation
37 GrBackendTextureDesc desc;
38 desc.fConfig = kPixelConfig;
39 desc.fWidth = kW;
40 desc.fHeight = kH;
41 desc.fTextureHandle = backendObj;
bungeman6bd52842016-10-27 09:30:08 -070042 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
egdanielb2df0c22016-05-13 11:30:37 -070046 GrVkImageInfo backendCopy = *backendTex;
jvanverthfd359ca2016-03-18 11:57:24 -070047 backendCopy.fImage = VK_NULL_HANDLE;
48 desc.fTextureHandle = (GrBackendObject) &backendCopy;
49 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
50 REPORTER_ASSERT(reporter, !tex);
51 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
52 REPORTER_ASSERT(reporter, !tex);
53
54 // alloc is null
55 backendCopy.fImage = backendTex->fImage;
jvanverth65b8cb02016-09-20 13:18:00 -070056 backendCopy.fAlloc = { VK_NULL_HANDLE, 0, 0, 0 };
jvanverthfd359ca2016-03-18 11:57:24 -070057 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
58 REPORTER_ASSERT(reporter, !tex);
59 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
60 REPORTER_ASSERT(reporter, !tex);
61
62 // check adopt creation
63 backendCopy.fAlloc = backendTex->fAlloc;
64 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
65 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;
bungeman6bd52842016-10-27 09:30:08 -070086 sk_sp<GrRenderTarget> rt = gpu->wrapBackendRenderTarget(desc, kBorrow_GrWrapOwnership);
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;
93 rt = gpu->wrapBackendRenderTarget(desc, kBorrow_GrWrapOwnership);
94 REPORTER_ASSERT(reporter, !rt);
95 rt = gpu->wrapBackendRenderTarget(desc, kAdopt_GrWrapOwnership);
96 REPORTER_ASSERT(reporter, !rt);
97
98 // alloc is null
99 backendCopy.fImage = backendTex->fImage;
jvanverth65b8cb02016-09-20 13:18:00 -0700100 backendCopy.fAlloc = { VK_NULL_HANDLE, 0, 0, 0 };
jvanverthfd359ca2016-03-18 11:57:24 -0700101 // can wrap null alloc if borrowing
102 rt = gpu->wrapBackendRenderTarget(desc, kBorrow_GrWrapOwnership);
103 REPORTER_ASSERT(reporter, rt);
104 // but not if adopting
105 rt = gpu->wrapBackendRenderTarget(desc, kAdopt_GrWrapOwnership);
106 REPORTER_ASSERT(reporter, !rt);
107
108 // check adopt creation
109 backendCopy.fAlloc = backendTex->fAlloc;
110 rt = gpu->wrapBackendRenderTarget(desc, kAdopt_GrWrapOwnership);
111 REPORTER_ASSERT(reporter, rt);
jvanverthfd359ca2016-03-18 11:57:24 -0700112
113 gpu->deleteTestingOnlyBackendTexture(backendObj, true);
114}
115
116void wrap_trt_test(skiatest::Reporter* reporter, GrContext* context) {
117 GrVkGpu* gpu = static_cast<GrVkGpu*>(context->getGpu());
118
egdaniel0a3a7f72016-06-24 09:22:31 -0700119 GrBackendObject backendObj = gpu->createTestingOnlyBackendTexture(nullptr, kW, kH, kPixelConfig,
120 true);
egdanielb2df0c22016-05-13 11:30:37 -0700121 const GrVkImageInfo* backendTex = reinterpret_cast<const GrVkImageInfo*>(backendObj);
jvanverthfd359ca2016-03-18 11:57:24 -0700122
123 // check basic borrowed creation
124 GrBackendTextureDesc desc;
125 desc.fFlags = kRenderTarget_GrBackendTextureFlag;
126 desc.fConfig = kPixelConfig;
127 desc.fWidth = kW;
128 desc.fHeight = kH;
129 desc.fTextureHandle = backendObj;
bungeman6bd52842016-10-27 09:30:08 -0700130 sk_sp<GrTexture> tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -0700131 REPORTER_ASSERT(reporter, tex);
jvanverthfd359ca2016-03-18 11:57:24 -0700132
133 // image is null
egdanielb2df0c22016-05-13 11:30:37 -0700134 GrVkImageInfo backendCopy = *backendTex;
jvanverthfd359ca2016-03-18 11:57:24 -0700135 backendCopy.fImage = VK_NULL_HANDLE;
136 desc.fTextureHandle = (GrBackendObject)&backendCopy;
137 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
138 REPORTER_ASSERT(reporter, !tex);
139 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
140 REPORTER_ASSERT(reporter, !tex);
141
142 // alloc is null
143 backendCopy.fImage = backendTex->fImage;
jvanverth65b8cb02016-09-20 13:18:00 -0700144 backendCopy.fAlloc = { VK_NULL_HANDLE, 0, 0, 0 };
jvanverthfd359ca2016-03-18 11:57:24 -0700145 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
146 REPORTER_ASSERT(reporter, !tex);
147 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
148 REPORTER_ASSERT(reporter, !tex);
149
150 // check adopt creation
151 backendCopy.fAlloc = backendTex->fAlloc;
152 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
153 REPORTER_ASSERT(reporter, tex);
jvanverthfd359ca2016-03-18 11:57:24 -0700154
155 gpu->deleteTestingOnlyBackendTexture(backendObj, true);
156}
157
bsalomondc0fcd42016-04-11 14:21:33 -0700158DEF_GPUTEST_FOR_VULKAN_CONTEXT(VkWrapTests, reporter, ctxInfo) {
bsalomon8b7451a2016-05-11 06:33:06 -0700159 wrap_tex_test(reporter, ctxInfo.grContext());
160 wrap_rt_test(reporter, ctxInfo.grContext());
161 wrap_trt_test(reporter, ctxInfo.grContext());
jvanverthfd359ca2016-03-18 11:57:24 -0700162}
163
164#endif