X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbackends%2Fvulkan%2Ftransferqueue.h;h=536edbd8782830f1352444e2c5f38419653523f4;hb=1b4d387b74b2108f3926796d8115bee134fbf7f1;hp=b8719d627513bd8962dec3df4c1b52ddd2a8dbc5;hpb=682d3ceda19df700ce6590028717e4f0042783ec;p=libs%2Fgl.git diff --git a/source/backends/vulkan/transferqueue.h b/source/backends/vulkan/transferqueue.h index b8719d62..536edbd8 100644 --- a/source/backends/vulkan/transferqueue.h +++ b/source/backends/vulkan/transferqueue.h @@ -10,6 +10,7 @@ namespace GL { class Buffer; class Device; +class VulkanCommandRecorder; class TransferQueue { @@ -22,6 +23,8 @@ private: std::size_t size = 0; std::size_t used = 0; void *mapped_address = 0; + unsigned async_count = 0; + unsigned last_frame = 0; StagingBuffer(Device &, std::size_t); StagingBuffer(StagingBuffer &&); @@ -30,40 +33,52 @@ private: struct PendingTransfer { + const void *object = 0; unsigned order = 0; - unsigned buffer_index = 0; + int buffer_index = -1; std::size_t offset = 0; std::size_t size = 0; + void *staging_address = 0; std::function synchronize; - std::function transfer; + std::function transfer; }; Device &device; std::size_t default_buffer_size = 16*1048576; std::vector buffers; std::vector transfers; - std::map next_orders; + std::vector async_transfers; + std::map next_orders; + unsigned current_frame = 0; public: TransferQueue(Device &); template - void *prepare_transfer(void *, bool, std::size_t, S &&, T &&); + void *prepare_transfer(const void *, bool, std::size_t, S &&, T &&); + + template + void prepare_transfer(const void *o, bool r, S &&s, T &&t) + { prepare_transfer(o, r, 0, std::forward(s), std::forward(t)); } + + void finalize_transfer(void *); private: - PendingTransfer &prepare_transfer(void *, bool, std::size_t); + void allocate_staging(PendingTransfer &, std::size_t); + PendingTransfer &prepare_transfer(const void *, bool, std::size_t); + PendingTransfer &insert_transfer(PendingTransfer &&); public: - void dispatch_transfers(VkCommandBuffer); + void dispatch_transfers(const VulkanCommandRecorder &); }; template -void *TransferQueue::prepare_transfer(void *object, bool ordered, std::size_t size, S &&synchronize, T &&transfer) +void *TransferQueue::prepare_transfer(const void *object, bool ordered, std::size_t size, S &&synchronize, T &&transfer) { PendingTransfer &pt = prepare_transfer(object, ordered, size); pt.synchronize = std::forward(synchronize); pt.transfer = std::forward(transfer); - return static_cast(buffers[pt.buffer_index].mapped_address)+pt.offset; + return pt.staging_address; } } // namespace GL