Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 Loading... | |
| 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 } |
| OLD | NEW |