blob: 7de31602f331b9367fbe33e4a654e6c77c6a3e20 [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;
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
103 gpu->deleteTestingOnlyBackendTexture(backendObj, true);
104}
105
106void wrap_trt_test(skiatest::Reporter* reporter, GrContext* context) {
107 GrVkGpu* gpu = static_cast<GrVkGpu*>(context->getGpu());
108
egdaniel0a3a7f72016-06-24 09:22:31 -0700109 GrBackendObject backendObj = gpu->createTestingOnlyBackendTexture(nullptr, kW, kH, kPixelConfig,
110 true);
egdanielb2df0c22016-05-13 11:30:37 -0700111 const GrVkImageInfo* backendTex = reinterpret_cast<const GrVkImageInfo*>(backendObj);
jvanverthfd359ca2016-03-18 11:57:24 -0700112
113 // check basic borrowed creation
114 GrBackendTextureDesc desc;
115 desc.fFlags = kRenderTarget_GrBackendTextureFlag;
116 desc.fConfig = kPixelConfig;
117 desc.fWidth = kW;
118 desc.fHeight = kH;
119 desc.fTextureHandle = backendObj;
bungeman6bd52842016-10-27 09:30:08 -0700120 sk_sp<GrTexture> tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
jvanverthfd359ca2016-03-18 11:57:24 -0700121 REPORTER_ASSERT(reporter, tex);
jvanverthfd359ca2016-03-18 11:57:24 -0700122
123 // image is null
egdanielb2df0c22016-05-13 11:30:37 -0700124 GrVkImageInfo backendCopy = *backendTex;
jvanverthfd359ca2016-03-18 11:57:24 -0700125 backendCopy.fImage = VK_NULL_HANDLE;
126 desc.fTextureHandle = (GrBackendObject)&backendCopy;
127 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
128 REPORTER_ASSERT(reporter, !tex);
129 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
130 REPORTER_ASSERT(reporter, !tex);
131
132 // alloc is null
133 backendCopy.fImage = backendTex->fImage;
jvanverth65b8cb02016-09-20 13:18:00 -0700134 backendCopy.fAlloc = { VK_NULL_HANDLE, 0, 0, 0 };
jvanverthfd359ca2016-03-18 11:57:24 -0700135 tex = gpu->wrapBackendTexture(desc, kBorrow_GrWrapOwnership);
136 REPORTER_ASSERT(reporter, !tex);
137 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
138 REPORTER_ASSERT(reporter, !tex);
139
140 // check adopt creation
141 backendCopy.fAlloc = backendTex->fAlloc;
142 tex = gpu->wrapBackendTexture(desc, kAdopt_GrWrapOwnership);
143 REPORTER_ASSERT(reporter, tex);
jvanverthfd359ca2016-03-18 11:57:24 -0700144
145 gpu->deleteTestingOnlyBackendTexture(backendObj, true);
146}
147
bsalomondc0fcd42016-04-11 14:21:33 -0700148DEF_GPUTEST_FOR_VULKAN_CONTEXT(VkWrapTests, reporter, ctxInfo) {
bsalomon8b7451a2016-05-11 06:33:06 -0700149 wrap_tex_test(reporter, ctxInfo.grContext());
150 wrap_rt_test(reporter, ctxInfo.grContext());
151 wrap_trt_test(reporter, ctxInfo.grContext());
jvanverthfd359ca2016-03-18 11:57:24 -0700152}
153
154#endif