# HEAP_PROFILE(1) ## NAME heap_profile - record heap profile on Android device ## DESCRIPTION `tools/heap_profile` allows to collect native memory profiles on Android. See [Recording traces](/docs/data-sources/native-heap-profiler.md) for more details about the data-source. ``` usage: heap_profile [-h] [-i INTERVAL] [-d DURATION] [--no-start] [-p PIDS] [-n NAMES] [-c CONTINUOUS_DUMP] [--disable-selinux] [--no-versions] [--no-running] [--no-startup] [--shmem-size SHMEM_SIZE] [--block-client] [--block-client-timeout BLOCK_CLIENT_TIMEOUT] [--no-block-client] [--idle-allocations] [--dump-at-max] [--disable-fork-teardown] [--simpleperf] [--trace-to-text-binary TRACE_TO_TEXT_BINARY] [--print-config] [-o DIRECTORY] ``` ## OPTIONS `-n`, `--name` _NAMES_ : Comma-separated list of process names to profile. `-p`, `--pid` _PIDS_ : Comma-separated list of PIDs to profile. `-i`, `--interval` : Sampling interval. Default 4096 (4KiB) `-o`, `--output` _DIRECTORY_ : Output directory. `--all-heaps` : Collect allocations from all heaps registered by target. `--block-client` : When buffer is full, block the client to wait for buffer space. Use with caution as this can significantly slow down the client. This is the default `--block-client-timeout` : If --block-client is given, do not block any allocation for longer than this timeout (us). `-c`, `--continuous-dump` : Dump interval in ms. 0 to disable continuous dump. `-d`, `--duration` : Duration of profile (ms). 0 to run until interrupted. Default: until interrupted by user. `--disable-fork-teardown` : Do not tear down client in forks. This can be useful for programs that use vfork. Android 11+ only. `--disable-selinux` : Disable SELinux enforcement for duration of profile. `--dump-at-max` : Dump the maximum memory usage rather than at the time of the dump. `-h`, `--help` : show this help message and exit `--heaps` _HEAPS_ : Comma-separated list of heaps to collect, e.g: malloc,art. Requires Android 12. `--idle-allocations` : Keep track of how many bytes were unused since the last dump, per callstack `--no-android-tree-symbolization` : Do not symbolize using currently lunched target in the Android tree. `--no-block-client` : When buffer is full, stop the profile early. `--no-running` : Do not target already running processes. Requires Android 11. `--no-start` : Do not start heapprofd. `--no-startup` : Do not target processes that start during the profile. Requires Android 11. `--no-versions` : Do not get version information about APKs. `--print-config` : Print config instead of running. For debugging. `--shmem-size` : Size of buffer between client and heapprofd. Default 8MiB. Needs to be a power of two multiple of 4096, at least 8192. `--simpleperf` : Get simpleperf profile of heapprofd. This is only for heapprofd development. `--trace-to-text-binary` : Path to local trace to text. For debugging.