Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Records a memory freeing event.
Syntax
void PIXRecordMemoryFreeEvent(
USHORT allocatorId,
void* baseAddress,
size_t size,
UINT64 metadata
)
Parameters
allocatorId
Type: USHORT
An ID you can use to identify groups of memory allocations in the memory profiler. For example, if you have different heaps for things such as graphics, audio, and physics, you can assign each of these categories a different allocatorID so they are easy to identify when viewing a memory capture in PIX.
baseAddress
Type: void*
The starting address of the memory that has been freed.
size
Type: size_t
The size of the memory that has been freed in bytes.
metadata
Type: UINT64
A 64-bit unsigned integer you can use to tag a memory freeing with additional data. This extra data is displayed in PIX in a UserData column. You can use this extra data to identify the type of object within your title that has been freed at a given memory location, for example. The value passed to PIXRecordMemoryFreeEvent
does not have to match the value passed to the corresponding call to PIXRecordMemoryAllocationEvent.
Return value
Type: void
Remarks
A PIX memory tracking event provides the data that PIX needs to display information about all memory allocations and releasings made from within the title's custom memory allocators in memory profiling captures. By providing this data, PIX will show all the same data for your custom allocators that it does for calls to VirtualAlloc/VirtualFree
and HeapAlloc/HeapFree
.
PIX uses the baseAddress and size parameters to locate the corresponding allocation as follows: If baseAddress matches the baseAddress passed to the corresponding call to PIXRecordMemoryAllocationEvent, PIX will match up the allocation and free by simply comparing the addresses. In this case, 0 can be passed for the size parameter. If baseAddress is different than the value specified in the corresponding allocation, the size parameter must be specified as non-zero. In this case, PIX will find the corresponding allocations using both baseAddress and size.
If there are a large number of events occurring at the same time or the system is under a heavy load, memory events can be lost by Event Tracing for Windows (ETW). Event loss will result in an incomplete analysis of data. PIX Memory Capture UI will display a warning indicating event loss.
Requirements
Header: pixmemory.h
Library: pixevt.lib
Supported platforms: Xbox One family consoles and Xbox Series consoles
See also
PIX custom memory allocators (NDA topic)Authorization required
PIX API reference
PIXRecordMemoryAllocationEvent
PIX (NDA topic)Authorization required