blob: 841fd4d1b5cf04c0fde2449eb6807469a5545344 [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// ContextVk.cpp:
7// Implements the class methods for ContextVk.
8//
9
10#include "libANGLE/renderer/vulkan/ContextVk.h"
11
Jamie Madill20e005b2017-04-07 14:19:22 -040012#include "common/bitset_utils.h"
Jamie Madill9e54b5a2016-05-25 12:57:39 -040013#include "common/debug.h"
Frank Henigmana53d0e12018-02-13 00:06:06 -050014#include "common/utilities.h"
Jamie Madillbd159f02017-10-09 19:39:06 -040015#include "libANGLE/Context.h"
Jamie Madilldf68a6f2017-01-13 17:29:53 -050016#include "libANGLE/Program.h"
Jamie Madillacccc6c2016-05-03 17:22:10 -040017#include "libANGLE/renderer/vulkan/BufferVk.h"
Jamie Madill1f46bc12018-02-20 16:09:43 -050018#include "libANGLE/renderer/vulkan/CommandGraph.h"
Jamie Madillacccc6c2016-05-03 17:22:10 -040019#include "libANGLE/renderer/vulkan/CompilerVk.h"
20#include "libANGLE/renderer/vulkan/ContextVk.h"
21#include "libANGLE/renderer/vulkan/DeviceVk.h"
22#include "libANGLE/renderer/vulkan/FenceNVVk.h"
Jamie Madillacccc6c2016-05-03 17:22:10 -040023#include "libANGLE/renderer/vulkan/FramebufferVk.h"
24#include "libANGLE/renderer/vulkan/ImageVk.h"
Yunchao Hea336b902017-08-02 16:05:21 +080025#include "libANGLE/renderer/vulkan/ProgramPipelineVk.h"
Jamie Madillacccc6c2016-05-03 17:22:10 -040026#include "libANGLE/renderer/vulkan/ProgramVk.h"
27#include "libANGLE/renderer/vulkan/QueryVk.h"
28#include "libANGLE/renderer/vulkan/RenderbufferVk.h"
29#include "libANGLE/renderer/vulkan/RendererVk.h"
30#include "libANGLE/renderer/vulkan/SamplerVk.h"
31#include "libANGLE/renderer/vulkan/ShaderVk.h"
Jamie Madill70b5bb02017-08-28 13:32:37 -040032#include "libANGLE/renderer/vulkan/SyncVk.h"
Jamie Madillacccc6c2016-05-03 17:22:10 -040033#include "libANGLE/renderer/vulkan/TextureVk.h"
34#include "libANGLE/renderer/vulkan/TransformFeedbackVk.h"
35#include "libANGLE/renderer/vulkan/VertexArrayVk.h"
Jamie Madill3c424b42018-01-19 12:35:09 -050036#include "libANGLE/renderer/vulkan/vk_format_utils.h"
Jamie Madill9e54b5a2016-05-25 12:57:39 -040037
38namespace rx
39{
Luc Ferron14f48172018-04-11 08:43:28 -040040
41namespace
42{
43constexpr gl::Rectangle kMaxSizedScissor(0,
44 0,
45 std::numeric_limits<int>::max(),
46 std::numeric_limits<int>::max());
47
Jamie Madill9aef3672018-04-27 11:45:06 -040048constexpr VkColorComponentFlags kAllColorChannelsMask =
49 (VK_COLOR_COMPONENT_R_BIT | VK_COLOR_COMPONENT_G_BIT | VK_COLOR_COMPONENT_B_BIT |
50 VK_COLOR_COMPONENT_A_BIT);
Luc Ferron14f48172018-04-11 08:43:28 -040051} // anonymous namespace
52
Jamie Madillacccc6c2016-05-03 17:22:10 -040053ContextVk::ContextVk(const gl::ContextState &state, RendererVk *renderer)
Jamie Madill49ac74b2017-12-21 14:42:33 -050054 : ContextImpl(state),
55 mRenderer(renderer),
56 mCurrentDrawMode(GL_NONE),
Luc Ferrondaedf4d2018-03-16 09:28:53 -040057 mDynamicDescriptorPool(),
Frank Henigman17448952017-01-05 15:48:26 -050058 mTexturesDirty(false),
Jamie Madill9aef3672018-04-27 11:45:06 -040059 mVertexArrayBindingHasChanged(false),
60 mClearColorMask(kAllColorChannelsMask)
Jamie Madill9e54b5a2016-05-25 12:57:39 -040061{
Jamie Madillf4d693c2018-02-14 16:38:16 -050062 memset(&mClearColorValue, 0, sizeof(mClearColorValue));
63 memset(&mClearDepthStencilValue, 0, sizeof(mClearDepthStencilValue));
Jamie Madill9e54b5a2016-05-25 12:57:39 -040064}
65
66ContextVk::~ContextVk()
67{
68}
69
Jamie Madill76e471e2017-10-21 09:56:01 -040070void ContextVk::onDestroy(const gl::Context *context)
71{
Luc Ferrondaedf4d2018-03-16 09:28:53 -040072 mDynamicDescriptorPool.destroy(mRenderer);
Jamie Madill76e471e2017-10-21 09:56:01 -040073}
74
Jamie Madill9e54b5a2016-05-25 12:57:39 -040075gl::Error ContextVk::initialize()
76{
Luc Ferrondaedf4d2018-03-16 09:28:53 -040077 ANGLE_TRY(mDynamicDescriptorPool.init(this->getDevice(),
78 mRenderer->getUniformBufferDescriptorCount(),
79 mRenderer->getMaxActiveTextures()));
Jamie Madill76e471e2017-10-21 09:56:01 -040080
Jamie Madillf2f6d372018-01-10 21:37:23 -050081 mPipelineDesc.reset(new vk::PipelineDesc());
82 mPipelineDesc->initDefaults();
83
Jamie Madille09bd5d2016-11-29 16:20:35 -050084 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -040085}
86
Jamie Madillafa02a22017-11-23 12:57:38 -050087gl::Error ContextVk::flush(const gl::Context *context)
Jamie Madill9e54b5a2016-05-25 12:57:39 -040088{
Jamie Madill49ac74b2017-12-21 14:42:33 -050089 // TODO(jmadill): Flush will need to insert a semaphore for the next flush to wait on.
Jamie Madill9e54b5a2016-05-25 12:57:39 -040090 UNIMPLEMENTED();
Luc Ferron33140402018-03-08 13:57:52 -050091
92 // dEQP tests rely on having no errors thrown at the end of the test and they always call
93 // flush at the end of the their tests. Just returning NoError until we implement flush
94 // allow us to work on enabling many tests in the meantime.
95 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -040096}
97
Jamie Madillafa02a22017-11-23 12:57:38 -050098gl::Error ContextVk::finish(const gl::Context *context)
Jamie Madill9e54b5a2016-05-25 12:57:39 -040099{
Jamie Madill49ac74b2017-12-21 14:42:33 -0500100 return mRenderer->finish(context);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400101}
102
Jamie Madillb90779e2018-04-27 11:45:01 -0400103gl::Error ContextVk::initPipeline()
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400104{
Jamie Madillffa4cbb2018-01-23 13:04:07 -0500105 ASSERT(!mCurrentPipeline);
Jamie Madill72106562017-03-24 14:18:50 -0400106
Jamie Madillf2f6d372018-01-10 21:37:23 -0500107 const gl::State &state = mState.getState();
108 VertexArrayVk *vertexArrayVk = vk::GetImpl(state.getVertexArray());
109 FramebufferVk *framebufferVk = vk::GetImpl(state.getDrawFramebuffer());
110 ProgramVk *programVk = vk::GetImpl(state.getProgram());
Luc Ferronceb71902018-02-05 15:18:47 -0500111 const gl::AttributesMask activeAttribLocationsMask =
112 state.getProgram()->getActiveAttribLocationsMask();
Jamie Madillf2f6d372018-01-10 21:37:23 -0500113
114 // Ensure the topology of the pipeline description is updated.
115 mPipelineDesc->updateTopology(mCurrentDrawMode);
Jamie Madilldf68a6f2017-01-13 17:29:53 -0500116
Jamie Madill112a3a82018-01-23 13:04:06 -0500117 // Copy over the latest attrib and binding descriptions.
118 vertexArrayVk->getPackedInputDescriptions(mPipelineDesc.get());
Jamie Madilldf68a6f2017-01-13 17:29:53 -0500119
Jamie Madillf2f6d372018-01-10 21:37:23 -0500120 // Ensure that the RenderPass description is updated.
Jamie Madillb90779e2018-04-27 11:45:01 -0400121 mPipelineDesc->updateRenderPassDesc(framebufferVk->getRenderPassDesc());
Jamie Madilldf68a6f2017-01-13 17:29:53 -0500122
123 // TODO(jmadill): Validate with ASSERT against physical device limits/caps?
Jamie Madill9aef3672018-04-27 11:45:06 -0400124 ANGLE_TRY(mRenderer->getAppPipeline(programVk, *mPipelineDesc, activeAttribLocationsMask,
125 &mCurrentPipeline));
Jamie Madilldf68a6f2017-01-13 17:29:53 -0500126
Jamie Madill72106562017-03-24 14:18:50 -0400127 return gl::NoError();
128}
129
Jamie Madillb90779e2018-04-27 11:45:01 -0400130gl::Error ContextVk::setupDraw(const gl::DrawCallParams &drawCallParams,
Jamie Madillc3755fc2018-04-05 08:39:13 -0400131 vk::CommandGraphNode **drawNodeOut,
132 bool *newCommandBufferOut)
Jamie Madill72106562017-03-24 14:18:50 -0400133{
Jamie Madill32fd63b2018-03-31 11:20:35 -0400134 if (drawCallParams.mode() != mCurrentDrawMode)
Jamie Madill72106562017-03-24 14:18:50 -0400135 {
136 invalidateCurrentPipeline();
Jamie Madill32fd63b2018-03-31 11:20:35 -0400137 mCurrentDrawMode = drawCallParams.mode();
Jamie Madill72106562017-03-24 14:18:50 -0400138 }
139
Jamie Madillffa4cbb2018-01-23 13:04:07 -0500140 if (!mCurrentPipeline)
Jamie Madill72106562017-03-24 14:18:50 -0400141 {
Jamie Madillb90779e2018-04-27 11:45:01 -0400142 ANGLE_TRY(initPipeline());
Jamie Madill72106562017-03-24 14:18:50 -0400143 }
144
Frank Henigman17448952017-01-05 15:48:26 -0500145 const auto &state = mState.getState();
Jamie Madillacf2f3a2017-11-21 19:22:44 -0500146 const gl::Program *programGL = state.getProgram();
Frank Henigman17448952017-01-05 15:48:26 -0500147 ProgramVk *programVk = vk::GetImpl(programGL);
Frank Henigman17448952017-01-05 15:48:26 -0500148 const auto *drawFBO = state.getDrawFramebuffer();
149 FramebufferVk *vkFBO = vk::GetImpl(drawFBO);
Luc Ferronf8be7562018-02-06 15:59:11 -0500150 Serial queueSerial = mRenderer->getCurrentQueueSerial();
Jamie Madill72106562017-03-24 14:18:50 -0400151
Jamie Madille4c5a232018-03-02 21:00:31 -0500152 vk::CommandGraphNode *graphNode = nullptr;
Jamie Madillb90779e2018-04-27 11:45:01 -0400153 ANGLE_TRY(vkFBO->getCommandGraphNodeForDraw(this, &graphNode));
Jamie Madilldf68a6f2017-01-13 17:29:53 -0500154
Jamie Madill32fd63b2018-03-31 11:20:35 -0400155 vk::CommandBuffer *commandBuffer = nullptr;
156
Jamie Madille4c5a232018-03-02 21:00:31 -0500157 if (!graphNode->getInsideRenderPassCommands()->valid())
Jamie Madill49ac74b2017-12-21 14:42:33 -0500158 {
Jamie Madill49ac74b2017-12-21 14:42:33 -0500159 mTexturesDirty = true;
Jamie Madillc3755fc2018-04-05 08:39:13 -0400160 *newCommandBufferOut = true;
Jamie Madill32fd63b2018-03-31 11:20:35 -0400161 ANGLE_TRY(graphNode->beginInsideRenderPassRecording(mRenderer, &commandBuffer));
Jamie Madill49ac74b2017-12-21 14:42:33 -0500162 }
163 else
164 {
Jamie Madillc3755fc2018-04-05 08:39:13 -0400165 *newCommandBufferOut = mVertexArrayBindingHasChanged;
166 mVertexArrayBindingHasChanged = false;
167 commandBuffer = graphNode->getInsideRenderPassCommands();
Jamie Madill49ac74b2017-12-21 14:42:33 -0500168 }
169
170 // Ensure any writes to the textures are flushed before we read from them.
171 if (mTexturesDirty)
172 {
173 mTexturesDirty = false;
174 // TODO(jmadill): Should probably merge this for loop with programVk's descriptor update.
175 const auto &completeTextures = state.getCompleteTextureCache();
176 for (const gl::SamplerBinding &samplerBinding : programGL->getSamplerBindings())
177 {
178 ASSERT(!samplerBinding.unreferenced);
179
180 // TODO(jmadill): Sampler arrays
181 ASSERT(samplerBinding.boundTextureUnits.size() == 1);
182
183 GLuint textureUnit = samplerBinding.boundTextureUnits[0];
184 const gl::Texture *texture = completeTextures[textureUnit];
185
186 // TODO(jmadill): Incomplete textures handling.
187 ASSERT(texture);
188
189 TextureVk *textureVk = vk::GetImpl(texture);
Jamie Madill26084d02018-04-09 13:44:04 -0400190 ANGLE_TRY(textureVk->ensureImageInitialized(mRenderer));
Jamie Madille4c5a232018-03-02 21:00:31 -0500191 textureVk->onReadResource(graphNode, mRenderer->getCurrentQueueSerial());
Jamie Madill49ac74b2017-12-21 14:42:33 -0500192 }
193 }
194
Jamie Madill32fd63b2018-03-31 11:20:35 -0400195 commandBuffer->bindPipeline(VK_PIPELINE_BIND_POINT_GRAPHICS, mCurrentPipeline->get());
Jamie Madill49ac74b2017-12-21 14:42:33 -0500196
197 // Update the queue serial for the pipeline object.
Jamie Madillffa4cbb2018-01-23 13:04:07 -0500198 ASSERT(mCurrentPipeline && mCurrentPipeline->valid());
199 mCurrentPipeline->updateSerial(queueSerial);
Jamie Madilldf68a6f2017-01-13 17:29:53 -0500200
Jamie Madill76e471e2017-10-21 09:56:01 -0400201 // TODO(jmadill): Can probably use more dirty bits here.
Jamie Madill49ac74b2017-12-21 14:42:33 -0500202 ANGLE_TRY(programVk->updateUniforms(this));
Luc Ferron6ea1b412018-03-21 16:13:01 -0400203 ANGLE_TRY(programVk->updateTexturesDescriptorSet(this));
Jamie Madill76e471e2017-10-21 09:56:01 -0400204
205 // Bind the graphics descriptor sets.
206 // TODO(jmadill): Handle multiple command buffers.
Jamie Madill5547b382017-10-23 18:16:01 -0400207 const auto &descriptorSets = programVk->getDescriptorSets();
Jamie Madill8c3988c2017-12-21 14:44:56 -0500208 const gl::RangeUI &usedRange = programVk->getUsedDescriptorSetRange();
209 if (!usedRange.empty())
Jamie Madill76e471e2017-10-21 09:56:01 -0400210 {
Jamie Madill8c3988c2017-12-21 14:44:56 -0500211 ASSERT(!descriptorSets.empty());
212 const vk::PipelineLayout &pipelineLayout = mRenderer->getGraphicsPipelineLayout();
Luc Ferron7a06ac12018-03-15 10:17:04 -0400213
Jamie Madill32fd63b2018-03-31 11:20:35 -0400214 commandBuffer->bindDescriptorSets(
215 VK_PIPELINE_BIND_POINT_GRAPHICS, pipelineLayout, usedRange.low(), usedRange.length(),
216 &descriptorSets[usedRange.low()], programVk->getDynamicOffsetsCount(),
217 programVk->getDynamicOffsets());
Jamie Madill76e471e2017-10-21 09:56:01 -0400218 }
219
Jamie Madillc3755fc2018-04-05 08:39:13 -0400220 *drawNodeOut = graphNode;
Jamie Madilldf68a6f2017-01-13 17:29:53 -0500221 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400222}
223
Jamie Madilld03a8492017-10-03 15:46:06 -0400224gl::Error ContextVk::drawArrays(const gl::Context *context, GLenum mode, GLint first, GLsizei count)
225{
Jamie Madill32fd63b2018-03-31 11:20:35 -0400226 const gl::DrawCallParams &drawCallParams = context->getParams<gl::DrawCallParams>();
227
Jamie Madillc3755fc2018-04-05 08:39:13 -0400228 vk::CommandGraphNode *drawNode = nullptr;
229 bool newCommands = false;
Jamie Madillb90779e2018-04-27 11:45:01 -0400230 ANGLE_TRY(setupDraw(drawCallParams, &drawNode, &newCommands));
Luc Ferron360098d2018-02-21 07:33:50 -0500231
Jamie Madillc3755fc2018-04-05 08:39:13 -0400232 const gl::VertexArray *vertexArray = context->getGLState().getVertexArray();
233 VertexArrayVk *vertexArrayVk = vk::GetImpl(vertexArray);
234 ANGLE_TRY(vertexArrayVk->drawArrays(context, mRenderer, drawCallParams, drawNode, newCommands));
Luc Ferron360098d2018-02-21 07:33:50 -0500235
Jamie Madilld03a8492017-10-03 15:46:06 -0400236 return gl::NoError();
237}
238
Jamie Madillc564c072017-06-01 12:45:42 -0400239gl::Error ContextVk::drawArraysInstanced(const gl::Context *context,
240 GLenum mode,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400241 GLint first,
242 GLsizei count,
243 GLsizei instanceCount)
244{
245 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500246 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400247}
248
Jamie Madillc564c072017-06-01 12:45:42 -0400249gl::Error ContextVk::drawElements(const gl::Context *context,
250 GLenum mode,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400251 GLsizei count,
252 GLenum type,
Qin Jiajia1da00652017-06-20 17:16:25 +0800253 const void *indices)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400254{
Jamie Madill32fd63b2018-03-31 11:20:35 -0400255 const gl::DrawCallParams &drawCallParams = context->getParams<gl::DrawCallParams>();
256
Jamie Madillc3755fc2018-04-05 08:39:13 -0400257 vk::CommandGraphNode *drawNode = nullptr;
258 bool newCommands = false;
Jamie Madillb90779e2018-04-27 11:45:01 -0400259 ANGLE_TRY(setupDraw(drawCallParams, &drawNode, &newCommands));
Jamie Madilld03a8492017-10-03 15:46:06 -0400260
Jamie Madillc3755fc2018-04-05 08:39:13 -0400261 gl::VertexArray *vao = mState.getState().getVertexArray();
262 VertexArrayVk *vertexArrayVk = vk::GetImpl(vao);
263 ANGLE_TRY(
264 vertexArrayVk->drawElements(context, mRenderer, drawCallParams, drawNode, newCommands));
Jamie Madilld03a8492017-10-03 15:46:06 -0400265
266 return gl::NoError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400267}
268
Jamie Madillc564c072017-06-01 12:45:42 -0400269gl::Error ContextVk::drawElementsInstanced(const gl::Context *context,
270 GLenum mode,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400271 GLsizei count,
272 GLenum type,
Jamie Madill876429b2017-04-20 15:46:24 -0400273 const void *indices,
Qin Jiajia1da00652017-06-20 17:16:25 +0800274 GLsizei instances)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400275{
276 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500277 return gl::InternalError();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400278}
279
Jamie Madillc564c072017-06-01 12:45:42 -0400280gl::Error ContextVk::drawRangeElements(const gl::Context *context,
281 GLenum mode,
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400282 GLuint start,
283 GLuint end,
284 GLsizei count,
285 GLenum type,
Qin Jiajia1da00652017-06-20 17:16:25 +0800286 const void *indices)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400287{
Jamie Madill7b57b9d2017-01-13 09:33:38 -0500288 return gl::NoError();
289}
290
291VkDevice ContextVk::getDevice() const
292{
293 return mRenderer->getDevice();
294}
295
Jamie Madillc564c072017-06-01 12:45:42 -0400296gl::Error ContextVk::drawArraysIndirect(const gl::Context *context,
297 GLenum mode,
298 const void *indirect)
Jiajia Qind9671222016-11-29 16:30:31 +0800299{
300 UNIMPLEMENTED();
301 return gl::InternalError() << "DrawArraysIndirect hasn't been implemented for vulkan backend.";
302}
303
Jamie Madillc564c072017-06-01 12:45:42 -0400304gl::Error ContextVk::drawElementsIndirect(const gl::Context *context,
305 GLenum mode,
306 GLenum type,
307 const void *indirect)
Jiajia Qind9671222016-11-29 16:30:31 +0800308{
309 UNIMPLEMENTED();
310 return gl::InternalError()
311 << "DrawElementsIndirect hasn't been implemented for vulkan backend.";
312}
313
Corentin Wallez87fbe1c2016-08-03 14:41:42 -0400314GLenum ContextVk::getResetStatus()
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400315{
316 UNIMPLEMENTED();
Corentin Wallez87fbe1c2016-08-03 14:41:42 -0400317 return GL_NO_ERROR;
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400318}
319
320std::string ContextVk::getVendorString() const
321{
322 UNIMPLEMENTED();
323 return std::string();
324}
325
326std::string ContextVk::getRendererDescription() const
327{
Jamie Madille09bd5d2016-11-29 16:20:35 -0500328 return mRenderer->getRendererDescription();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400329}
330
331void ContextVk::insertEventMarker(GLsizei length, const char *marker)
332{
333 UNIMPLEMENTED();
334}
335
336void ContextVk::pushGroupMarker(GLsizei length, const char *marker)
337{
338 UNIMPLEMENTED();
339}
340
341void ContextVk::popGroupMarker()
342{
343 UNIMPLEMENTED();
344}
345
Geoff Lang5d5253a2017-11-22 14:51:12 -0500346void ContextVk::pushDebugGroup(GLenum source, GLuint id, GLsizei length, const char *message)
347{
348 UNIMPLEMENTED();
349}
350
351void ContextVk::popDebugGroup()
352{
353 UNIMPLEMENTED();
354}
355
Luc Ferrond17bdfe2018-04-05 13:50:10 -0400356void ContextVk::updateScissor(const gl::State &glState)
357{
358 if (glState.isScissorTestEnabled())
359 {
Luc Ferron14f48172018-04-11 08:43:28 -0400360 mPipelineDesc->updateScissor(glState.getScissor());
Luc Ferrond17bdfe2018-04-05 13:50:10 -0400361 }
362 else
363 {
Luc Ferron14f48172018-04-11 08:43:28 -0400364 // If the scissor test isn't enabled, we can simply use a really big scissor that's
365 // certainly larger than the current surface using the maximum size of a 2D texture
366 // for the width and height.
367 mPipelineDesc->updateScissor(kMaxSizedScissor);
Luc Ferrond17bdfe2018-04-05 13:50:10 -0400368 }
369}
370
Jamie Madillfe548342017-06-19 11:13:24 -0400371void ContextVk::syncState(const gl::Context *context, const gl::State::DirtyBits &dirtyBits)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400372{
Jamie Madill72106562017-03-24 14:18:50 -0400373 if (dirtyBits.any())
374 {
375 invalidateCurrentPipeline();
376 }
Jamie Madillebf72992017-10-13 14:09:45 -0400377
378 const auto &glState = context->getGLState();
379
380 // TODO(jmadill): Full dirty bits implementation.
Jamie Madill5547b382017-10-23 18:16:01 -0400381 bool dirtyTextures = false;
Jamie Madillebf72992017-10-13 14:09:45 -0400382
383 for (auto dirtyBit : dirtyBits)
384 {
385 switch (dirtyBit)
386 {
387 case gl::State::DIRTY_BIT_SCISSOR_TEST_ENABLED:
Jamie Madillebf72992017-10-13 14:09:45 -0400388 case gl::State::DIRTY_BIT_SCISSOR:
Luc Ferron14f48172018-04-11 08:43:28 -0400389 updateScissor(glState);
Jamie Madillebf72992017-10-13 14:09:45 -0400390 break;
391 case gl::State::DIRTY_BIT_VIEWPORT:
Jamie Madillf2f6d372018-01-10 21:37:23 -0500392 mPipelineDesc->updateViewport(glState.getViewport(), glState.getNearPlane(),
393 glState.getFarPlane());
Jamie Madillebf72992017-10-13 14:09:45 -0400394 break;
Jamie Madillebf72992017-10-13 14:09:45 -0400395 case gl::State::DIRTY_BIT_DEPTH_RANGE:
Luc Ferron0986f1c2018-04-16 13:47:23 -0400396 mPipelineDesc->updateDepthRange(glState.getNearPlane(), glState.getFarPlane());
Jamie Madillebf72992017-10-13 14:09:45 -0400397 break;
398 case gl::State::DIRTY_BIT_BLEND_ENABLED:
Luc Ferronf8be7562018-02-06 15:59:11 -0500399 mPipelineDesc->updateBlendEnabled(glState.isBlendEnabled());
Jamie Madillebf72992017-10-13 14:09:45 -0400400 break;
401 case gl::State::DIRTY_BIT_BLEND_COLOR:
Luc Ferronf8be7562018-02-06 15:59:11 -0500402 mPipelineDesc->updateBlendColor(glState.getBlendColor());
Jamie Madillebf72992017-10-13 14:09:45 -0400403 break;
404 case gl::State::DIRTY_BIT_BLEND_FUNCS:
Luc Ferronf8be7562018-02-06 15:59:11 -0500405 mPipelineDesc->updateBlendFuncs(glState.getBlendState());
Jamie Madillebf72992017-10-13 14:09:45 -0400406 break;
407 case gl::State::DIRTY_BIT_BLEND_EQUATIONS:
Luc Ferronf8be7562018-02-06 15:59:11 -0500408 mPipelineDesc->updateBlendEquations(glState.getBlendState());
Jamie Madillebf72992017-10-13 14:09:45 -0400409 break;
410 case gl::State::DIRTY_BIT_COLOR_MASK:
Jamie Madill9aef3672018-04-27 11:45:06 -0400411 {
412 const gl::BlendState &blendState = glState.getBlendState();
413 mClearColorMask = gl_vk::GetColorComponentFlags(
414 blendState.colorMaskRed, blendState.colorMaskGreen, blendState.colorMaskBlue,
415 blendState.colorMaskAlpha);
416 mPipelineDesc->updateColorWriteMask(mClearColorMask);
Jamie Madillebf72992017-10-13 14:09:45 -0400417 break;
Jamie Madill9aef3672018-04-27 11:45:06 -0400418 }
Jamie Madillebf72992017-10-13 14:09:45 -0400419 case gl::State::DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED:
420 WARN() << "DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED unimplemented";
421 break;
422 case gl::State::DIRTY_BIT_SAMPLE_COVERAGE_ENABLED:
423 WARN() << "DIRTY_BIT_SAMPLE_COVERAGE_ENABLED unimplemented";
424 break;
425 case gl::State::DIRTY_BIT_SAMPLE_COVERAGE:
426 WARN() << "DIRTY_BIT_SAMPLE_COVERAGE unimplemented";
427 break;
428 case gl::State::DIRTY_BIT_SAMPLE_MASK_ENABLED:
429 WARN() << "DIRTY_BIT_SAMPLE_MASK_ENABLED unimplemented";
430 break;
Jamie Madillc67323a2017-11-02 23:11:41 -0400431 case gl::State::DIRTY_BIT_SAMPLE_MASK:
432 WARN() << "DIRTY_BIT_SAMPLE_MASK unimplemented";
Jamie Madillebf72992017-10-13 14:09:45 -0400433 break;
434 case gl::State::DIRTY_BIT_DEPTH_TEST_ENABLED:
Jamie Madill0cec82a2018-03-14 09:21:07 -0400435 mPipelineDesc->updateDepthTestEnabled(glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400436 break;
437 case gl::State::DIRTY_BIT_DEPTH_FUNC:
Jamie Madill0cec82a2018-03-14 09:21:07 -0400438 mPipelineDesc->updateDepthFunc(glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400439 break;
440 case gl::State::DIRTY_BIT_DEPTH_MASK:
Luc Ferrondd196e02018-04-04 11:41:44 -0400441 mPipelineDesc->updateDepthWriteEnabled(glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400442 break;
443 case gl::State::DIRTY_BIT_STENCIL_TEST_ENABLED:
Luc Ferron364a9552018-03-29 09:44:51 -0400444 mPipelineDesc->updateStencilTestEnabled(glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400445 break;
446 case gl::State::DIRTY_BIT_STENCIL_FUNCS_FRONT:
Luc Ferron364a9552018-03-29 09:44:51 -0400447 mPipelineDesc->updateStencilFrontFuncs(glState.getStencilRef(),
448 glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400449 break;
450 case gl::State::DIRTY_BIT_STENCIL_FUNCS_BACK:
Luc Ferron364a9552018-03-29 09:44:51 -0400451 mPipelineDesc->updateStencilBackFuncs(glState.getStencilBackRef(),
452 glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400453 break;
454 case gl::State::DIRTY_BIT_STENCIL_OPS_FRONT:
Luc Ferron364a9552018-03-29 09:44:51 -0400455 mPipelineDesc->updateStencilFrontOps(glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400456 break;
457 case gl::State::DIRTY_BIT_STENCIL_OPS_BACK:
Luc Ferron364a9552018-03-29 09:44:51 -0400458 mPipelineDesc->updateStencilBackOps(glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400459 break;
460 case gl::State::DIRTY_BIT_STENCIL_WRITEMASK_FRONT:
Luc Ferron364a9552018-03-29 09:44:51 -0400461 mPipelineDesc->updateStencilFrontWriteMask(glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400462 break;
463 case gl::State::DIRTY_BIT_STENCIL_WRITEMASK_BACK:
Luc Ferron364a9552018-03-29 09:44:51 -0400464 mPipelineDesc->updateStencilBackWriteMask(glState.getDepthStencilState());
Jamie Madillebf72992017-10-13 14:09:45 -0400465 break;
466 case gl::State::DIRTY_BIT_CULL_FACE_ENABLED:
467 case gl::State::DIRTY_BIT_CULL_FACE:
Jamie Madillf2f6d372018-01-10 21:37:23 -0500468 mPipelineDesc->updateCullMode(glState.getRasterizerState());
Jamie Madillebf72992017-10-13 14:09:45 -0400469 break;
470 case gl::State::DIRTY_BIT_FRONT_FACE:
Jamie Madillf2f6d372018-01-10 21:37:23 -0500471 mPipelineDesc->updateFrontFace(glState.getRasterizerState());
Jamie Madillebf72992017-10-13 14:09:45 -0400472 break;
473 case gl::State::DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED:
474 WARN() << "DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED unimplemented";
475 break;
476 case gl::State::DIRTY_BIT_POLYGON_OFFSET:
477 WARN() << "DIRTY_BIT_POLYGON_OFFSET unimplemented";
478 break;
479 case gl::State::DIRTY_BIT_RASTERIZER_DISCARD_ENABLED:
480 WARN() << "DIRTY_BIT_RASTERIZER_DISCARD_ENABLED unimplemented";
481 break;
482 case gl::State::DIRTY_BIT_LINE_WIDTH:
Jamie Madillf2f6d372018-01-10 21:37:23 -0500483 mPipelineDesc->updateLineWidth(glState.getLineWidth());
Jamie Madillebf72992017-10-13 14:09:45 -0400484 break;
485 case gl::State::DIRTY_BIT_PRIMITIVE_RESTART_ENABLED:
486 WARN() << "DIRTY_BIT_PRIMITIVE_RESTART_ENABLED unimplemented";
487 break;
488 case gl::State::DIRTY_BIT_CLEAR_COLOR:
Jamie Madillf4d693c2018-02-14 16:38:16 -0500489 mClearColorValue.color.float32[0] = glState.getColorClearValue().red;
490 mClearColorValue.color.float32[1] = glState.getColorClearValue().green;
491 mClearColorValue.color.float32[2] = glState.getColorClearValue().blue;
492 mClearColorValue.color.float32[3] = glState.getColorClearValue().alpha;
Jamie Madillebf72992017-10-13 14:09:45 -0400493 break;
494 case gl::State::DIRTY_BIT_CLEAR_DEPTH:
Jamie Madillf4d693c2018-02-14 16:38:16 -0500495 mClearDepthStencilValue.depthStencil.depth = glState.getDepthClearValue();
Jamie Madillebf72992017-10-13 14:09:45 -0400496 break;
497 case gl::State::DIRTY_BIT_CLEAR_STENCIL:
Jamie Madillf4d693c2018-02-14 16:38:16 -0500498 mClearDepthStencilValue.depthStencil.stencil =
499 static_cast<uint32_t>(glState.getStencilClearValue());
Jamie Madillebf72992017-10-13 14:09:45 -0400500 break;
Jamie Madillc67323a2017-11-02 23:11:41 -0400501 case gl::State::DIRTY_BIT_UNPACK_STATE:
Luc Ferronf9749ea2018-04-24 15:34:53 -0400502 // This is a no-op, its only important to use the right unpack state when we do
503 // setImage or setSubImage in TextureVk, which is plumbed through the frontend call
Jamie Madillebf72992017-10-13 14:09:45 -0400504 break;
Corentin Wallez29a20992017-11-06 18:23:16 -0500505 case gl::State::DIRTY_BIT_UNPACK_BUFFER_BINDING:
506 WARN() << "DIRTY_BIT_UNPACK_BUFFER_BINDING unimplemented";
507 break;
Jamie Madillc67323a2017-11-02 23:11:41 -0400508 case gl::State::DIRTY_BIT_PACK_STATE:
509 WARN() << "DIRTY_BIT_PACK_STATE unimplemented";
Jamie Madillebf72992017-10-13 14:09:45 -0400510 break;
Corentin Wallez29a20992017-11-06 18:23:16 -0500511 case gl::State::DIRTY_BIT_PACK_BUFFER_BINDING:
512 WARN() << "DIRTY_BIT_PACK_BUFFER_BINDING unimplemented";
513 break;
Jamie Madillebf72992017-10-13 14:09:45 -0400514 case gl::State::DIRTY_BIT_DITHER_ENABLED:
515 WARN() << "DIRTY_BIT_DITHER_ENABLED unimplemented";
516 break;
517 case gl::State::DIRTY_BIT_GENERATE_MIPMAP_HINT:
518 WARN() << "DIRTY_BIT_GENERATE_MIPMAP_HINT unimplemented";
519 break;
520 case gl::State::DIRTY_BIT_SHADER_DERIVATIVE_HINT:
521 WARN() << "DIRTY_BIT_SHADER_DERIVATIVE_HINT unimplemented";
522 break;
523 case gl::State::DIRTY_BIT_READ_FRAMEBUFFER_BINDING:
524 WARN() << "DIRTY_BIT_READ_FRAMEBUFFER_BINDING unimplemented";
525 break;
526 case gl::State::DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING:
527 WARN() << "DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING unimplemented";
528 break;
529 case gl::State::DIRTY_BIT_RENDERBUFFER_BINDING:
530 WARN() << "DIRTY_BIT_RENDERBUFFER_BINDING unimplemented";
531 break;
532 case gl::State::DIRTY_BIT_VERTEX_ARRAY_BINDING:
Jamie Madillc3755fc2018-04-05 08:39:13 -0400533 invalidateCurrentPipeline();
534 mVertexArrayBindingHasChanged = true;
Jamie Madillebf72992017-10-13 14:09:45 -0400535 break;
536 case gl::State::DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING:
537 WARN() << "DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING unimplemented";
538 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +0800539 case gl::State::DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING:
540 WARN() << "DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING unimplemented";
541 break;
Jamie Madillebf72992017-10-13 14:09:45 -0400542 case gl::State::DIRTY_BIT_PROGRAM_BINDING:
Jamie Madillebf72992017-10-13 14:09:45 -0400543 break;
544 case gl::State::DIRTY_BIT_PROGRAM_EXECUTABLE:
545 {
Jamie Madillf2f6d372018-01-10 21:37:23 -0500546 ProgramVk *programVk = vk::GetImpl(glState.getProgram());
Jamie Madill78feddc2018-04-27 11:45:05 -0400547 mPipelineDesc->updateShaders(programVk->getVertexModuleSerial(),
548 programVk->getFragmentModuleSerial());
Jamie Madill5547b382017-10-23 18:16:01 -0400549 dirtyTextures = true;
Jamie Madillebf72992017-10-13 14:09:45 -0400550 break;
551 }
552 case gl::State::DIRTY_BIT_TEXTURE_BINDINGS:
Jamie Madill5547b382017-10-23 18:16:01 -0400553 dirtyTextures = true;
Jamie Madillebf72992017-10-13 14:09:45 -0400554 break;
555 case gl::State::DIRTY_BIT_SAMPLER_BINDINGS:
Jamie Madill5547b382017-10-23 18:16:01 -0400556 dirtyTextures = true;
Jamie Madillebf72992017-10-13 14:09:45 -0400557 break;
Geoff Langded79232017-11-28 15:21:11 -0500558 case gl::State::DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING:
559 WARN() << "DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING unimplemented";
560 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +0800561 case gl::State::DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING:
562 WARN() << "DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING unimplemented";
563 break;
Jamie Madillf4141212017-12-12 15:08:07 -0500564 case gl::State::DIRTY_BIT_UNIFORM_BUFFER_BINDINGS:
565 WARN() << "DIRTY_BIT_UNIFORM_BUFFER_BINDINGS unimplemented";
566 break;
Jamie Madillebf72992017-10-13 14:09:45 -0400567 case gl::State::DIRTY_BIT_MULTISAMPLING:
568 WARN() << "DIRTY_BIT_MULTISAMPLING unimplemented";
569 break;
570 case gl::State::DIRTY_BIT_SAMPLE_ALPHA_TO_ONE:
571 WARN() << "DIRTY_BIT_SAMPLE_ALPHA_TO_ONE unimplemented";
572 break;
573 case gl::State::DIRTY_BIT_COVERAGE_MODULATION:
574 WARN() << "DIRTY_BIT_COVERAGE_MODULATION unimplemented";
575 break;
576 case gl::State::DIRTY_BIT_PATH_RENDERING_MATRIX_MV:
577 WARN() << "DIRTY_BIT_PATH_RENDERING_MATRIX_MV unimplemented";
578 break;
579 case gl::State::DIRTY_BIT_PATH_RENDERING_MATRIX_PROJ:
580 WARN() << "DIRTY_BIT_PATH_RENDERING_MATRIX_PROJ unimplemented";
581 break;
582 case gl::State::DIRTY_BIT_PATH_RENDERING_STENCIL_STATE:
583 WARN() << "DIRTY_BIT_PATH_RENDERING_STENCIL_STATE unimplemented";
584 break;
585 case gl::State::DIRTY_BIT_FRAMEBUFFER_SRGB:
586 WARN() << "DIRTY_BIT_FRAMEBUFFER_SRGB unimplemented";
587 break;
Jamie Madillc67323a2017-11-02 23:11:41 -0400588 case gl::State::DIRTY_BIT_CURRENT_VALUES:
589 WARN() << "DIRTY_BIT_CURRENT_VALUES unimplemented";
590 break;
Jamie Madillebf72992017-10-13 14:09:45 -0400591 default:
Jamie Madillc67323a2017-11-02 23:11:41 -0400592 UNREACHABLE();
Jamie Madillebf72992017-10-13 14:09:45 -0400593 break;
594 }
595 }
Jamie Madill5547b382017-10-23 18:16:01 -0400596
597 if (dirtyTextures)
598 {
Jamie Madille1f3ad42017-10-28 23:00:42 -0400599 ProgramVk *programVk = vk::GetImpl(glState.getProgram());
Jamie Madill5547b382017-10-23 18:16:01 -0400600 programVk->invalidateTextures();
Jamie Madill49ac74b2017-12-21 14:42:33 -0500601 mTexturesDirty = true;
Jamie Madill5547b382017-10-23 18:16:01 -0400602 }
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400603}
604
605GLint ContextVk::getGPUDisjoint()
606{
607 UNIMPLEMENTED();
608 return GLint();
609}
610
611GLint64 ContextVk::getTimestamp()
612{
613 UNIMPLEMENTED();
614 return GLint64();
615}
616
Jamie Madill4928b7c2017-06-20 12:57:39 -0400617void ContextVk::onMakeCurrent(const gl::Context * /*context*/)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400618{
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400619}
620
621const gl::Caps &ContextVk::getNativeCaps() const
622{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400623 return mRenderer->getNativeCaps();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400624}
625
626const gl::TextureCapsMap &ContextVk::getNativeTextureCaps() const
627{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400628 return mRenderer->getNativeTextureCaps();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400629}
630
631const gl::Extensions &ContextVk::getNativeExtensions() const
632{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400633 return mRenderer->getNativeExtensions();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400634}
635
636const gl::Limitations &ContextVk::getNativeLimitations() const
637{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400638 return mRenderer->getNativeLimitations();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400639}
640
641CompilerImpl *ContextVk::createCompiler()
642{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400643 return new CompilerVk();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400644}
645
Jamie Madillacccc6c2016-05-03 17:22:10 -0400646ShaderImpl *ContextVk::createShader(const gl::ShaderState &state)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400647{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400648 return new ShaderVk(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400649}
650
Jamie Madillacccc6c2016-05-03 17:22:10 -0400651ProgramImpl *ContextVk::createProgram(const gl::ProgramState &state)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400652{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400653 return new ProgramVk(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400654}
655
Jamie Madillacccc6c2016-05-03 17:22:10 -0400656FramebufferImpl *ContextVk::createFramebuffer(const gl::FramebufferState &state)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400657{
Jamie Madill7b57b9d2017-01-13 09:33:38 -0500658 return FramebufferVk::CreateUserFBO(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400659}
660
661TextureImpl *ContextVk::createTexture(const gl::TextureState &state)
662{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400663 return new TextureVk(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400664}
665
Jamie Madille703c602018-02-20 10:21:48 -0500666RenderbufferImpl *ContextVk::createRenderbuffer(const gl::RenderbufferState &state)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400667{
Jamie Madille703c602018-02-20 10:21:48 -0500668 return new RenderbufferVk(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400669}
670
Jamie Madill8f775602016-11-03 16:45:34 -0400671BufferImpl *ContextVk::createBuffer(const gl::BufferState &state)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400672{
Jamie Madill8f775602016-11-03 16:45:34 -0400673 return new BufferVk(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400674}
675
Jamie Madillacccc6c2016-05-03 17:22:10 -0400676VertexArrayImpl *ContextVk::createVertexArray(const gl::VertexArrayState &state)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400677{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400678 return new VertexArrayVk(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400679}
680
Corentin Wallezad3ae902018-03-09 13:40:42 -0500681QueryImpl *ContextVk::createQuery(gl::QueryType type)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400682{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400683 return new QueryVk(type);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400684}
685
686FenceNVImpl *ContextVk::createFenceNV()
687{
Jamie Madillacccc6c2016-05-03 17:22:10 -0400688 return new FenceNVVk();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400689}
690
Jamie Madill70b5bb02017-08-28 13:32:37 -0400691SyncImpl *ContextVk::createSync()
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400692{
Jamie Madill70b5bb02017-08-28 13:32:37 -0400693 return new SyncVk();
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400694}
695
Geoff Lang73bd2182016-07-15 13:01:24 -0400696TransformFeedbackImpl *ContextVk::createTransformFeedback(const gl::TransformFeedbackState &state)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400697{
Geoff Lang73bd2182016-07-15 13:01:24 -0400698 return new TransformFeedbackVk(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400699}
700
Jamie Madill06ef36b2017-09-09 23:32:46 -0400701SamplerImpl *ContextVk::createSampler(const gl::SamplerState &state)
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400702{
Jamie Madill06ef36b2017-09-09 23:32:46 -0400703 return new SamplerVk(state);
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400704}
705
Yunchao Hea336b902017-08-02 16:05:21 +0800706ProgramPipelineImpl *ContextVk::createProgramPipeline(const gl::ProgramPipelineState &state)
707{
708 return new ProgramPipelineVk(state);
709}
710
Sami Väisänene45e53b2016-05-25 10:36:04 +0300711std::vector<PathImpl *> ContextVk::createPaths(GLsizei)
712{
713 return std::vector<PathImpl *>();
714}
715
Jamie Madill72106562017-03-24 14:18:50 -0400716void ContextVk::invalidateCurrentPipeline()
717{
Jamie Madillffa4cbb2018-01-23 13:04:07 -0500718 mCurrentPipeline = nullptr;
Jamie Madill72106562017-03-24 14:18:50 -0400719}
720
Jamie Madillfe548342017-06-19 11:13:24 -0400721gl::Error ContextVk::dispatchCompute(const gl::Context *context,
722 GLuint numGroupsX,
723 GLuint numGroupsY,
724 GLuint numGroupsZ)
Xinghua Cao2b396592017-03-29 15:36:04 +0800725{
726 UNIMPLEMENTED();
Yuly Novikovc4d18aa2017-03-09 18:45:02 -0500727 return gl::InternalError();
Xinghua Cao2b396592017-03-29 15:36:04 +0800728}
729
Qin Jiajia62fcf622017-11-30 16:16:12 +0800730gl::Error ContextVk::dispatchComputeIndirect(const gl::Context *context, GLintptr indirect)
731{
732 UNIMPLEMENTED();
733 return gl::InternalError();
734}
735
Xinghua Cao89c422a2017-11-29 18:24:20 +0800736gl::Error ContextVk::memoryBarrier(const gl::Context *context, GLbitfield barriers)
737{
738 UNIMPLEMENTED();
739 return gl::InternalError();
740}
741
742gl::Error ContextVk::memoryBarrierByRegion(const gl::Context *context, GLbitfield barriers)
743{
744 UNIMPLEMENTED();
745 return gl::InternalError();
746}
747
Jamie Madill6c7ab7f2018-03-31 14:19:15 -0400748vk::DynamicDescriptorPool *ContextVk::getDynamicDescriptorPool()
Jamie Madill76e471e2017-10-21 09:56:01 -0400749{
Luc Ferrondaedf4d2018-03-16 09:28:53 -0400750 return &mDynamicDescriptorPool;
Jamie Madill76e471e2017-10-21 09:56:01 -0400751}
752
Jamie Madillf4d693c2018-02-14 16:38:16 -0500753const VkClearValue &ContextVk::getClearColorValue() const
754{
755 return mClearColorValue;
756}
757
758const VkClearValue &ContextVk::getClearDepthStencilValue() const
759{
760 return mClearDepthStencilValue;
761}
762
Jamie Madill9aef3672018-04-27 11:45:06 -0400763VkColorComponentFlags ContextVk::getClearColorMask() const
764{
765 return mClearColorMask;
766}
Jamie Madill9e54b5a2016-05-25 12:57:39 -0400767} // namespace rx