X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbackends%2Fvulkan%2Ftransferqueue.h;h=58b1bc2d6fa5f4743964c72d1e15e01305a97af0;hb=c633fcc87e295ebc88b5847c44ca0da121652819;hp=419760bdf4d6b709bd4b28a393428f8da45f9383;hpb=99ca354f18119f82f1adeca100cd665a8f640317;p=libs%2Fgl.git diff --git a/source/backends/vulkan/transferqueue.h b/source/backends/vulkan/transferqueue.h index 419760bd..58b1bc2d 100644 --- a/source/backends/vulkan/transferqueue.h +++ b/source/backends/vulkan/transferqueue.h @@ -28,40 +28,42 @@ private: ~StagingBuffer(); }; - using TransferCallback = void(VkCommandBuffer, VkBuffer, std::size_t); - struct PendingTransfer { - unsigned buffer_index = 0; + unsigned order = 0; + int buffer_index = -1; std::size_t offset = 0; std::size_t size = 0; - std::function callback; + std::function synchronize; + std::function transfer; }; Device &device; 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, T &&); + template + void *prepare_transfer(const void *, bool, std::size_t, S &&, T &&); private: - PendingTransfer &prepare_transfer(std::size_t); + PendingTransfer &prepare_transfer(const void *, bool, std::size_t); public: void dispatch_transfers(VkCommandBuffer); }; -template -void *TransferQueue::prepare_transfer(std::size_t size, T &&callback) +template +void *TransferQueue::prepare_transfer(const void *object, bool ordered, std::size_t size, S &&synchronize, T &&transfer) { - PendingTransfer &pt = prepare_transfer(size); - pt.callback = std::forward(callback); - return static_cast(buffers[pt.buffer_index].mapped_address)+pt.offset; + PendingTransfer &pt = prepare_transfer(object, ordered, size); + pt.synchronize = std::forward(synchronize); + pt.transfer = std::forward(transfer); + return (pt.buffer_index<0 ? 0 : static_cast(buffers[pt.buffer_index].mapped_address)+pt.offset); } } // namespace GL