Files
UnrealEngineUWP/Engine/Source/Runtime/SlateRHIRenderer/Private/SlateElementIndexBuffer.cpp
zach bethel aa1b0c680f Deprecated non-command list RHI methods.
- RHICreate{Vertex, Index, Structured}Buffer
 - RHICreate{ShaderResource, UnorderedAccess}View
 - RHIUpdateUniformBuffer
 - Various initialization / locking methods for helper buffer types in RHIUtilities.h

The goal is to continue to force resource creation through command lists to avoid surprises with moving things off the render thread.

#rb christopher.waters

[CL 26183242 by zach bethel in ue5-main branch]
2023-06-22 11:08:27 -04:00

114 lines
2.8 KiB
C++

// Copyright Epic Games, Inc. All Rights Reserved.
#include "SlateElementIndexBuffer.h"
#include "SlateGlobals.h"
#include "Rendering/RenderingCommon.h"
#include "RHI.h"
#include "RHICommandList.h"
DECLARE_MEMORY_STAT(TEXT("Index Buffer Memory (GPU)"), STAT_SlateIndexBufferMemory, STATGROUP_SlateMemory);
FSlateElementIndexBuffer::FSlateElementIndexBuffer()
: BufferSize(0)
, MinBufferSize(0)
, BufferUsageSize(0)
{
}
FSlateElementIndexBuffer::~FSlateElementIndexBuffer()
{
}
void FSlateElementIndexBuffer::Init( int32 MinNumIndices )
{
MinBufferSize = sizeof(SlateIndex) * FMath::Max( MinNumIndices, 100 );
if ( IsInRenderingThread() )
{
InitResource(FRHICommandListImmediate::Get());
}
else
{
BeginInitResource(this);
}
}
void FSlateElementIndexBuffer::Destroy()
{
if ( IsInRenderingThread() )
{
ReleaseResource();
}
else
{
BeginReleaseResource(this);
}
}
/** Initializes the index buffers RHI resource. */
void FSlateElementIndexBuffer::InitRHI(FRHICommandListBase& RHICmdList)
{
checkSlow( IsInRenderingThread() );
check( MinBufferSize > 0 );
SetBufferSize(MinBufferSize);
FRHIResourceCreateInfo CreateInfo(TEXT("FSlateElementIndexBuffer"));
IndexBufferRHI = RHICmdList.CreateIndexBuffer( sizeof(SlateIndex), MinBufferSize, BUF_Dynamic, CreateInfo );
check( IsValidRef(IndexBufferRHI) );
}
/** Resizes the buffer to the passed in size. Preserves internal data */
void FSlateElementIndexBuffer::ResizeBuffer( int32 NewSizeBytes )
{
checkSlow( IsInRenderingThread() );
int32 FinalSize = FMath::Max( NewSizeBytes, MinBufferSize );
if( FinalSize != 0 && FinalSize != BufferSize )
{
IndexBufferRHI.SafeRelease();
FRHIResourceCreateInfo CreateInfo(TEXT("FSlateElementIndexBuffer"));
IndexBufferRHI = FRHICommandListImmediate::Get().CreateIndexBuffer( sizeof(SlateIndex), FinalSize, BUF_Dynamic, CreateInfo );
check(IsValidRef(IndexBufferRHI));
SetBufferSize(FinalSize);
}
}
void FSlateElementIndexBuffer::PreFillBuffer(int32 RequiredIndexCount, bool bShrinkToMinSize)
{
SCOPE_CYCLE_COUNTER( STAT_SlatePreFullBufferRTTime );
checkSlow(IsInRenderingThread());
if (RequiredIndexCount > 0)
{
int32 RequiredBufferSize = RequiredIndexCount*sizeof(SlateIndex);
// resize if needed
if (RequiredBufferSize > GetBufferSize() || bShrinkToMinSize)
{
// Use array resize techniques for the vertex buffer
ResizeBuffer(RequiredBufferSize);
}
BufferUsageSize = RequiredBufferSize;
}
}
/** Releases the index buffers RHI resource. */
void FSlateElementIndexBuffer::ReleaseRHI()
{
IndexBufferRHI.SafeRelease();
SetBufferSize(0);
}
void FSlateElementIndexBuffer::SetBufferSize(int32 NewBufferSize)
{
DEC_MEMORY_STAT_BY(STAT_SlateIndexBufferMemory, BufferSize);
BufferSize = NewBufferSize;
INC_MEMORY_STAT_BY(STAT_SlateIndexBufferMemory, BufferSize);
}