X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fbackends%2Fvulkan%2Ftransferqueue.h;h=b8719d627513bd8962dec3df4c1b52ddd2a8dbc5;hb=682d3ceda19df700ce6590028717e4f0042783ec;hp=a25519c8a121b417b0fe1dc1a60692bc7f7f90ff;hpb=d9c769b5847beefa378d2c5555f5b5d8e5d26c0e;p=libs%2Fgl.git diff --git a/source/backends/vulkan/transferqueue.h b/source/backends/vulkan/transferqueue.h index a25519c8..b8719d62 100644 --- a/source/backends/vulkan/transferqueue.h +++ b/source/backends/vulkan/transferqueue.h @@ -30,6 +30,7 @@ private: struct PendingTransfer { + unsigned order = 0; unsigned buffer_index = 0; std::size_t offset = 0; std::size_t size = 0; @@ -41,24 +42,25 @@ private: std::size_t default_buffer_size = 16*1048576; std::vector buffers; std::vector transfers; + std::map next_orders; public: TransferQueue(Device &); template - void *prepare_transfer(std::size_t, S &&, T &&); + void *prepare_transfer(void *, bool, std::size_t, S &&, T &&); private: - PendingTransfer &prepare_transfer(std::size_t); + PendingTransfer &prepare_transfer(void *, bool, std::size_t); public: void dispatch_transfers(VkCommandBuffer); }; template -void *TransferQueue::prepare_transfer(std::size_t size, S &&synchronize, T &&transfer) +void *TransferQueue::prepare_transfer(void *object, bool ordered, std::size_t size, S &&synchronize, T &&transfer) { - PendingTransfer &pt = prepare_transfer(size); + 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;