blob: e6371cdadf91161c41176d38b6d293a4bcef5635 [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{
20
21TextureVk::TextureVk(const gl::TextureState &state) : TextureImpl(state)
22{
23}
24
25TextureVk::~TextureVk()
26{
27}
28
Jamie Madill035fd6b2017-10-03 15:43:22 -040029gl::Error TextureVk::onDestroy(const gl::Context *context)
30{
Jamie Madille1f3ad42017-10-28 23:00:42 -040031 ContextVk *contextVk = vk::GetImpl(context);
Jamie Madill035fd6b2017-10-03 15:43:22 -040032 RendererVk *renderer = contextVk->getRenderer();
33
Jamie Madille88ec8e2017-10-31 17:18:14 -040034 renderer->releaseResource(*this, &mImage);
35 renderer->releaseResource(*this, &mDeviceMemory);
36 renderer->releaseResource(*this, &mImageView);
37 renderer->releaseResource(*this, &mSampler);
Jamie Madill035fd6b2017-10-03 15:43:22 -040038
Jamie Madill7b213812018-03-06 10:13:13 -050039 onStateChange(context, angle::SubjectMessage::DEPENDENT_DIRTY_BITS);
40
Jamie Madill035fd6b2017-10-03 15:43:22 -040041 return gl::NoError();
42}
43
Jamie Madillc564c072017-06-01 12:45:42 -040044gl::Error TextureVk::setImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -050045 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -040046 size_t level,
47 GLenum internalFormat,
48 const gl::Extents &size,
49 GLenum format,
50 GLenum type,
51 const gl::PixelUnpackState &unpack,
52 const uint8_t *pixels)
53{
Jamie Madille1f3ad42017-10-28 23:00:42 -040054 ContextVk *contextVk = vk::GetImpl(context);
Jamie Madill1b038242017-11-01 15:14:36 -040055 RendererVk *renderer = contextVk->getRenderer();
Jamie Madill6a89d222017-11-02 11:59:51 -040056 VkDevice device = contextVk->getDevice();
Jamie Madill1b038242017-11-01 15:14:36 -040057
Jamie Madill035fd6b2017-10-03 15:43:22 -040058 // TODO(jmadill): support multi-level textures.
59 ASSERT(level == 0);
60
Jamie Madill1b038242017-11-01 15:14:36 -040061 if (mImage.valid())
62 {
63 const gl::ImageDesc &desc = mState.getImageDesc(target, level);
64
65 // TODO(jmadill): Consider comparing stored vk::Format.
66 if (desc.size != size ||
67 !gl::Format::SameSized(desc.format, gl::Format(internalFormat, type)))
68 {
69 renderer->releaseResource(*this, &mImage);
70 renderer->releaseResource(*this, &mDeviceMemory);
71 renderer->releaseResource(*this, &mImageView);
Jamie Madill7b213812018-03-06 10:13:13 -050072
73 onStateChange(context, angle::SubjectMessage::DEPENDENT_DIRTY_BITS);
Jamie Madill1b038242017-11-01 15:14:36 -040074 }
75 }
Jamie Madill035fd6b2017-10-03 15:43:22 -040076
Geoff Langbd6ae4a2018-01-29 15:51:18 -050077 mRenderTarget.reset();
78
79 // Early-out on empty textures, don't create a zero-sized storage.
80 if (size.width == 0 || size.height == 0 || size.depth == 0)
81 {
82 return gl::NoError();
83 }
84
Jamie Madill035fd6b2017-10-03 15:43:22 -040085 // TODO(jmadill): support other types of textures.
Corentin Wallez99d492c2018-02-27 15:17:10 -050086 ASSERT(target == gl::TextureTarget::_2D);
Jamie Madill035fd6b2017-10-03 15:43:22 -040087
88 // Convert internalFormat to sized internal format.
89 const gl::InternalFormat &formatInfo = gl::GetInternalFormatInfo(internalFormat, type);
Jamie Madill6a89d222017-11-02 11:59:51 -040090 const vk::Format &vkFormat = renderer->getFormat(formatInfo.sizedInternalFormat);
Jamie Madill035fd6b2017-10-03 15:43:22 -040091
Jamie Madill1b038242017-11-01 15:14:36 -040092 if (!mImage.valid())
93 {
94 ASSERT(!mDeviceMemory.valid() && !mImageView.valid());
Jamie Madill035fd6b2017-10-03 15:43:22 -040095
Jamie Madill1b038242017-11-01 15:14:36 -040096 VkImageCreateInfo imageInfo;
97 imageInfo.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
98 imageInfo.pNext = nullptr;
99 imageInfo.flags = 0;
100 imageInfo.imageType = VK_IMAGE_TYPE_2D;
Jamie Madill1d7be502017-10-29 18:06:50 -0400101 imageInfo.format = vkFormat.vkTextureFormat;
Jamie Madill1b038242017-11-01 15:14:36 -0400102 imageInfo.extent.width = size.width;
103 imageInfo.extent.height = size.height;
104 imageInfo.extent.depth = size.depth;
105 imageInfo.mipLevels = 1;
106 imageInfo.arrayLayers = 1;
107 imageInfo.samples = VK_SAMPLE_COUNT_1_BIT;
108 imageInfo.tiling = VK_IMAGE_TILING_OPTIMAL;
Jamie Madill035fd6b2017-10-03 15:43:22 -0400109
Jamie Madill1b038242017-11-01 15:14:36 -0400110 // TODO(jmadill): Are all these image transfer bits necessary?
111 imageInfo.usage = (VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT | VK_IMAGE_USAGE_TRANSFER_DST_BIT |
112 VK_IMAGE_USAGE_TRANSFER_SRC_BIT | VK_IMAGE_USAGE_SAMPLED_BIT);
113 imageInfo.sharingMode = VK_SHARING_MODE_EXCLUSIVE;
114 imageInfo.queueFamilyIndexCount = 0;
115 imageInfo.pQueueFamilyIndices = nullptr;
116 imageInfo.initialLayout = VK_IMAGE_LAYOUT_UNDEFINED;
Jamie Madill035fd6b2017-10-03 15:43:22 -0400117
Jamie Madill1b038242017-11-01 15:14:36 -0400118 ANGLE_TRY(mImage.init(device, imageInfo));
Jamie Madill035fd6b2017-10-03 15:43:22 -0400119
Jamie Madill57dd97a2018-02-06 17:10:49 -0500120 VkMemoryPropertyFlags flags = (VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT);
121 size_t requiredSize = 0;
Jamie Madill57fbfd82018-02-14 12:45:34 -0500122 ANGLE_TRY(vk::AllocateImageMemory(renderer, flags, &mImage, &mDeviceMemory, &requiredSize));
Jamie Madill035fd6b2017-10-03 15:43:22 -0400123
Jamie Madill1b038242017-11-01 15:14:36 -0400124 VkImageViewCreateInfo viewInfo;
125 viewInfo.sType = VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO;
126 viewInfo.pNext = nullptr;
127 viewInfo.flags = 0;
128 viewInfo.image = mImage.getHandle();
129 viewInfo.viewType = VK_IMAGE_VIEW_TYPE_2D;
Jamie Madill1d7be502017-10-29 18:06:50 -0400130 viewInfo.format = vkFormat.vkTextureFormat;
Jamie Madill1b038242017-11-01 15:14:36 -0400131 viewInfo.components.r = VK_COMPONENT_SWIZZLE_R;
132 viewInfo.components.g = VK_COMPONENT_SWIZZLE_G;
133 viewInfo.components.b = VK_COMPONENT_SWIZZLE_B;
134 viewInfo.components.a = VK_COMPONENT_SWIZZLE_A;
135 viewInfo.subresourceRange.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT;
136 viewInfo.subresourceRange.baseMipLevel = 0;
137 viewInfo.subresourceRange.levelCount = 1;
138 viewInfo.subresourceRange.baseArrayLayer = 0;
139 viewInfo.subresourceRange.layerCount = 1;
Jamie Madill035fd6b2017-10-03 15:43:22 -0400140
Jamie Madill1b038242017-11-01 15:14:36 -0400141 ANGLE_TRY(mImageView.init(device, viewInfo));
Jamie Madille4c5a232018-03-02 21:00:31 -0500142
143 // TODO(jmadill): Fold this into the RenderPass load/store ops. http://anglebug.com/2361
144 vk::CommandBuffer *commandBuffer = nullptr;
145 ANGLE_TRY(beginWriteResource(renderer, &commandBuffer));
146 VkClearColorValue black = {{0}};
147 mImage.changeLayoutWithStages(
148 VK_IMAGE_ASPECT_COLOR_BIT, VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL,
149 VK_PIPELINE_STAGE_ALL_COMMANDS_BIT, VK_PIPELINE_STAGE_TRANSFER_BIT, commandBuffer);
150 commandBuffer->clearSingleColorImage(mImage, black);
Jamie Madill1b038242017-11-01 15:14:36 -0400151 }
Jamie Madill5547b382017-10-23 18:16:01 -0400152
Jamie Madill1b038242017-11-01 15:14:36 -0400153 if (!mSampler.valid())
154 {
155 // Create a simple sampler. Force basic parameter settings.
156 // TODO(jmadill): Sampler parameters.
157 VkSamplerCreateInfo samplerInfo;
158 samplerInfo.sType = VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO;
159 samplerInfo.pNext = nullptr;
160 samplerInfo.flags = 0;
161 samplerInfo.magFilter = VK_FILTER_NEAREST;
162 samplerInfo.minFilter = VK_FILTER_NEAREST;
163 samplerInfo.mipmapMode = VK_SAMPLER_MIPMAP_MODE_NEAREST;
164 samplerInfo.addressModeU = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE;
165 samplerInfo.addressModeV = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE;
166 samplerInfo.addressModeW = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE;
167 samplerInfo.mipLodBias = 0.0f;
168 samplerInfo.anisotropyEnable = VK_FALSE;
169 samplerInfo.maxAnisotropy = 1.0f;
170 samplerInfo.compareEnable = VK_FALSE;
171 samplerInfo.compareOp = VK_COMPARE_OP_ALWAYS;
172 samplerInfo.minLod = 0.0f;
173 samplerInfo.maxLod = 1.0f;
174 samplerInfo.borderColor = VK_BORDER_COLOR_INT_TRANSPARENT_BLACK;
175 samplerInfo.unnormalizedCoordinates = VK_FALSE;
176
177 ANGLE_TRY(mSampler.init(device, samplerInfo));
178 }
Jamie Madill5547b382017-10-23 18:16:01 -0400179
Jamie Madillb79e7bb2017-10-24 13:55:50 -0400180 mRenderTarget.image = &mImage;
181 mRenderTarget.imageView = &mImageView;
182 mRenderTarget.format = &vkFormat;
183 mRenderTarget.extents = size;
184 mRenderTarget.samples = VK_SAMPLE_COUNT_1_BIT;
185 mRenderTarget.resource = this;
186
Jamie Madill035fd6b2017-10-03 15:43:22 -0400187 // Handle initial data.
Jamie Madill035fd6b2017-10-03 15:43:22 -0400188 if (pixels)
189 {
Jamie Madill5b18f482017-11-30 17:24:22 -0500190 ANGLE_TRY(setSubImageImpl(contextVk, formatInfo, unpack, type, pixels));
Jamie Madill035fd6b2017-10-03 15:43:22 -0400191 }
192
193 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400194}
195
Jamie Madillc564c072017-06-01 12:45:42 -0400196gl::Error TextureVk::setSubImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500197 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400198 size_t level,
199 const gl::Box &area,
200 GLenum format,
201 GLenum type,
202 const gl::PixelUnpackState &unpack,
203 const uint8_t *pixels)
204{
Jamie Madill5b18f482017-11-30 17:24:22 -0500205 ContextVk *contextVk = vk::GetImpl(context);
206 const gl::InternalFormat &formatInfo = gl::GetInternalFormatInfo(format, type);
207 ANGLE_TRY(setSubImageImpl(contextVk, formatInfo, unpack, type, pixels));
208 return gl::NoError();
209}
210
211gl::Error TextureVk::setSubImageImpl(ContextVk *contextVk,
212 const gl::InternalFormat &formatInfo,
213 const gl::PixelUnpackState &unpack,
214 GLenum type,
215 const uint8_t *pixels)
216{
217 RendererVk *renderer = contextVk->getRenderer();
218 VkDevice device = renderer->getDevice();
219 const gl::Extents &size = mRenderTarget.extents;
220 const vk::Format &vkFormat = *mRenderTarget.format;
221
222 vk::StagingImage stagingImage;
Jamie Madill57dd97a2018-02-06 17:10:49 -0500223 ANGLE_TRY(stagingImage.init(contextVk, TextureDimension::TEX_2D, vkFormat, size,
224 vk::StagingUsage::Write));
Jamie Madill5b18f482017-11-30 17:24:22 -0500225
226 GLuint inputRowPitch = 0;
227 ANGLE_TRY_RESULT(
228 formatInfo.computeRowPitch(type, size.width, unpack.alignment, unpack.rowLength),
229 inputRowPitch);
230
231 GLuint inputDepthPitch = 0;
232 ANGLE_TRY_RESULT(formatInfo.computeDepthPitch(size.height, unpack.imageHeight, inputRowPitch),
233 inputDepthPitch);
234
235 // TODO(jmadill): skip images for 3D Textures.
236 bool applySkipImages = false;
237
238 GLuint inputSkipBytes = 0;
239 ANGLE_TRY_RESULT(
240 formatInfo.computeSkipBytes(inputRowPitch, inputDepthPitch, unpack, applySkipImages),
241 inputSkipBytes);
242
243 auto loadFunction = vkFormat.loadFunctions(type);
244
245 uint8_t *mapPointer = nullptr;
246 ANGLE_TRY(stagingImage.getDeviceMemory().map(device, 0, VK_WHOLE_SIZE, 0, &mapPointer));
247
248 const uint8_t *source = pixels + inputSkipBytes;
249
250 // Get the subresource layout. This has important parameters like row pitch.
251 // TODO(jmadill): Fill out this structure based on input parameters.
252 VkImageSubresource subresource;
253 subresource.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT;
254 subresource.mipLevel = 0;
255 subresource.arrayLayer = 0;
256
257 VkSubresourceLayout subresourceLayout;
258 vkGetImageSubresourceLayout(device, stagingImage.getImage().getHandle(), &subresource,
259 &subresourceLayout);
260
261 loadFunction.loadFunction(size.width, size.height, size.depth, source, inputRowPitch,
262 inputDepthPitch, mapPointer,
263 static_cast<size_t>(subresourceLayout.rowPitch),
264 static_cast<size_t>(subresourceLayout.depthPitch));
265
266 stagingImage.getDeviceMemory().unmap(device);
267
Jamie Madill49ac74b2017-12-21 14:42:33 -0500268 vk::CommandBuffer *commandBuffer = nullptr;
Jamie Madill1f46bc12018-02-20 16:09:43 -0500269 ANGLE_TRY(beginWriteResource(renderer, &commandBuffer));
Jamie Madill5b18f482017-11-30 17:24:22 -0500270
271 stagingImage.getImage().changeLayoutWithStages(
272 VK_IMAGE_ASPECT_COLOR_BIT, VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL,
273 VK_PIPELINE_STAGE_ALL_COMMANDS_BIT, VK_PIPELINE_STAGE_TRANSFER_BIT, commandBuffer);
274 mImage.changeLayoutWithStages(VK_IMAGE_ASPECT_COLOR_BIT, VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL,
275 VK_PIPELINE_STAGE_ALL_COMMANDS_BIT,
276 VK_PIPELINE_STAGE_TRANSFER_BIT, commandBuffer);
277
278 gl::Box wholeRegion(0, 0, 0, size.width, size.height, size.depth);
279 commandBuffer->copySingleImage(stagingImage.getImage(), mImage, wholeRegion,
280 VK_IMAGE_ASPECT_COLOR_BIT);
281
Jamie Madill49ac74b2017-12-21 14:42:33 -0500282 // Immediately release staging image.
283 // TODO(jmadill): Staging image re-use.
Jamie Madill5b18f482017-11-30 17:24:22 -0500284 renderer->releaseObject(renderer->getCurrentQueueSerial(), &stagingImage);
285 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400286}
287
Jamie Madillc564c072017-06-01 12:45:42 -0400288gl::Error TextureVk::setCompressedImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500289 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400290 size_t level,
291 GLenum internalFormat,
292 const gl::Extents &size,
293 const gl::PixelUnpackState &unpack,
294 size_t imageSize,
295 const uint8_t *pixels)
296{
297 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500298 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400299}
300
Jamie Madillc564c072017-06-01 12:45:42 -0400301gl::Error TextureVk::setCompressedSubImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500302 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400303 size_t level,
304 const gl::Box &area,
305 GLenum format,
306 const gl::PixelUnpackState &unpack,
307 size_t imageSize,
308 const uint8_t *pixels)
309{
310 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500311 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400312}
313
Jamie Madillc564c072017-06-01 12:45:42 -0400314gl::Error TextureVk::copyImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500315 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400316 size_t level,
317 const gl::Rectangle &sourceArea,
318 GLenum internalFormat,
319 const gl::Framebuffer *source)
320{
321 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500322 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400323}
324
Jamie Madillc564c072017-06-01 12:45:42 -0400325gl::Error TextureVk::copySubImage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500326 gl::TextureTarget target,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400327 size_t level,
328 const gl::Offset &destOffset,
329 const gl::Rectangle &sourceArea,
330 const gl::Framebuffer *source)
331{
332 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500333 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400334}
335
Jamie Madillc564c072017-06-01 12:45:42 -0400336gl::Error TextureVk::setStorage(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500337 gl::TextureType type,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400338 size_t levels,
339 GLenum internalFormat,
340 const gl::Extents &size)
341{
342 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500343 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400344}
345
Corentin Wallez99d492c2018-02-27 15:17:10 -0500346gl::Error TextureVk::setEGLImageTarget(const gl::Context *context,
347 gl::TextureType type,
348 egl::Image *image)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400349{
350 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500351 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400352}
353
Jamie Madill4928b7c2017-06-20 12:57:39 -0400354gl::Error TextureVk::setImageExternal(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500355 gl::TextureType type,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400356 egl::Stream *stream,
357 const egl::Stream::GLTextureDescription &desc)
358{
359 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500360 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400361}
362
Jamie Madillc564c072017-06-01 12:45:42 -0400363gl::Error TextureVk::generateMipmap(const gl::Context *context)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400364{
365 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500366 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400367}
368
Jamie Madill4928b7c2017-06-20 12:57:39 -0400369gl::Error TextureVk::setBaseLevel(const gl::Context *context, GLuint baseLevel)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400370{
371 UNIMPLEMENTED();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400372 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400373}
374
Jamie Madill4928b7c2017-06-20 12:57:39 -0400375gl::Error TextureVk::bindTexImage(const gl::Context *context, egl::Surface *surface)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400376{
377 UNIMPLEMENTED();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400378 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400379}
380
Jamie Madill4928b7c2017-06-20 12:57:39 -0400381gl::Error TextureVk::releaseTexImage(const gl::Context *context)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400382{
383 UNIMPLEMENTED();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400384 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400385}
386
Jamie Madill4928b7c2017-06-20 12:57:39 -0400387gl::Error TextureVk::getAttachmentRenderTarget(const gl::Context *context,
388 GLenum binding,
Jamie Madill4fd95d52017-04-05 11:22:18 -0400389 const gl::ImageIndex &imageIndex,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400390 FramebufferAttachmentRenderTarget **rtOut)
391{
Corentin Wallez99d492c2018-02-27 15:17:10 -0500392 ASSERT(imageIndex.type == gl::TextureType::_2D);
Jamie Madillb79e7bb2017-10-24 13:55:50 -0400393 ASSERT(imageIndex.mipIndex == 0 && imageIndex.layerIndex == gl::ImageIndex::ENTIRE_LEVEL);
394 *rtOut = &mRenderTarget;
395 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400396}
397
Geoff Lang22416862016-06-08 16:14:36 -0700398void TextureVk::syncState(const gl::Texture::DirtyBits &dirtyBits)
399{
Jamie Madill5547b382017-10-23 18:16:01 -0400400 // TODO(jmadill): Texture sync state.
Geoff Lang22416862016-06-08 16:14:36 -0700401}
402
Jamie Madillc564c072017-06-01 12:45:42 -0400403gl::Error TextureVk::setStorageMultisample(const gl::Context *context,
Corentin Wallez99d492c2018-02-27 15:17:10 -0500404 gl::TextureType type,
JiangYizhoubddc46b2016-12-09 09:50:51 +0800405 GLsizei samples,
406 GLint internalformat,
407 const gl::Extents &size,
Geoff Lang92019432017-11-20 13:09:34 -0500408 bool fixedSampleLocations)
JiangYizhoubddc46b2016-12-09 09:50:51 +0800409{
410 UNIMPLEMENTED();
411 return gl::InternalError() << "setStorageMultisample is unimplemented.";
412}
413
Jamie Madill05b35b22017-10-03 09:01:44 -0400414gl::Error TextureVk::initializeContents(const gl::Context *context,
415 const gl::ImageIndex &imageIndex)
416{
417 UNIMPLEMENTED();
418 return gl::NoError();
419}
420
Jamie Madill5547b382017-10-23 18:16:01 -0400421const vk::Image &TextureVk::getImage() const
422{
423 ASSERT(mImage.valid());
424 return mImage;
425}
426
427const vk::ImageView &TextureVk::getImageView() const
428{
429 ASSERT(mImageView.valid());
430 return mImageView;
431}
432
433const vk::Sampler &TextureVk::getSampler() const
434{
435 ASSERT(mSampler.valid());
436 return mSampler;
437}
438
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400439} // namespace rx