blob: 70f277e755025ee7ed4e5fc9f79d0d01ee33487e [file] [log] [blame]
Jamie Madill9e54b5a2016-05-25 12:57:39 -04001//
2// Copyright 2016 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6// TextureVk.cpp:
7// Implements the class methods for TextureVk.
8//
9
10#include "libANGLE/renderer/vulkan/TextureVk.h"
11
12#include "common/debug.h"
Jamie Madill035fd6b2017-10-03 15:43:22 -040013#include "libANGLE/Context.h"
14#include "libANGLE/renderer/vulkan/ContextVk.h"
15#include "libANGLE/renderer/vulkan/RendererVk.h"
Jamie Madill3c424b42018-01-19 12:35:09 -050016#include "libANGLE/renderer/vulkan/vk_format_utils.h"
Jamie Madill9e54b5a2016-05-25 12:57:39 -040017
18namespace rx
19{
Luc Ferron5164b792018-03-06 09:10:12 -050020namespace
21{
Jamie Madill93edca12018-03-30 10:43:18 -040022void MapSwizzleState(GLenum internalFormat,
23 const gl::SwizzleState &swizzleState,
24 gl::SwizzleState *swizzleStateOut)
Luc Ferron5164b792018-03-06 09:10:12 -050025{
26 switch (internalFormat)
27 {
Jamie Madill26084d02018-04-09 13:44:04 -040028 case GL_LUMINANCE8_OES:
Jamie Madill93edca12018-03-30 10:43:18 -040029 swizzleStateOut->swizzleRed = swizzleState.swizzleRed;
30 swizzleStateOut->swizzleGreen = swizzleState.swizzleRed;
31 swizzleStateOut->swizzleBlue = swizzleState.swizzleRed;
32 swizzleStateOut->swizzleAlpha = GL_ONE;
Luc Ferron5164b792018-03-06 09:10:12 -050033 break;
Jamie Madill26084d02018-04-09 13:44:04 -040034 case GL_LUMINANCE8_ALPHA8_OES:
Jamie Madill93edca12018-03-30 10:43:18 -040035 swizzleStateOut->swizzleRed = swizzleState.swizzleRed;
36 swizzleStateOut->swizzleGreen = swizzleState.swizzleRed;
37 swizzleStateOut->swizzleBlue = swizzleState.swizzleRed;
38 swizzleStateOut->swizzleAlpha = swizzleState.swizzleGreen;
Luc Ferron5164b792018-03-06 09:10:12 -050039 break;
Jamie Madill26084d02018-04-09 13:44:04 -040040 case GL_ALPHA8_OES:
Jamie Madill93edca12018-03-30 10:43:18 -040041 swizzleStateOut->swizzleRed = GL_ZERO;
42 swizzleStateOut->swizzleGreen = GL_ZERO;
43 swizzleStateOut->swizzleBlue = GL_ZERO;
44 swizzleStateOut->swizzleAlpha = swizzleState.swizzleRed;
Luc Ferron49cef9a2018-03-21 17:28:53 -040045 break;
Luc Ferron5164b792018-03-06 09:10:12 -050046 default:
Jamie Madill93edca12018-03-30 10:43:18 -040047 *swizzleStateOut = swizzleState;
Luc Ferron5164b792018-03-06 09:10:12 -050048 break;
49 }
50}
Jamie Madill26084d02018-04-09 13:44:04 -040051
52constexpr VkBufferUsageFlags kStagingBufferFlags =
53 (VK_BUFFER_USAGE_TRANSFER_SRC_BIT | VK_BUFFER_USAGE_TRANSFER_DST_BIT);
54constexpr size_t kStagingBufferSize = 1024 * 16;
Luc Ferron5164b792018-03-06 09:10:12 -050055} // anonymous namespace
Jamie Madill9e54b5a2016-05-25 12:57:39 -040056
Jamie Madill26084d02018-04-09 13:44:04 -040057// StagingStorage implementation.
58StagingStorage::StagingStorage()
59 : mStagingBuffer(kStagingBufferFlags, kStagingBufferSize), mCurrentBufferHandle(VK_NULL_HANDLE)
60{
61 mStagingBuffer.init(1);
62}
63
64StagingStorage::~StagingStorage()
65{
66}
67
68void StagingStorage::release(RendererVk *renderer)
69{
70 mStagingBuffer.release(renderer);
71}
72
73gl::Error StagingStorage::stageSubresourceUpdate(ContextVk *contextVk,
74 const gl::Extents &extents,
75 const gl::InternalFormat &formatInfo,
76 const gl::PixelUnpackState &unpack,
77 GLenum type,
78 const uint8_t *pixels)
79{
80 GLuint inputRowPitch = 0;
81 ANGLE_TRY_RESULT(
82 formatInfo.computeRowPitch(type, extents.width, unpack.alignment, unpack.rowLength),
83 inputRowPitch);
84
85 GLuint inputDepthPitch = 0;
86 ANGLE_TRY_RESULT(
87 formatInfo.computeDepthPitch(extents.height, unpack.imageHeight, inputRowPitch),
88 inputDepthPitch);
89
90 // TODO(jmadill): skip images for 3D Textures.
91 bool applySkipImages = false;
92
93 GLuint inputSkipBytes = 0;
94 ANGLE_TRY_RESULT(
95 formatInfo.computeSkipBytes(inputRowPitch, inputDepthPitch, unpack, applySkipImages),
96 inputSkipBytes);
97
98 RendererVk *renderer = contextVk->getRenderer();
99
100 const vk::Format &vkFormat = renderer->getFormat(formatInfo.sizedInternalFormat);
101 const angle::Format &storageFormat = vkFormat.textureFormat();
102
103 size_t outputRowPitch = storageFormat.pixelBytes * extents.width;
104 size_t outputDepthPitch = outputRowPitch * extents.height;
105
106 uint8_t *stagingPointer = nullptr;
107 bool newBufferAllocated = false;
108 uint32_t stagingOffset = 0;
109 size_t allocationSize = outputDepthPitch * extents.depth;
110 mStagingBuffer.allocate(renderer, allocationSize, &stagingPointer, &mCurrentBufferHandle,
111 &stagingOffset, &newBufferAllocated);
112
113 const uint8_t *source = pixels + inputSkipBytes;
114
115 LoadImageFunctionInfo loadFunction = vkFormat.loadFunctions(type);
116
117 loadFunction.loadFunction(extents.width, extents.height, extents.depth, source, inputRowPitch,
118 inputDepthPitch, stagingPointer, outputRowPitch, outputDepthPitch);
119
120 mCurrentCopyRegion.bufferOffset = static_cast<VkDeviceSize>(stagingOffset);
121 mCurrentCopyRegion.bufferRowLength = extents.width;
122 mCurrentCopyRegion.bufferImageHeight = extents.height;
123 mCurrentCopyRegion.imageSubresource.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT;
124 mCurrentCopyRegion.imageSubresource.mipLevel = 0;
125 mCurrentCopyRegion.imageSubresource.baseArrayLayer = 0;
126 mCurrentCopyRegion.imageSubresource.layerCount = 1;
127
128 gl_vk::GetOffset(gl::Offset(), &mCurrentCopyRegion.imageOffset);
129 gl_vk::GetExtent(extents, &mCurrentCopyRegion.imageExtent);
130
131 return gl::NoError();
132}
133
134vk::Error StagingStorage::flushUpdatesToImage(RendererVk *renderer,
135 vk::ImageHelper *image,
136 vk::CommandBuffer *commandBuffer)
137{
138 if (mCurrentBufferHandle != VK_NULL_HANDLE)
139 {
140 // Conservatively flush all writes to the image. We could use a more restricted barrier.
141 image->changeLayoutWithStages(
142 VK_IMAGE_ASPECT_COLOR_BIT, VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL,
143 VK_PIPELINE_STAGE_ALL_COMMANDS_BIT, VK_PIPELINE_STAGE_TRANSFER_BIT, commandBuffer);
144
145 ANGLE_TRY(mStagingBuffer.flush(renderer->getDevice()));
146 commandBuffer->copyBufferToImage(mCurrentBufferHandle, image->getImage(),
147 image->getCurrentLayout(), 1, &mCurrentCopyRegion);
148 mCurrentBufferHandle = VK_NULL_HANDLE;
149 }
150
151 return vk::NoError();
152}
153
154// TextureVk implementation.
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400155TextureVk::TextureVk(const gl::TextureState &state) : TextureImpl(state)
156{
Jamie Madillbc543422018-03-30 10:43:19 -0400157 mRenderTarget.image = &mImage;
158 mRenderTarget.imageView = &mImageView;
159 mRenderTarget.resource = this;
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400160}
161
162TextureVk::~TextureVk()
163{
164}
165
Jamie Madill035fd6b2017-10-03 15:43:22 -0400166gl::Error TextureVk::onDestroy(const gl::Context *context)
167{
Jamie Madille1f3ad42017-10-28 23:00:42 -0400168 ContextVk *contextVk = vk::GetImpl(context);
Jamie Madill035fd6b2017-10-03 15:43:22 -0400169 RendererVk *renderer = contextVk->getRenderer();
170
Jamie Madill93edca12018-03-30 10:43:18 -0400171 mImage.release(renderer->getCurrentQueueSerial(), renderer);
172
Jamie Madille88ec8e2017-10-31 17:18:14 -0400173 renderer->releaseResource(*this, &mImageView);
174 renderer->releaseResource(*this, &mSampler);
Jamie Madill035fd6b2017-10-03 15:43:22 -0400175
Jamie Madill26084d02018-04-09 13:44:04 -0400176 mStagingStorage.release(renderer);
177
Jamie Madill7b213812018-03-06 10:13:13 -0500178 onStateChange(context, angle::SubjectMessage::DEPENDENT_DIRTY_BITS);
179
Jamie Madill035fd6b2017-10-03 15:43:22 -0400180 return gl::NoError();
181}
182
Jamie Madillc564c072017-06-01 12:45:42 -0400183gl::Error TextureVk::setImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500184 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400185 size_t level,
186 GLenum internalFormat,
187 const gl::Extents &size,
188 GLenum format,
189 GLenum type,
190 const gl::PixelUnpackState &unpack,
191 const uint8_t *pixels)
192{
Jamie Madille1f3ad42017-10-28 23:00:42 -0400193 ContextVk *contextVk = vk::GetImpl(context);
Jamie Madill1b038242017-11-01 15:14:36 -0400194 RendererVk *renderer = contextVk->getRenderer();
Jamie Madill6a89d222017-11-02 11:59:51 -0400195 VkDevice device = contextVk->getDevice();
Jamie Madill1b038242017-11-01 15:14:36 -0400196
Jamie Madill035fd6b2017-10-03 15:43:22 -0400197 // TODO(jmadill): support multi-level textures.
198 ASSERT(level == 0);
199
Jamie Madill1b038242017-11-01 15:14:36 -0400200 if (mImage.valid())
201 {
202 const gl::ImageDesc &desc = mState.getImageDesc(target, level);
203
204 // TODO(jmadill): Consider comparing stored vk::Format.
205 if (desc.size != size ||
206 !gl::Format::SameSized(desc.format, gl::Format(internalFormat, type)))
207 {
Jamie Madill93edca12018-03-30 10:43:18 -0400208 mImage.release(renderer->getCurrentQueueSerial(), renderer);
Jamie Madill1b038242017-11-01 15:14:36 -0400209 renderer->releaseResource(*this, &mImageView);
Jamie Madill7b213812018-03-06 10:13:13 -0500210
211 onStateChange(context, angle::SubjectMessage::DEPENDENT_DIRTY_BITS);
Jamie Madill1b038242017-11-01 15:14:36 -0400212 }
213 }
Jamie Madill035fd6b2017-10-03 15:43:22 -0400214
Geoff Langbd6ae4a2018-01-29 15:51:18 -0500215 // Early-out on empty textures, don't create a zero-sized storage.
Jamie Madill26084d02018-04-09 13:44:04 -0400216 if (size.empty())
Geoff Langbd6ae4a2018-01-29 15:51:18 -0500217 {
218 return gl::NoError();
219 }
220
Jamie Madill26084d02018-04-09 13:44:04 -0400221 // TODO(jmadill): Cube map textures. http://anglebug.com/2318
222 if (target != gl::TextureTarget::_2D)
Jamie Madill1b038242017-11-01 15:14:36 -0400223 {
Jamie Madill26084d02018-04-09 13:44:04 -0400224 UNIMPLEMENTED();
225 return gl::InternalError();
Jamie Madill1b038242017-11-01 15:14:36 -0400226 }
Jamie Madill5547b382017-10-23 18:16:01 -0400227
Jamie Madill1b038242017-11-01 15:14:36 -0400228 if (!mSampler.valid())
229 {
230 // Create a simple sampler. Force basic parameter settings.
231 // TODO(jmadill): Sampler parameters.
232 VkSamplerCreateInfo samplerInfo;
233 samplerInfo.sType = VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO;
234 samplerInfo.pNext = nullptr;
235 samplerInfo.flags = 0;
236 samplerInfo.magFilter = VK_FILTER_NEAREST;
237 samplerInfo.minFilter = VK_FILTER_NEAREST;
238 samplerInfo.mipmapMode = VK_SAMPLER_MIPMAP_MODE_NEAREST;
239 samplerInfo.addressModeU = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE;
240 samplerInfo.addressModeV = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE;
241 samplerInfo.addressModeW = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE;
242 samplerInfo.mipLodBias = 0.0f;
243 samplerInfo.anisotropyEnable = VK_FALSE;
244 samplerInfo.maxAnisotropy = 1.0f;
245 samplerInfo.compareEnable = VK_FALSE;
246 samplerInfo.compareOp = VK_COMPARE_OP_ALWAYS;
247 samplerInfo.minLod = 0.0f;
248 samplerInfo.maxLod = 1.0f;
249 samplerInfo.borderColor = VK_BORDER_COLOR_INT_TRANSPARENT_BLACK;
250 samplerInfo.unnormalizedCoordinates = VK_FALSE;
251
252 ANGLE_TRY(mSampler.init(device, samplerInfo));
253 }
Jamie Madill5547b382017-10-23 18:16:01 -0400254
Jamie Madill26084d02018-04-09 13:44:04 -0400255 // Create a new graph node to store image initialization commands.
256 getNewWritingNode(renderer);
257
Jamie Madill035fd6b2017-10-03 15:43:22 -0400258 // Handle initial data.
Jamie Madill035fd6b2017-10-03 15:43:22 -0400259 if (pixels)
260 {
Jamie Madill26084d02018-04-09 13:44:04 -0400261 // Convert internalFormat to sized internal format.
262 const gl::InternalFormat &formatInfo = gl::GetInternalFormatInfo(internalFormat, type);
263 ANGLE_TRY(mStagingStorage.stageSubresourceUpdate(contextVk, size, formatInfo, unpack, type,
264 pixels));
Jamie Madill035fd6b2017-10-03 15:43:22 -0400265 }
266
267 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400268}
269
Jamie Madillc564c072017-06-01 12:45:42 -0400270gl::Error TextureVk::setSubImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500271 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400272 size_t level,
273 const gl::Box &area,
274 GLenum format,
275 GLenum type,
276 const gl::PixelUnpackState &unpack,
277 const uint8_t *pixels)
278{
Jamie Madill5b18f482017-11-30 17:24:22 -0500279 ContextVk *contextVk = vk::GetImpl(context);
280 const gl::InternalFormat &formatInfo = gl::GetInternalFormatInfo(format, type);
Jamie Madill26084d02018-04-09 13:44:04 -0400281 ANGLE_TRY(mStagingStorage.stageSubresourceUpdate(
282 contextVk, gl::Extents(area.width, area.height, area.depth), formatInfo, unpack, type,
283 pixels));
Jamie Madill5b18f482017-11-30 17:24:22 -0500284 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400285}
286
Jamie Madillc564c072017-06-01 12:45:42 -0400287gl::Error TextureVk::setCompressedImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500288 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400289 size_t level,
290 GLenum internalFormat,
291 const gl::Extents &size,
292 const gl::PixelUnpackState &unpack,
293 size_t imageSize,
294 const uint8_t *pixels)
295{
296 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500297 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400298}
299
Jamie Madillc564c072017-06-01 12:45:42 -0400300gl::Error TextureVk::setCompressedSubImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500301 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400302 size_t level,
303 const gl::Box &area,
304 GLenum format,
305 const gl::PixelUnpackState &unpack,
306 size_t imageSize,
307 const uint8_t *pixels)
308{
309 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500310 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400311}
312
Jamie Madillc564c072017-06-01 12:45:42 -0400313gl::Error TextureVk::copyImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500314 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400315 size_t level,
316 const gl::Rectangle &sourceArea,
317 GLenum internalFormat,
Jamie Madill690c8eb2018-03-12 15:20:03 -0400318 gl::Framebuffer *source)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400319{
320 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500321 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400322}
323
Jamie Madillc564c072017-06-01 12:45:42 -0400324gl::Error TextureVk::copySubImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500325 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400326 size_t level,
327 const gl::Offset &destOffset,
328 const gl::Rectangle &sourceArea,
Jamie Madill690c8eb2018-03-12 15:20:03 -0400329 gl::Framebuffer *source)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400330{
331 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500332 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400333}
334
Jamie Madillc564c072017-06-01 12:45:42 -0400335gl::Error TextureVk::setStorage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500336 gl::TextureType type,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400337 size_t levels,
338 GLenum internalFormat,
339 const gl::Extents &size)
340{
341 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500342 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400343}
344
Corentin Wallez99d492c2018-02-27 15:17:10 -0500345gl::Error TextureVk::setEGLImageTarget(const gl::Context *context,
346 gl::TextureType type,
347 egl::Image *image)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400348{
349 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500350 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400351}
352
Jamie Madill4928b7c2017-06-20 12:57:39 -0400353gl::Error TextureVk::setImageExternal(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500354 gl::TextureType type,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400355 egl::Stream *stream,
356 const egl::Stream::GLTextureDescription &desc)
357{
358 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500359 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400360}
361
Jamie Madillc564c072017-06-01 12:45:42 -0400362gl::Error TextureVk::generateMipmap(const gl::Context *context)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400363{
364 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500365 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400366}
367
Jamie Madill4928b7c2017-06-20 12:57:39 -0400368gl::Error TextureVk::setBaseLevel(const gl::Context *context, GLuint baseLevel)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400369{
370 UNIMPLEMENTED();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400371 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400372}
373
Jamie Madill4928b7c2017-06-20 12:57:39 -0400374gl::Error TextureVk::bindTexImage(const gl::Context *context, egl::Surface *surface)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400375{
376 UNIMPLEMENTED();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400377 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400378}
379
Jamie Madill4928b7c2017-06-20 12:57:39 -0400380gl::Error TextureVk::releaseTexImage(const gl::Context *context)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400381{
382 UNIMPLEMENTED();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400383 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400384}
385
Jamie Madill4928b7c2017-06-20 12:57:39 -0400386gl::Error TextureVk::getAttachmentRenderTarget(const gl::Context *context,
387 GLenum binding,
Jamie Madill4fd95d52017-04-05 11:22:18 -0400388 const gl::ImageIndex &imageIndex,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400389 FramebufferAttachmentRenderTarget **rtOut)
390{
Jamie Madill26084d02018-04-09 13:44:04 -0400391 // TODO(jmadill): Handle cube textures. http://anglebug.com/2318
Corentin Wallez99d492c2018-02-27 15:17:10 -0500392 ASSERT(imageIndex.type == gl::TextureType::_2D);
Jamie Madill26084d02018-04-09 13:44:04 -0400393
394 // Non-zero mip level attachments are an ES 3.0 feature.
Jamie Madillb79e7bb2017-10-24 13:55:50 -0400395 ASSERT(imageIndex.mipIndex == 0 && imageIndex.layerIndex == gl::ImageIndex::ENTIRE_LEVEL);
Jamie Madill26084d02018-04-09 13:44:04 -0400396
397 ContextVk *contextVk = vk::GetImpl(context);
398 RendererVk *renderer = contextVk->getRenderer();
399
400 ANGLE_TRY(ensureImageInitialized(renderer));
401
Jamie Madillb79e7bb2017-10-24 13:55:50 -0400402 *rtOut = &mRenderTarget;
403 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400404}
405
Jamie Madill26084d02018-04-09 13:44:04 -0400406vk::Error TextureVk::ensureImageInitialized(RendererVk *renderer)
407{
408 VkDevice device = renderer->getDevice();
409 vk::CommandBuffer *commandBuffer = nullptr;
410
411 updateQueueSerial(renderer->getCurrentQueueSerial());
412 if (!hasChildlessWritingNode())
413 {
414 beginWriteResource(renderer, &commandBuffer);
415 }
416 else
417 {
418 vk::CommandGraphNode *node = getCurrentWritingNode();
419 commandBuffer = node->getOutsideRenderPassCommands();
420 if (!commandBuffer->valid())
421 {
422 ANGLE_TRY(node->beginOutsideRenderPassRecording(device, renderer->getCommandPool(),
423 &commandBuffer));
424 }
425 }
426
427 if (!mImage.valid())
428 {
429 const gl::ImageDesc &baseLevelDesc = mState.getBaseLevelDesc();
430 const gl::Extents &extents = baseLevelDesc.size;
431 const vk::Format &format =
432 renderer->getFormat(baseLevelDesc.format.info->sizedInternalFormat);
433
434 VkImageUsageFlags usage =
435 (VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT | VK_IMAGE_USAGE_TRANSFER_DST_BIT |
436 VK_IMAGE_USAGE_TRANSFER_SRC_BIT | VK_IMAGE_USAGE_SAMPLED_BIT);
437 ANGLE_TRY(mImage.init2D(device, extents, format, 1, usage));
438
439 VkMemoryPropertyFlags flags = VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT;
440 ANGLE_TRY(mImage.initMemory(device, renderer->getMemoryProperties(), flags));
441
442 gl::SwizzleState mappedSwizzle;
443 MapSwizzleState(format.internalFormat, mState.getSwizzleState(), &mappedSwizzle);
444
445 ANGLE_TRY(
446 mImage.initImageView(device, VK_IMAGE_ASPECT_COLOR_BIT, mappedSwizzle, &mImageView));
447
448 // TODO(jmadill): Fold this into the RenderPass load/store ops. http://anglebug.com/2361
449
450 VkClearColorValue black = {{0}};
451 mImage.clearColor(black, commandBuffer);
452 }
453
454 ANGLE_TRY(mStagingStorage.flushUpdatesToImage(renderer, &mImage, commandBuffer));
455 return vk::NoError();
456}
457
Geoff Lang22416862016-06-08 16:14:36 -0700458void TextureVk::syncState(const gl::Texture::DirtyBits &dirtyBits)
459{
Jamie Madill5547b382017-10-23 18:16:01 -0400460 // TODO(jmadill): Texture sync state.
Geoff Lang22416862016-06-08 16:14:36 -0700461}
462
Jamie Madillc564c072017-06-01 12:45:42 -0400463gl::Error TextureVk::setStorageMultisample(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500464 gl::TextureType type,
JiangYizhoubddc46b2016-12-09 09:50:51 +0800465 GLsizei samples,
466 GLint internalformat,
467 const gl::Extents &size,
Geoff Lang92019432017-11-20 13:09:34 -0500468 bool fixedSampleLocations)
JiangYizhoubddc46b2016-12-09 09:50:51 +0800469{
470 UNIMPLEMENTED();
471 return gl::InternalError() << "setStorageMultisample is unimplemented.";
472}
473
Jamie Madill05b35b22017-10-03 09:01:44 -0400474gl::Error TextureVk::initializeContents(const gl::Context *context,
475 const gl::ImageIndex &imageIndex)
476{
477 UNIMPLEMENTED();
478 return gl::NoError();
479}
480
Jamie Madill858c1cc2018-03-31 14:19:13 -0400481const vk::ImageHelper &TextureVk::getImage() const
Jamie Madill5547b382017-10-23 18:16:01 -0400482{
483 ASSERT(mImage.valid());
Jamie Madill858c1cc2018-03-31 14:19:13 -0400484 return mImage;
Jamie Madill5547b382017-10-23 18:16:01 -0400485}
486
487const vk::ImageView &TextureVk::getImageView() const
488{
Jamie Madill93edca12018-03-30 10:43:18 -0400489 ASSERT(mImage.valid());
Jamie Madill5547b382017-10-23 18:16:01 -0400490 return mImageView;
491}
492
493const vk::Sampler &TextureVk::getSampler() const
494{
495 ASSERT(mSampler.valid());
496 return mSampler;
497}
498
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400499} // namespace rx