Represents main object of this library initialized for particular ID3D12Device
.
More...
#include <D3D12MemAlloc.h>
Inherits IUnknownImpl.
Public Member Functions | |
const D3D12_FEATURE_DATA_D3D12_OPTIONS & | GetD3D12Options () const |
Returns cached options retrieved from D3D12 device. | |
BOOL | IsUMA () const |
Returns true if D3D12_FEATURE_DATA_ARCHITECTURE1::UMA was found to be true. | |
BOOL | IsCacheCoherentUMA () const |
Returns true if D3D12_FEATURE_DATA_ARCHITECTURE1::CacheCoherentUMA was found to be true. | |
UINT64 | GetMemoryCapacity (UINT memorySegmentGroup) const |
Returns total amount of memory of specific segment group, in bytes. | |
HRESULT | CreateResource (const ALLOCATION_DESC *pAllocDesc, const D3D12_RESOURCE_DESC *pResourceDesc, D3D12_RESOURCE_STATES InitialResourceState, const D3D12_CLEAR_VALUE *pOptimizedClearValue, Allocation **ppAllocation, REFIID riidResource, void **ppvResource) |
Allocates memory and creates a D3D12 resource (buffer or texture). This is the main allocation function. | |
HRESULT | AllocateMemory (const ALLOCATION_DESC *pAllocDesc, const D3D12_RESOURCE_ALLOCATION_INFO *pAllocInfo, Allocation **ppAllocation) |
Allocates memory without creating any resource placed in it. | |
HRESULT | CreateAliasingResource (Allocation *pAllocation, UINT64 AllocationLocalOffset, const D3D12_RESOURCE_DESC *pResourceDesc, D3D12_RESOURCE_STATES InitialResourceState, const D3D12_CLEAR_VALUE *pOptimizedClearValue, REFIID riidResource, void **ppvResource) |
Creates a new resource in place of an existing allocation. This is useful for memory aliasing. | |
HRESULT | CreatePool (const POOL_DESC *pPoolDesc, Pool **ppPool) |
Creates custom pool. | |
void | SetCurrentFrameIndex (UINT frameIndex) |
Sets the index of the current frame. | |
void | GetBudget (Budget *pLocalBudget, Budget *pNonLocalBudget) |
Retrieves information about current memory usage and budget. | |
void | CalculateStatistics (TotalStatistics *pStats) |
Retrieves statistics from current state of the allocator. | |
void | BuildStatsString (WCHAR **ppStatsString, BOOL DetailedMap) const |
Builds and returns statistics as a string in JSON format. | |
void | FreeStatsString (WCHAR *pStatsString) const |
Frees memory of a string returned from Allocator::BuildStatsString. | |
void | BeginDefragmentation (const DEFRAGMENTATION_DESC *pDesc, DefragmentationContext **ppContext) |
Begins defragmentation process of the default pools. | |
Protected Member Functions | |
void | ReleaseThis () override |
Friends | |
class | DefragmentationContext |
class | Pool |
D3D12MA_API HRESULT | CreateAllocator (const ALLOCATOR_DESC *, Allocator **) |
Creates new main D3D12MA::Allocator object and returns it through ppAllocator . | |
template<typename T > | |
void | D3D12MA_DELETE (const ALLOCATION_CALLBACKS &, T *) |
Represents main object of this library initialized for particular ID3D12Device
.
Fill structure D3D12MA::ALLOCATOR_DESC and call function CreateAllocator() to create it. Call method Release()
to destroy it.
It is recommended to create just one object of this type per ID3D12Device
object, right after Direct3D 12 is initialized and keep it alive until before Direct3D device is destroyed.
HRESULT D3D12MA::Allocator::AllocateMemory | ( | const ALLOCATION_DESC * | pAllocDesc, |
const D3D12_RESOURCE_ALLOCATION_INFO * | pAllocInfo, | ||
Allocation ** | ppAllocation | ||
) |
Allocates memory without creating any resource placed in it.
This function is similar to ID3D12Device::CreateHeap
, but it may really assign part of a larger, existing heap to the allocation.
pAllocDesc->heapFlags
should contain one of these values, depending on type of resources you are going to create in this memory: D3D12_HEAP_FLAG_ALLOW_ONLY_BUFFERS
, D3D12_HEAP_FLAG_ALLOW_ONLY_NON_RT_DS_TEXTURES
, D3D12_HEAP_FLAG_ALLOW_ONLY_RT_DS_TEXTURES
. Except if you validate that ResourceHeapTier = 2 - then heapFlags
may be D3D12_HEAP_FLAG_ALLOW_ALL_BUFFERS_AND_TEXTURES
= 0. Additional flags in heapFlags
are allowed as well.
pAllocInfo->SizeInBytes
must be multiply of 64KB. pAllocInfo->Alignment
must be one of the legal values as described in documentation of D3D12_HEAP_DESC
.
If you use D3D12MA::ALLOCATION_FLAG_COMMITTED you will get a separate memory block - a heap that always has offset 0.
void D3D12MA::Allocator::BeginDefragmentation | ( | const DEFRAGMENTATION_DESC * | pDesc, |
DefragmentationContext ** | ppContext | ||
) |
Begins defragmentation process of the default pools.
pDesc | Structure filled with parameters of defragmentation. | |
[out] | ppContext | Context object that will manage defragmentation. |
For more information about defragmentation, see documentation chapter: Defragmentation.
void D3D12MA::Allocator::BuildStatsString | ( | WCHAR ** | ppStatsString, |
BOOL | DetailedMap | ||
) | const |
Builds and returns statistics as a string in JSON format.
[out] | ppStatsString | Must be freed using Allocator::FreeStatsString. |
DetailedMap | TRUE to include full list of allocations (can make the string quite long), FALSE to only return statistics. |
void D3D12MA::Allocator::CalculateStatistics | ( | TotalStatistics * | pStats | ) |
Retrieves statistics from current state of the allocator.
This function is called "calculate" not "get" because it has to traverse all internal data structures, so it may be quite slow. Use it for debugging purposes. For faster but more brief statistics suitable to be called every frame or every allocation, use GetBudget().
Note that when using allocator from multiple threads, returned information may immediately become outdated.
HRESULT D3D12MA::Allocator::CreateAliasingResource | ( | Allocation * | pAllocation, |
UINT64 | AllocationLocalOffset, | ||
const D3D12_RESOURCE_DESC * | pResourceDesc, | ||
D3D12_RESOURCE_STATES | InitialResourceState, | ||
const D3D12_CLEAR_VALUE * | pOptimizedClearValue, | ||
REFIID | riidResource, | ||
void ** | ppvResource | ||
) |
Creates a new resource in place of an existing allocation. This is useful for memory aliasing.
pAllocation | Existing allocation indicating the memory where the new resource should be created. It can be created using D3D12MA::Allocator::CreateResource and already have a resource bound to it, or can be a raw memory allocated with D3D12MA::Allocator::AllocateMemory. It must not be created as committed so that ID3D12Heap is available and not implicit. | |
AllocationLocalOffset | Additional offset in bytes to be applied when allocating the resource. Local from the start of pAllocation , not the beginning of the whole ID3D12Heap ! If the new resource should start from the beginning of the pAllocation it should be 0. | |
pResourceDesc | Description of the new resource to be created. | |
InitialResourceState | ||
pOptimizedClearValue | ||
riidResource | ||
[out] | ppvResource | Returns pointer to the new resource. The resource is not bound with pAllocation . This pointer must not be null - you must get the resource pointer and Release it when no longer needed. |
Memory requirements of the new resource are checked for validation. If its size exceeds the end of pAllocation
or required alignment is not fulfilled considering pAllocation->GetOffset() + AllocationLocalOffset
, the function returns E_INVALIDARG
.
HRESULT D3D12MA::Allocator::CreateResource | ( | const ALLOCATION_DESC * | pAllocDesc, |
const D3D12_RESOURCE_DESC * | pResourceDesc, | ||
D3D12_RESOURCE_STATES | InitialResourceState, | ||
const D3D12_CLEAR_VALUE * | pOptimizedClearValue, | ||
Allocation ** | ppAllocation, | ||
REFIID | riidResource, | ||
void ** | ppvResource | ||
) |
Allocates memory and creates a D3D12 resource (buffer or texture). This is the main allocation function.
The function is similar to ID3D12Device::CreateCommittedResource
, but it may really call ID3D12Device::CreatePlacedResource
to assign part of a larger, existing memory heap to the new resource, which is the main purpose of this whole library.
If ppvResource
is null, you receive only ppAllocation
object from this function. It holds pointer to ID3D12Resource
that can be queried using function D3D12MA::Allocation::GetResource(). Reference count of the resource object is 1. It is automatically destroyed when you destroy the allocation object.
If ppvResource
is not null, you receive pointer to the resource next to allocation object. Reference count of the resource object is then increased by calling QueryInterface
, so you need to manually Release
it along with the allocation.
pAllocDesc | Parameters of the allocation. | |
pResourceDesc | Description of created resource. | |
InitialResourceState | Initial resource state. | |
pOptimizedClearValue | Optional. Either null or optimized clear value. | |
[out] | ppAllocation | Filled with pointer to new allocation object created. |
riidResource | IID of a resource to be returned via ppvResource . | |
[out] | ppvResource | Optional. If not null, filled with pointer to new resouce created. |
Retrieves information about current memory usage and budget.
[out] | pLocalBudget | Optional, can be null. |
[out] | pNonLocalBudget | Optional, can be null. |
== FALSE
(discrete graphics card):pLocalBudget
returns the budget of the video memory.pNonLocalBudget
returns the budget of the system memory available for D3D12 resources.== TRUE
(integrated graphics chip):pLocalBudget
returns the budget of the shared memory available for all D3D12 resources. All memory is considered "local".pNonLocalBudget
is not applicable and returns zeros.This function is called "get" not "calculate" because it is very fast, suitable to be called every frame or every allocation. For more detailed statistics use CalculateStatistics().
Note that when using allocator from multiple threads, returned information may immediately become outdated.
UINT64 D3D12MA::Allocator::GetMemoryCapacity | ( | UINT | memorySegmentGroup | ) | const |
Returns total amount of memory of specific segment group, in bytes.
memorySegmentGroup | use DXGI_MEMORY_SEGMENT_GROUP_LOCAL or DXGI_MEMORY_SEGMENT_GROUP_NON_LOCAL`. |
This information is taken from DXGI_ADAPTER_DESC
. It is not recommended to use this number. You should preferably call GetBudget() and limit memory usage to D3D12MA::Budget::BudgetBytes instead.
== FALSE
(discrete graphics card):GetMemoryCapacity(DXGI_MEMORY_SEGMENT_GROUP_LOCAL)
returns the size of the video memory.GetMemoryCapacity(DXGI_MEMORY_SEGMENT_GROUP_NON_LOCAL)
returns the size of the system memory available for D3D12 resources.== TRUE
(integrated graphics chip):GetMemoryCapacity(DXGI_MEMORY_SEGMENT_GROUP_LOCAL)
returns the size of the shared memory available for all D3D12 resources. All memory is considered "local".GetMemoryCapacity(DXGI_MEMORY_SEGMENT_GROUP_NON_LOCAL)
is not applicable and returns 0. BOOL D3D12MA::Allocator::IsCacheCoherentUMA | ( | ) | const |
Returns true if D3D12_FEATURE_DATA_ARCHITECTURE1::CacheCoherentUMA
was found to be true.
For more information about how to use it, see articles in Microsoft Docs articles:
BOOL D3D12MA::Allocator::IsUMA | ( | ) | const |
Returns true if D3D12_FEATURE_DATA_ARCHITECTURE1::UMA
was found to be true.
For more information about how to use it, see articles in Microsoft Docs articles:
void D3D12MA::Allocator::SetCurrentFrameIndex | ( | UINT | frameIndex | ) |
Sets the index of the current frame.
This function is used to set the frame index in the allocator when a new game frame begins.
|
friend |
Creates new main D3D12MA::Allocator object and returns it through ppAllocator
.
You normally only need to call it once and keep a single Allocator object for your ID3D12Device
.