]> git.tdb.fi Git - libs/gl.git/blobdiff - source/backends/vulkan/transferqueue.h
Track the order of transfers involving the same objects
[libs/gl.git] / source / backends / vulkan / transferqueue.h
index a25519c8a121b417b0fe1dc1a60692bc7f7f90ff..b8719d627513bd8962dec3df4c1b52ddd2a8dbc5 100644 (file)
@@ -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<StagingBuffer> buffers;
        std::vector<PendingTransfer> transfers;
+       std::map<void *, unsigned> next_orders;
 
 public:
        TransferQueue(Device &);
 
        template<typename S, typename T>
-       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<typename S, typename T>
-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<S>(synchronize);
        pt.transfer = std::forward<T>(transfer);
        return static_cast<char *>(buffers[pt.buffer_index].mapped_address)+pt.offset;