]> git.tdb.fi Git - libs/gl.git/blobdiff - source/backends/vulkan/buffer_backend.cpp
Multiplex streaming buffer contents on Vulkan
[libs/gl.git] / source / backends / vulkan / buffer_backend.cpp
index 14164daf208a8b67f4fdba00284b10df2d2aedc3..5439548f886fd1d81ba0ac16181f12c4a213f28f 100644 (file)
@@ -37,7 +37,7 @@ void VulkanBuffer::allocate()
 
        VkBufferCreateInfo buffer_info = { };
        buffer_info.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
-       buffer_info.size = self.size;
+       buffer_info.size = self.get_total_size();
        buffer_info.usage = VK_BUFFER_USAGE_TRANSFER_SRC_BIT|VK_BUFFER_USAGE_TRANSFER_DST_BIT|VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT|
                VK_BUFFER_USAGE_INDEX_BUFFER_BIT|VK_BUFFER_USAGE_VERTEX_BUFFER_BIT;
        buffer_info.sharingMode = VK_SHARING_MODE_EXCLUSIVE;
@@ -52,7 +52,8 @@ void VulkanBuffer::allocate()
 
 void VulkanBuffer::sub_data(size_t off, size_t sz, const void *d)
 {
-       void *staging = device.get_transfer_queue().prepare_transfer(sz,
+       TransferQueue &tq = device.get_transfer_queue();
+       void *staging = tq.prepare_transfer(this, false, sz,
                [this, off, sz](){
                        device.get_synchronizer().write_buffer(handle, off, sz);
                },
@@ -68,6 +69,13 @@ void VulkanBuffer::sub_data(size_t off, size_t sz, const void *d)
 
        const char *src = static_cast<const char *>(d);
        copy(src, src+sz, static_cast<char *>(staging));
+       tq.finalize_transfer(staging);
+}
+
+unsigned VulkanBuffer::get_multiplicity() const
+{
+       BufferUsage usage = static_cast<const Buffer *>(this)->usage;
+       return (usage==STREAMING ? device.get_n_frames_in_flight() : 1);
 }
 
 bool VulkanBuffer::can_map() const