X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbackends%2Fvulkan%2Fvertexsetup_backend.cpp;fp=source%2Fbackends%2Fvulkan%2Fvertexsetup_backend.cpp;h=9579fd402af5eca57e21a279072822082253cdc0;hb=bb82b949ff134b07618c02bcd6d40e97fdecbf1a;hp=0d25181448caebe7ceb9ff14e4855f8daa4536a9;hpb=0d94309bc07629feea62bd03837b6e21ccc15b6f;p=libs%2Fgl.git diff --git a/source/backends/vulkan/vertexsetup_backend.cpp b/source/backends/vulkan/vertexsetup_backend.cpp index 0d251814..9579fd40 100644 --- a/source/backends/vulkan/vertexsetup_backend.cpp +++ b/source/backends/vulkan/vertexsetup_backend.cpp @@ -35,14 +35,14 @@ void VulkanVertexSetup::update(unsigned) const bindings[0].binding = 0; bindings[0].stride = self.vertex_format.stride(); bindings[0].inputRate = VK_VERTEX_INPUT_RATE_VERTEX; - update_attributes(self.vertex_format, 0, attribs); + void *attrib_ptr = update_attributes(self.vertex_format, 0, attribs); if(!self.inst_format.empty()) { bindings[1].binding = 1; bindings[1].stride = self.inst_format.stride(); bindings[1].inputRate = VK_VERTEX_INPUT_RATE_INSTANCE; - update_attributes(self.inst_format, 1, attribs+self.vertex_format.size()); + update_attributes(self.inst_format, 1, attrib_ptr); } input_state->sType = VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO; @@ -61,7 +61,7 @@ void VulkanVertexSetup::update(unsigned) const } } -void VulkanVertexSetup::update_attributes(const VertexFormat &fmt, unsigned binding, void *buffer) const +void *VulkanVertexSetup::update_attributes(const VertexFormat &fmt, unsigned binding, void *buffer) const { VkVertexInputAttributeDescription *attrib = reinterpret_cast(buffer); unsigned offset = 0; @@ -77,6 +77,8 @@ void VulkanVertexSetup::update_attributes(const VertexFormat &fmt, unsigned bind } offset += get_attribute_size(a); } + + return attrib; } uint64_t VulkanVertexSetup::compute_hash() const