MayaFlux 0.4.0
Digital-First Multimedia Processing Framework
Loading...
Searching...
No Matches
MayaFlux::Buffers::VKBuffer Class Reference

Vulkan-backed buffer wrapper used in processing chains. More...

#include <VKBuffer.hpp>

+ Inheritance diagram for MayaFlux::Buffers::VKBuffer:
+ Collaboration diagram for MayaFlux::Buffers::VKBuffer:

Classes

struct  EngineContext
 Engine-internal per-frame binding state. More...
 
struct  PipelineContext
 Context shared with BufferProcessors during pipeline execution. More...
 

Public Types

using RenderConfig = Portal::Graphics::RenderConfig
 
enum class  Usage : uint8_t {
  STAGING , DEVICE , COMPUTE , VERTEX ,
  INDEX , UNIFORM , UNIFORM_BDA , STORAGE_BDA
}
 

Public Member Functions

void clear () override
 Clear buffer contents.
 
void clear_pipeline_commands ()
 Clear all recorded commands (called after presentation)
 
void clear_vertex_layout ()
 Clear vertex layout.
 
std::shared_ptr< Bufferclone_to (uint8_t dest_desc) override
 Creates a clone of this buffer for a specific channel or usage enum.
 
std::shared_ptr< VKBufferclone_to (Usage usage)
 Create a clone of this buffer with the same data and properties.
 
void enforce_default_processing (bool should_process) override
 Controls whether the buffer should use default processing.
 
void force_internal_usage (bool internal) override
 Set whether this buffer is for internal engine usage.
 
std::vector< std::pair< size_t, size_t > > get_and_clear_dirty_ranges ()
 Retrieve and clear all dirty ranges.
 
std::vector< std::pair< size_t, size_t > > get_and_clear_invalid_ranges ()
 Retrieve and clear all invalid ranges.
 
vk::Buffer & get_buffer ()
 Get VkBuffer handle (VK_NULL_HANDLE if not registered)
 
const VKBufferResourcesget_buffer_resources ()
 Get all buffer resources at once.
 
std::vector< Kakshya::DataVariantget_data ()
 Read buffer contents as Kakshya DataVariant.
 
std::shared_ptr< Buffers::BufferProcessorget_default_processor () const override
 Get the currently attached default processor.
 
uint64_t get_device_address () const
 Get the Vulkan device address for this buffer (if applicable)
 
const std::vector< Kakshya::DataDimension > & get_dimensions () const
 Get the inferred data dimensions for the buffer contents.
 
EngineContextget_engine_context ()
 
const EngineContextget_engine_context () const
 
vk::Format get_format () const
 Convert modality to a recommended VkFormat.
 
vk::Buffer get_index_buffer () const
 Return the raw index buffer handle.
 
size_t get_index_buffer_size () const
 Number of bytes in the index buffer.
 
void * get_mapped_ptr () const
 Get mapped host pointer (nullptr if not host-visible or unmapped)
 
vk::MemoryPropertyFlags get_memory_properties () const
 Get appropriate VkMemoryPropertyFlags for allocation based on Usage.
 
Kakshya::DataModality get_modality () const
 Get the buffer's semantic modality.
 
CommandBufferID get_pipeline_command (RenderPipelineID pipeline_id) const
 Get recorded command buffer for a pipeline.
 
PipelineContextget_pipeline_context ()
 Access the pipeline context for custom metadata (non-const)
 
const PipelineContextget_pipeline_context () const
 Access the pipeline context for custom metadata (const)
 
std::shared_ptr< Core::Windowget_pipeline_window (RenderPipelineID id) const
 Get the window associated with this buffer.
 
std::shared_ptr< Buffers::BufferProcessingChainget_processing_chain () override
 Access the buffer's processing chain.
 
RenderConfig get_render_config () const
 Get the current render configuration.
 
std::unordered_map< RenderPipelineID, std::shared_ptr< Core::Window > > get_render_pipelines () const
 Get all render pipelines associated with this buffer.
 
virtual std::shared_ptr< RenderProcessorget_render_processor () const
 Get a RenderProcessor suitable for rendering this buffer.
 
size_t get_size () const
 Get current logical size in bytes.
 
vk::DeviceSize get_size_bytes () const
 
Usage get_usage () const
 Retrieve the declared usage intent.
 
vk::BufferUsageFlags get_usage_flags () const
 Get appropriate VkBufferUsageFlags for creation based on Usage.
 
std::optional< Kakshya::VertexLayoutget_vertex_layout () const
 Get vertex layout if set.
 
bool has_data_for_cycle () const override
 Checks if the buffer has data for the current processing cycle.
 
bool has_index_buffer () const
 True when an index buffer has been associated with this buffer.
 
bool has_render_pipeline () const
 Check if this buffer has a rendering pipeline configured.
 
bool has_vertex_layout () const
 Check if this buffer has vertex layout configured.
 
bool is_host_visible () const
 Whether this VKBuffer should be host-visible.
 
bool is_initialized () const
 Check whether Vulkan handles are present (buffer registered)
 
bool is_internal_only () const override
 Check whether this buffer is for internal engine usage.
 
bool is_processing () const override
 Query whether the buffer is currently being processed.
 
bool is_render_config_dirty () const
 Check if config has changed since last frame.
 
void mark_dirty_range (size_t offset, size_t size)
 Get device memory handle.
 
void mark_for_processing (bool has_data) override
 Marks the buffer's data availability for the current processing cycle.
 
void mark_for_removal () override
 Marks the buffer for removal from processing chains.
 
void mark_invalid_range (size_t offset, size_t size)
 Mark a range as invalid (needs download)
 
virtual void mark_render_config_dirty (bool is_dirty=true)
 Mark config as changed (processors will detect and react)
 
bool needs_default_processing () override
 Checks if the buffer should undergo default processing.
 
bool needs_depth_attachment () const
 Check if this buffer requires depth attachment for rendering.
 
bool needs_removal () const override
 Checks if the buffer should be removed from processing chains.
 
void process_default () override
 Run the buffer's default processor (if set and enabled)
 
void release_processing () override
 Release previously acquired processing lock.
 
void resize (size_t new_size, bool preserve_data=false)
 Resize buffer and recreate GPU resources if needed.
 
void set_buffer (vk::Buffer buffer)
 Set VkBuffer handle after backend allocation.
 
void set_buffer_resources (const VKBufferResources &resources)
 Set all buffer resources at once.
 
void set_data (const std::vector< Kakshya::DataVariant > &data)
 Write data into the buffer.
 
void set_default_processor (const std::shared_ptr< BufferProcessor > &processor) override
 Set the buffer's default processor.
 
void set_index_resources (vk::Buffer buf, vk::DeviceMemory mem, size_t size)
 Store raw index buffer handles produced by the geometry upload path.
 
void set_mapped_ptr (void *ptr)
 Set mapped host pointer (for host-visible allocations)
 
void set_memory (vk::DeviceMemory memory)
 Set device memory handle after backend allocation.
 
void set_modality (Kakshya::DataModality modality)
 Update the semantic modality and re-infer dimensions.
 
void set_needs_depth_attachment (bool needs)
 Mark this buffer as requiring depth testing when rendered.
 
void set_pipeline_command (RenderPipelineID pipeline_id, CommandBufferID cmd_id)
 Store recorded command buffer for a pipeline.
 
void set_pipeline_window (RenderPipelineID id, const std::shared_ptr< Core::Window > &window)
 Associate this buffer with a window for rendering.
 
void set_processing_chain (const std::shared_ptr< BufferProcessingChain > &chain, bool force=false) override
 Replace the buffer's processing chain.
 
virtual void set_render_config (const RenderConfig &config)
 Update the render configuration and mark as dirty.
 
void set_vertex_layout (const Kakshya::VertexLayout &layout)
 Set vertex layout for this buffer.
 
virtual void setup_processors (ProcessingToken token)
 Setup processors with a processing token.
 
bool try_acquire_processing () override
 Try to acquire processing lock for this buffer.
 
 VKBuffer ()=default
 
 VKBuffer (size_t size_bytes, Usage usage, Kakshya::DataModality modality)
 Construct an unregistered VKBuffer.
 
 ~VKBuffer () override
 Virtual destructor.
 
- Public Member Functions inherited from MayaFlux::Buffers::Buffer
virtual ~Buffer ()=default
 Virtual destructor for proper resource management.
 

Protected Member Functions

void set_default_render_config (const RenderConfig &config)
 Called by derived classes to set their context-specific defaults.
 

Protected Attributes

RenderConfig m_render_config
 
bool m_render_config_dirty {}
 

Private Member Functions

void infer_dimensions_from_data (size_t byte_count)
 Infer Kakshya::DataDimension entries from a given byte count.
 

Private Attributes

std::shared_ptr< Buffers::BufferProcessorm_default_processor
 
std::vector< Kakshya::DataDimensionm_dimensions
 
std::vector< std::pair< size_t, size_t > > m_dirty_ranges
 
EngineContext m_engine_context
 
bool m_has_data { true }
 
bool m_internal_usage {}
 
std::vector< std::pair< size_t, size_t > > m_invalid_ranges
 
std::atomic< bool > m_is_processing
 
Kakshya::DataModality m_modality
 
bool m_needs_depth {}
 
bool m_needs_removal {}
 
std::unordered_map< RenderPipelineID, CommandBufferIDm_pipeline_commands
 
PipelineContext m_pipeline_context
 
bool m_process_default { true }
 
std::shared_ptr< Buffers::BufferProcessingChainm_processing_chain
 
ProcessingToken m_processing_token
 
VKBufferResources m_resources
 
size_t m_size_bytes {}
 
Usage m_usage {}
 
std::optional< Kakshya::VertexLayoutm_vertex_layout
 
std::unordered_map< RenderPipelineID, std::shared_ptr< Core::Window > > m_window_pipelines
 

Detailed Description

Vulkan-backed buffer wrapper used in processing chains.

VKBuffer is a lightweight, high-level representation of a GPU buffer used by the MayaFlux processing pipeline. It carries semantic metadata (Kakshya modalities and dimensions), integrates with the Buffer processing chain and BufferManager, and exposes Vulkan handles once the backend registers the buffer. Prior to registration the object contains no GPU resources and can be manipulated cheaply (like AudioBuffer).

Responsibilities:

  • Store buffer size, usage intent and semantic modality
  • Provide inferred data dimensions for processors and pipeline inspection
  • Hold Vulkan handles (VkBuffer, VkDeviceMemory) assigned by graphics backend
  • Provide convenience helpers for common Vulkan creation flags and memory props
  • Integrate with BufferProcessor / BufferProcessingChain for default processing

Note: Actual allocation, mapping and command-based transfers are performed by the graphics backend / BufferManager. VKBuffer only stores handles and metadata and provides helpers for processors to operate on it.

Definition at line 67 of file VKBuffer.hpp.


The documentation for this class was generated from the following files: