Enabling Heap Data Capture
Process heap analysis is most effective when stacks are collected capturing HeapAlloc and HeapRealloc events. To decode stacks with symbols, you must enable symbol decoding. You can capture heap data either when a process is started or on an existing process.
To Enable Data Capture When a Process Is Started
This example starts the process being analyzed from the command-line sequence that starts data capture. Enabling data capture when a process is started guarantees that there is no loss of allocation information or history. Take the following steps to enable data capture on process launch:
From an elevated command prompt, type the following command:
xperf -on Base -BufferSize 1024 -MinBuffers 10 -MaxBuffers 16
The following is an example command:
xperf -start HeapSession -heap -PidNewProcess "C:\Program Files\Windows Sidebar\sidebar.exe" -BufferSize 1024 -MinBuffers 128 -MaxBuffers 128 -stackwalk HeapAlloc+HeapRealloc
The sidebar opens on the desktop.
The following table describes these commands.
Command Description -start HeapSession
Initializes a tracing session or logger session. In this case the session is named "HeapSession".
-heap
Identifies "HeapSession" as a heap trace.
-PidNewProcess
Initializes a process. In this case, initializes the Windows Sidebar.
-BufferSize
Sets the buffer size of the buffer in which the event data is stored. An optimum size for a buffer is 1024 KB. The default is 64 KB.
-MinBuffers
Sets the minimum number of buffers for event data storage. MinBuffers should be equal to MaxBuffers to guarantee consistency between traces.
-MaxBuffers
Allocate MaxBuffers conservatively, because buffers are allocated from non-paged memory, which is a finite system resource.
-stackwalk
Initializes the stackwalk facility to collect allocation and deallocation information and associate that information with specific threads.
HeapAlloc+HeapRealloc
Identifies specific heap events to be captured and presented by the stackwalk facility.
Type the following command:
xperf -stop -stop HeapSession -d HeapTrace.etl
The
-d HeapTrace.etl
command merges traces produced in the session into the HeapTrace.etl file.
To Enable Data Capture on an Existing Process
This option enables data capture without stopping and restarting the process. This may be advantageous when the scenario being analyzed does not occur until well after the application starts, and initial heap allocation (which can generate extremely large trace files) is not needed.
Take the following steps:
From an elevated command prompt, start the NT Kernel Logger with the BASE flag as follows:
xperf -on BASE
To enable heap tracing on an existing process, substitute the actual process ID for XXX in the following command:
xperf -start HeapSession -heap -Pid XXX -BufferSize 1024 -MinBuffers 128 -MaxBuffers 128 -stackwalk HeapAlloc+HeapRealloc
Prepare the traces for analysis in the same manner as done for data capture when a process is started:
xperf -stop -stop HeapSession -d heapTrace.etl