MayaFlux 0.4.0
Digital-First Multimedia Processing Framework
Loading...
Searching...
No Matches

◆ clone_to() [2/2]

std::shared_ptr< Buffers::VKBuffer > MayaFlux::Buffers::VKBuffer::clone_to ( Usage  usage)

Create a clone of this buffer with the same data and properties.

Parameters
usageUsage enum for the cloned buffer
Returns
Shared pointer to the cloned VKBuffer

The cloned buffer will have the same size, modality, dimensions, processing chain and default processor as the original. Changes to one buffer after cloning do not affect the other.

Definition at line 417 of file VKBuffer.cpp.

418{
419 auto buffer = std::make_shared<VKBuffer>(m_size_bytes, usage, m_modality);
420
421 if (auto layout = get_vertex_layout(); layout.has_value()) {
422 buffer->set_vertex_layout(layout.value());
423 }
424
425 buffer->set_processing_chain(get_processing_chain());
426 buffer->set_default_processor(get_default_processor());
427
428 if (is_host_visible()) {
429 if (buffer->is_host_visible()) {
430 auto src_ptr = static_cast<uint8_t*>(m_resources.mapped_ptr);
431 buffer->set_data({ std::vector<uint8_t>(src_ptr, src_ptr + m_size_bytes) });
432 } else {
434 std::dynamic_pointer_cast<VKBuffer>(shared_from_this()),
435 buffer,
436 nullptr);
437 }
438 } else {
439 if (buffer->is_host_visible()) {
441 buffer,
442 std::dynamic_pointer_cast<VKBuffer>(shared_from_this()),
443 get_data()[0]);
444 } else {
446 "Cloning device-local VKBuffer to another device-local VKBuffer requires external data transfer");
447 }
448 }
449
450 return buffer;
451}
#define MF_WARN(comp, ctx,...)
std::vector< Kakshya::DataVariant > get_data()
Read buffer contents as Kakshya DataVariant.
Definition VKBuffer.cpp:125
std::shared_ptr< Buffers::BufferProcessor > get_default_processor() const override
Get the currently attached default processor.
Definition VKBuffer.cpp:281
std::shared_ptr< Buffers::BufferProcessingChain > get_processing_chain() override
Access the buffer's processing chain.
Definition VKBuffer.cpp:286
std::optional< Kakshya::VertexLayout > get_vertex_layout() const
Get vertex layout if set.
Definition VKBuffer.hpp:487
VKBufferResources m_resources
Definition VKBuffer.hpp:621
Kakshya::DataModality m_modality
Definition VKBuffer.hpp:629
bool is_host_visible() const
Whether this VKBuffer should be host-visible.
Definition VKBuffer.hpp:369
void upload_device_local(const std::shared_ptr< VKBuffer > &target, const std::shared_ptr< VKBuffer > &staging_buffer, const Kakshya::DataVariant &data)
Upload data to a device-local buffer using a staging buffer.
void download_device_local(const std::shared_ptr< VKBuffer > &source, const std::shared_ptr< VKBuffer > &target, const std::shared_ptr< VKBuffer > &staging_buffer)
Download data from a device-local buffer using a staging buffer.
@ BufferManagement
Buffer Management (Buffers::BufferManager, creating buffers)
@ Buffers
Buffers, Managers, processors and processing chains.

References MayaFlux::Journal::BufferManagement, MayaFlux::Journal::Buffers, MayaFlux::Buffers::download_device_local(), get_data(), get_default_processor(), get_processing_chain(), get_vertex_layout(), is_host_visible(), m_modality, m_resources, m_size_bytes, MayaFlux::Buffers::VKBufferResources::mapped_ptr, MF_WARN, and MayaFlux::Buffers::upload_device_local().

+ Here is the call graph for this function: