XII Release 0.1.0
Loading...
Searching...
No Matches
xiiGALBufferVulkan Class Referencefinal
Inheritance diagram for xiiGALBufferVulkan:
[legend]

Public Member Functions

virtual void FlushMappedRange (xiiUInt64 uiStartOffset, xiiUInt64 uiSize) override final
 This flushes the specified range of non-coherent memory from the host cache to make it available to the GPU.
 
virtual void InvalidateMappedRange (xiiUInt64 uiStartOffset, xiiUInt64 uiSize) override final
 This invalidates the specified range of non-coherent memory modified by the GPU to make it visible to the CPU.
 
virtual xiiGALSparseBufferProperties GetSparseProperties () const override final
 This returns the sparse buffer memory properties.
 
XII_ALWAYS_INLINE vk::Buffer GetVulkanBuffer () const
 
XII_ALWAYS_INLINE VmaAllocation GetAllocationDescription () const
 
vk::DeviceAddress GetVulkanBufferDeviceAddress () const
 
void SetAccessFlags (vk::AccessFlags accessFlags)
 
vk::AccessFlags GetAccessFlags () const
 
XII_ALWAYS_INLINE bool CheckAccessFlags (vk::AccessFlags accessFlags) const
 
- Public Member Functions inherited from xiiGALBuffer
XII_ALWAYS_INLINE const xiiGALBufferCreationDescriptionGetDescription () const
 This returns the creation description for this object.
 
XII_ALWAYS_INLINE xiiUInt64 GetSize () const
 This returns the buffer size.
 
virtual XII_ALWAYS_INLINE xiiUInt64 GetMemoryConsumption () const
 Returns the calculated memory consumption for buffer.
 
xiiSharedPtr< xiiGALBufferViewGetDefaultView (xiiEnum< xiiGALBufferViewType > viewType)
 This returns the handle of the default view.
 
XII_ALWAYS_INLINE xiiBitflags< xiiGALMemoryPropertyFlagsGetMemoryProperties () const
 This returns the buffer memory properties.
 
xiiSharedPtr< xiiGALBufferViewCreateView (xiiGALBufferViewCreationDescription &description)
 This creates a new buffer view.
 
- Public Member Functions inherited from xiiGALResource
virtual void SetResourceState (xiiBitflags< xiiGALResourceStateFlags > stateFlags)
 This sets the buffer usage state.
 
virtual XII_ALWAYS_INLINE xiiBitflags< xiiGALResourceStateFlagsGetResourceState () const
 This returns the buffer state.
 
XII_ALWAYS_INLINE bool IsInKnownState () const
 This returns true if the resource is in known state by the engine.
 
XII_ALWAYS_INLINE bool CheckState (xiiBitflags< xiiGALResourceStateFlags > resourceState) const
 This returns true if the given resource state is set.
 
XII_ALWAYS_INLINE bool CheckAnyState (xiiBitflags< xiiGALResourceStateFlags > resourceState) const
 This returns true if any of the given resource state are set.
 
- Public Member Functions inherited from xiiGALDeviceObject
XII_ALWAYS_INLINE xiiSharedPtr< xiiGALDeviceGetDevice () const
 Returns the xiiGALDevice that created this resource.
 
- Public Member Functions inherited from xiiGALObject
XII_ALWAYS_INLINE xiiStringView GetDebugName () const
 Returns the debug name of this resource.
 
void SetDebugName (xiiStringView sDebugName) const
 Sets the debug name for this resource.
 
- Public Member Functions inherited from xiiReflectedClass
virtual const xiiRTTIGetDynamicRTTI () const
 
bool IsInstanceOf (const xiiRTTI *pType) const
 Returns whether the type of this instance is of the given type or derived from it.
 
template<typename T>
XII_ALWAYS_INLINE bool IsInstanceOf () const
 Returns whether the type of this instance is of the given type or derived from it.
 
- Public Member Functions inherited from xiiRefCounted
virtual ~xiiRefCounted ()=default
 Adds a virtual destructor.
 
- Public Member Functions inherited from xiiRefCountingImpl
 xiiRefCountingImpl ()=default
 Constructor.
 
 xiiRefCountingImpl (const xiiRefCountingImpl &rhs)
 
void operator= (const xiiRefCountingImpl &rhs)
 
xiiUInt32 AddRef () const
 Increments the reference counter. Returns the new reference count.
 
xiiUInt32 ReleaseRef () const
 Decrements the reference counter. Returns the new reference count.
 
bool IsReferenced () const
 Returns true if the reference count is greater than 0, false otherwise.
 
xiiUInt32 GetRefCount () const
 Returns the current reference count.
 

Protected Member Functions

 xiiGALBufferVulkan (xiiSharedPtr< xiiGALDeviceVulkan > pDeviceVulkan, const xiiGALBufferCreationDescription &creationDescription)
 
virtual xiiResult InitPlatform (const xiiGALBufferData *pInitialData) override final
 
virtual xiiInternal::NewInstance< xiiGALBufferViewCreateViewPlatform (const xiiGALBufferViewCreationDescription &description) override
 
virtual void SetDebugNamePlatform (xiiStringView sName) const override final
 
- Protected Member Functions inherited from xiiGALBuffer
 xiiGALBuffer (xiiSharedPtr< xiiGALDevice > pDevice, const xiiGALBufferCreationDescription &creationDescription)
 
void VerifyFlushMappedRangeArguments (xiiUInt64 uiStartOffset, xiiUInt64 uiSize) const
 
void VerifyInvalidateMappedRangeArguments (xiiUInt64 uiStartOffset, xiiUInt64 uiSize) const
 
- Protected Member Functions inherited from xiiGALResource
 xiiGALResource (xiiSharedPtr< xiiGALDevice > pDevice)
 
- Protected Member Functions inherited from xiiGALDeviceObject
 xiiGALDeviceObject (xiiSharedPtr< xiiGALDevice > pDevice)
 

Friends

class xiiGALDeviceVulkan
 
class xiiMemoryUtils
 

Additional Inherited Members

- Static Public Member Functions inherited from xiiNoBase
static const xiiRTTIGetStaticRTTI ()
 
- Protected Attributes inherited from xiiGALBuffer
xiiGALBufferCreationDescription m_Description
 
xiiBitflags< xiiGALMemoryPropertyFlagsm_MemoryPropertyFlags
 
xiiSharedPtr< xiiGALBufferViewm_DefaultBufferViews [xiiGALBufferViewType::ENUM_COUNT]
 
- Protected Attributes inherited from xiiGALResource
xiiBitflags< xiiGALResourceStateFlagsm_ResourceState
 
- Protected Attributes inherited from xiiGALDeviceObject
xiiSharedPtr< xiiGALDevicem_pDevice
 

Member Function Documentation

◆ CreateViewPlatform()

xiiInternal::NewInstance< xiiGALBufferView > xiiGALBufferVulkan::CreateViewPlatform ( const xiiGALBufferViewCreationDescription & description)
overrideprotectedvirtual

Implements xiiGALBuffer.

◆ FlushMappedRange()

void xiiGALBufferVulkan::FlushMappedRange ( xiiUInt64 uiStartOffset,
xiiUInt64 uiSize )
finaloverridevirtual

This flushes the specified range of non-coherent memory from the host cache to make it available to the GPU.

Parameters
uiStartOffset- The offset in bytes from the beginning of the buffer to the start of the memory range to flush.
uiSize- The size in bytes of the memory range to flush.

This method should only be used for persistently-mapped buffers that do not report the xiiGALMemoryProperties::HostCoherent property. After an application modifies a mapped memory range on the CPU, it must flush the range to make it available to the GPU.

Note
This method must not be called for Dynamic buffers. When a mapped buffer is unmapped, it is automatically flushed by the engine if necessary.

Implements xiiGALBuffer.

◆ GetSparseProperties()

xiiGALSparseBufferProperties xiiGALBufferVulkan::GetSparseProperties ( ) const
finaloverridevirtual

This returns the sparse buffer memory properties.

Implements xiiGALBuffer.

◆ InitPlatform()

xiiResult xiiGALBufferVulkan::InitPlatform ( const xiiGALBufferData * pInitialData)
finaloverrideprotectedvirtual
Todo
GraphicsVulkan: Selectively utilize vk::SharingMode::eConcurrent for multiple queue family's ownership of the Vulkan buffer.

Implements xiiGALBuffer.

◆ InvalidateMappedRange()

void xiiGALBufferVulkan::InvalidateMappedRange ( xiiUInt64 uiStartOffset,
xiiUInt64 uiSize )
finaloverridevirtual

This invalidates the specified range of non-coherent memory modified by the GPU to make it visible to the CPU.

Parameters
uiStartOffset- The offset in bytes from the beginning of the buffer to the start of the memory to invalidate.
uiSize- The size in bytes of the memory range to invalidate.

This method should only be used for persistently-mapped buffers that do not report the xiiGALMemoryProperties::HostCoherent property. After an application modifies a mapped memory range on the CPU, it must invalidate the range to make it visible to the CPU.

Note
This method must not be called for Dynamic buffers. When a mapped buffer is unmapped, it is automatically flushed by the engine if necessary.

Implements xiiGALBuffer.

◆ SetDebugNamePlatform()

void xiiGALBufferVulkan::SetDebugNamePlatform ( xiiStringView sName) const
finaloverrideprotectedvirtual

Reimplemented from xiiGALObject.


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