Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(196)

Side by Side Diff: src/gpu/vk/GrVkTexture.cpp

Issue 1974983002: Refactor Vulkan image, texture, RTs so that create and getter handles match. (Closed) Base URL: https://skia.googlesource.com/skia.git@fixLayerVersion
Patch Set: clean up Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/gpu/vk/GrVkTexture.h ('k') | src/gpu/vk/GrVkTextureRenderTarget.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2015 Google Inc. 2 * Copyright 2015 Google Inc.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 7
8 #include "GrVkTexture.h" 8 #include "GrVkTexture.h"
9 #include "GrVkGpu.h" 9 #include "GrVkGpu.h"
10 #include "GrVkImageView.h" 10 #include "GrVkImageView.h"
11 #include "GrTexturePriv.h" 11 #include "GrTexturePriv.h"
12 #include "GrVkUtil.h" 12 #include "GrVkUtil.h"
13 13
14 #include "vk/GrVkTypes.h" 14 #include "vk/GrVkTypes.h"
15 15
16 #define VK_CALL(GPU, X) GR_VK_CALL(GPU->vkInterface(), X) 16 #define VK_CALL(GPU, X) GR_VK_CALL(GPU->vkInterface(), X)
17 17
18 // Because this class is virtually derived from GrSurface we must explicitly cal l its constructor. 18 // Because this class is virtually derived from GrSurface we must explicitly cal l its constructor.
19 GrVkTexture::GrVkTexture(GrVkGpu* gpu, 19 GrVkTexture::GrVkTexture(GrVkGpu* gpu,
20 SkBudgeted budgeted, 20 SkBudgeted budgeted,
21 const GrSurfaceDesc& desc, 21 const GrSurfaceDesc& desc,
22 const GrVkImage::Resource* imageResource, 22 const GrVkImageInfo& info,
23 const GrVkImageView* view) 23 const GrVkImageView* view,
24 bool /*isBorrowed*/)
bsalomon 2016/05/13 13:25:48 unused constructor param?
egdaniel 2016/05/13 13:29:59 it is so this ctor and the next one can both be ca
egdaniel 2016/05/13 15:06:53 Done.
24 : GrSurface(gpu, desc) 25 : GrSurface(gpu, desc)
25 , GrVkImage(imageResource) 26 , GrVkImage(info, false)
26 , INHERITED(gpu, desc, kSampler2D_GrSLType, desc.fIsMipMapped) 27 , INHERITED(gpu, desc, kSampler2D_GrSLType, desc.fIsMipMapped)
27 , fTextureView(view) { 28 , fTextureView(view) {
28 this->registerWithCache(budgeted); 29 this->registerWithCache(budgeted);
29 } 30 }
30 31
31 GrVkTexture::GrVkTexture(GrVkGpu* gpu, 32 GrVkTexture::GrVkTexture(GrVkGpu* gpu,
32 Wrapped, 33 Wrapped,
33 const GrSurfaceDesc& desc, 34 const GrSurfaceDesc& desc,
34 const GrVkImage::Resource* imageResource, 35 const GrVkImageInfo& info,
35 const GrVkImageView* view) 36 const GrVkImageView* view,
37 bool isBorrowed)
36 : GrSurface(gpu, desc) 38 : GrSurface(gpu, desc)
37 , GrVkImage(imageResource) 39 , GrVkImage(info, isBorrowed)
38 , INHERITED(gpu, desc, kSampler2D_GrSLType, desc.fIsMipMapped) 40 , INHERITED(gpu, desc, kSampler2D_GrSLType, desc.fIsMipMapped)
39 , fTextureView(view) { 41 , fTextureView(view) {
40 this->registerWithCacheWrapped(); 42 this->registerWithCacheWrapped();
41 } 43 }
42 44
43 // Because this class is virtually derived from GrSurface we must explicitly cal l its constructor. 45 // Because this class is virtually derived from GrSurface we must explicitly cal l its constructor.
44 GrVkTexture::GrVkTexture(GrVkGpu* gpu, 46 GrVkTexture::GrVkTexture(GrVkGpu* gpu,
45 const GrSurfaceDesc& desc, 47 const GrSurfaceDesc& desc,
46 const GrVkImage::Resource* imageResource, 48 const GrVkImageInfo& info,
47 const GrVkImageView* view) 49 const GrVkImageView* view,
50 bool isWrapped)
48 : GrSurface(gpu, desc) 51 : GrSurface(gpu, desc)
49 , GrVkImage(imageResource) 52 , GrVkImage(info, isWrapped)
50 , INHERITED(gpu, desc, kSampler2D_GrSLType, desc.fIsMipMapped) 53 , INHERITED(gpu, desc, kSampler2D_GrSLType, desc.fIsMipMapped)
51 , fTextureView(view) {} 54 , fTextureView(view) {}
52 55
53 56
54 template<typename ResourceType> 57 template<typename ResourceType>
55 GrVkTexture* GrVkTexture::Create(GrVkGpu* gpu, 58 GrVkTexture* GrVkTexture::Create(GrVkGpu* gpu,
56 ResourceType type, 59 ResourceType type,
57 const GrSurfaceDesc& desc, 60 const GrSurfaceDesc& desc,
58 VkFormat format, 61 const GrVkImageInfo& info,
59 const GrVkImage::Resource* imageResource) { 62 bool isBorrowed) {
60 VkImage image = imageResource->fImage; 63 VkImage image = info.fImage;
61 64
62 const GrVkImageView* imageView = GrVkImageView::Create(gpu, image, format, 65 const GrVkImageView* imageView = GrVkImageView::Create(gpu, image, info.fFor mat,
63 GrVkImageView::kColor _Type, 66 GrVkImageView::kColor _Type,
64 imageResource->fLevel Count); 67 info.fLevelCount);
65 if (!imageView) { 68 if (!imageView) {
66 return nullptr; 69 return nullptr;
67 } 70 }
68 71
69 return new GrVkTexture(gpu, type, desc, imageResource, imageView); 72 return new GrVkTexture(gpu, type, desc, info, imageView, isBorrowed);
70 } 73 }
71 74
72 GrVkTexture* GrVkTexture::CreateNewTexture(GrVkGpu* gpu, SkBudgeted budgeted, 75 GrVkTexture* GrVkTexture::CreateNewTexture(GrVkGpu* gpu, SkBudgeted budgeted,
73 const GrSurfaceDesc& desc, 76 const GrSurfaceDesc& desc,
74 const GrVkImage::ImageDesc& imageDesc ) { 77 const GrVkImage::ImageDesc& imageDesc ) {
75 SkASSERT(imageDesc.fUsageFlags & VK_IMAGE_USAGE_SAMPLED_BIT); 78 SkASSERT(imageDesc.fUsageFlags & VK_IMAGE_USAGE_SAMPLED_BIT);
76 79
77 const GrVkImage::Resource* imageResource = GrVkImage::CreateResource(gpu, im ageDesc); 80 GrVkImageInfo info;
78 if (!imageResource) { 81 if (!GrVkImage::GetImageInfo(gpu, imageDesc, &info)) {
79 return nullptr; 82 return nullptr;
80 } 83 }
81 84
82 GrVkTexture* texture = Create(gpu, budgeted, desc, imageDesc.fFormat, imageR esource); 85 GrVkTexture* texture = Create(gpu, budgeted, desc, info, false);
83 // Create() will increment the refCount of the image resource if it succeeds 86 if (!texture) {
84 imageResource->unref(gpu); 87 VK_CALL(gpu, DestroyImage(gpu->device(), info.fImage, nullptr));
88 VK_CALL(gpu, FreeMemory(gpu->device(), info.fAlloc, nullptr));
89 }
85 90
86 return texture; 91 return texture;
87 } 92 }
88 93
89 GrVkTexture* GrVkTexture::CreateWrappedTexture(GrVkGpu* gpu, 94 GrVkTexture* GrVkTexture::CreateWrappedTexture(GrVkGpu* gpu,
90 const GrSurfaceDesc& desc, 95 const GrSurfaceDesc& desc,
91 GrWrapOwnership ownership, 96 GrWrapOwnership ownership,
92 VkFormat format, 97 const GrVkImageInfo* info) {
93 const GrVkTextureInfo* info) {
94 SkASSERT(info); 98 SkASSERT(info);
95 // Wrapped textures require both image and allocation (because they can be m apped) 99 // Wrapped textures require both image and allocation (because they can be m apped)
96 SkASSERT(VK_NULL_HANDLE != info->fImage && VK_NULL_HANDLE != info->fAlloc); 100 SkASSERT(VK_NULL_HANDLE != info->fImage && VK_NULL_HANDLE != info->fAlloc);
97 101
98 GrVkImage::Resource::Flags flags = (VK_IMAGE_TILING_LINEAR == info->fImageTi ling) 102 GrVkTexture* texture = Create(gpu, kWrapped, desc, *info,
99 ? Resource::kLinearTiling_Flag : Resource:: kNo_Flags; 103 kBorrow_GrWrapOwnership == ownership);
100
101 const GrVkImage::Resource* imageResource;
102 if (kBorrow_GrWrapOwnership == ownership) {
103 imageResource = new GrVkImage::BorrowedResource(info->fImage,
104 info->fAlloc,
105 info->fFormat,
106 info->fLevelCount,
107 flags);
108 } else {
109 imageResource = new GrVkImage::Resource(info->fImage, info->fAlloc, info ->fFormat,
110 info->fLevelCount, flags);
111 }
112 if (!imageResource) {
113 return nullptr;
114 }
115
116 GrVkTexture* texture = Create(gpu, kWrapped, desc, format, imageResource);
117 if (texture) {
118 texture->fCurrentLayout = info->fImageLayout;
119 }
120 // Create() will increment the refCount of the image resource if it succeeds
121 imageResource->unref(gpu);
122 104
123 return texture; 105 return texture;
124 } 106 }
125 107
126 GrVkTexture::~GrVkTexture() { 108 GrVkTexture::~GrVkTexture() {
127 // either release or abandon should have been called by the owner of this ob ject. 109 // either release or abandon should have been called by the owner of this ob ject.
128 SkASSERT(!fTextureView); 110 SkASSERT(!fTextureView);
129 } 111 }
130 112
131 void GrVkTexture::onRelease() { 113 void GrVkTexture::onRelease() {
(...skipping 13 matching lines...) Expand all
145 fTextureView->unrefAndAbandon(); 127 fTextureView->unrefAndAbandon();
146 fTextureView = nullptr; 128 fTextureView = nullptr;
147 } 129 }
148 130
149 this->abandonImage(); 131 this->abandonImage();
150 INHERITED::onAbandon(); 132 INHERITED::onAbandon();
151 } 133 }
152 134
153 GrBackendObject GrVkTexture::getTextureHandle() const { 135 GrBackendObject GrVkTexture::getTextureHandle() const {
154 // Currently just passing back the pointer to the Resource as the handle 136 // Currently just passing back the pointer to the Resource as the handle
155 return (GrBackendObject)&fResource; 137 return (GrBackendObject)&fInfo;
156 } 138 }
157 139
158 GrVkGpu* GrVkTexture::getVkGpu() const { 140 GrVkGpu* GrVkTexture::getVkGpu() const {
159 SkASSERT(!this->wasDestroyed()); 141 SkASSERT(!this->wasDestroyed());
160 return static_cast<GrVkGpu*>(this->getGpu()); 142 return static_cast<GrVkGpu*>(this->getGpu());
161 } 143 }
162 144
163 bool GrVkTexture::reallocForMipmap(const GrVkGpu* gpu, uint32_t mipLevels) { 145 bool GrVkTexture::reallocForMipmap(const GrVkGpu* gpu, uint32_t mipLevels) {
164 if (mipLevels == 1) { 146 if (mipLevels == 1) {
165 // don't need to do anything for a 1x1 texture 147 // don't need to do anything for a 1x1 texture
166 return false; 148 return false;
167 } 149 }
168 150
169 const GrVkImage::Resource* oldResource = fResource; 151 const GrVkResource* oldResource = this->resource();
170 152
171 // We shouldn't realloc something that doesn't belong to us 153 // We shouldn't realloc something that doesn't belong to us
172 if (GrVkImage::Resource::kBorrowed_Flag & oldResource->fFlags) { 154 if (fIsBorrowed) {
173 return false; 155 return false;
174 } 156 }
175 157
176 // Does this even make sense for rendertargets? 158 // Does this even make sense for rendertargets?
177 bool renderTarget = SkToBool(fDesc.fFlags & kRenderTarget_GrSurfaceFlag); 159 bool renderTarget = SkToBool(fDesc.fFlags & kRenderTarget_GrSurfaceFlag);
178 160
179 VkImageUsageFlags usageFlags = VK_IMAGE_USAGE_SAMPLED_BIT; 161 VkImageUsageFlags usageFlags = VK_IMAGE_USAGE_SAMPLED_BIT;
180 if (renderTarget) { 162 if (renderTarget) {
181 usageFlags |= VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT; 163 usageFlags |= VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT;
182 } 164 }
183 usageFlags |= VK_IMAGE_USAGE_TRANSFER_SRC_BIT | VK_IMAGE_USAGE_TRANSFER_DST_ BIT; 165 usageFlags |= VK_IMAGE_USAGE_TRANSFER_SRC_BIT | VK_IMAGE_USAGE_TRANSFER_DST_ BIT;
184 166
185 GrVkImage::ImageDesc imageDesc; 167 GrVkImage::ImageDesc imageDesc;
186 imageDesc.fImageType = VK_IMAGE_TYPE_2D; 168 imageDesc.fImageType = VK_IMAGE_TYPE_2D;
187 imageDesc.fFormat = oldResource->fFormat; 169 imageDesc.fFormat = fInfo.fFormat;
188 imageDesc.fWidth = fDesc.fWidth; 170 imageDesc.fWidth = fDesc.fWidth;
189 imageDesc.fHeight = fDesc.fHeight; 171 imageDesc.fHeight = fDesc.fHeight;
190 imageDesc.fLevels = mipLevels; 172 imageDesc.fLevels = mipLevels;
191 imageDesc.fSamples = 1; 173 imageDesc.fSamples = 1;
192 imageDesc.fImageTiling = VK_IMAGE_TILING_OPTIMAL; 174 imageDesc.fImageTiling = VK_IMAGE_TILING_OPTIMAL;
193 imageDesc.fUsageFlags = usageFlags; 175 imageDesc.fUsageFlags = usageFlags;
194 imageDesc.fMemProps = VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT; 176 imageDesc.fMemProps = VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT;
195 177
196 const GrVkImage::Resource* imageResource = GrVkImage::CreateResource(gpu, im ageDesc); 178 GrVkImageInfo info;
197 if (!imageResource) { 179 if (!GrVkImage::GetImageInfo(gpu, imageDesc, &info)) {
198 return false; 180 return nullptr;
199 } 181 }
200 182
201 // have to create a new image view for new resource 183 // have to create a new image view for new resource
202 const GrVkImageView* oldView = fTextureView; 184 const GrVkImageView* oldView = fTextureView;
203 VkImage image = imageResource->fImage; 185 VkImage image = info.fImage;
204 const GrVkImageView* textureView = GrVkImageView::Create(gpu, image, imageRe source->fFormat, 186 const GrVkImageView* textureView = GrVkImageView::Create(gpu, image, info.fF ormat,
205 GrVkImageView::kCol or_Type, mipLevels); 187 GrVkImageView::kCol or_Type, mipLevels);
206 if (!textureView) { 188 if (!textureView) {
207 imageResource->unref(gpu); 189 VK_CALL(gpu, DestroyImage(gpu->device(), info.fImage, nullptr));
190 VK_CALL(gpu, FreeMemory(gpu->device(), info.fAlloc, nullptr));
208 return false; 191 return false;
209 } 192 }
210 193
211 oldResource->unref(gpu); 194 oldResource->unref(gpu);
212 oldView->unref(gpu); 195 oldView->unref(gpu);
213 fResource = imageResource; 196 this->setNewResource(info.fImage, info.fAlloc);
214 fTextureView = textureView; 197 fTextureView = textureView;
215 fCurrentLayout = VK_IMAGE_LAYOUT_UNDEFINED; 198 fInfo = info;
216 this->texturePriv().setMaxMipMapLevel(mipLevels); 199 this->texturePriv().setMaxMipMapLevel(mipLevels);
217 200
218 return true; 201 return true;
219 } 202 }
OLDNEW
« no previous file with comments | « src/gpu/vk/GrVkTexture.h ('k') | src/gpu/vk/GrVkTextureRenderTarget.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698