| # PERFETTO(1) |
| |
| ## NAME |
| |
| perfetto - capture traces |
| |
| ## DESCRIPTION |
| |
| This section describes how to use the `perfetto` commandline binary to capture |
| traces. Examples are given in terms of an Android device connected over ADB. |
| |
| `perfetto` has two modes for configuring the tracing session (i.e. what and how |
| to collect): |
| |
| __lightweight mode__ |
| : all config options are supplied as commandline flags, |
| but the available data sources are restricted to ftrace and atrace. This mode |
| is similar to |
| [`systrace`](https://developer.android.com/topic/performance/tracing/command-line). |
| |
| __normal mode__ |
| : the configuration is specified in a protocol buffer. This allows for full |
| customisation of collected traces. |
| |
| |
| ## GENERAL OPTIONS |
| |
| The following table lists the available options when using `perfetto` in either |
| mode. |
| |
| `-d`, `--background` |
| : Perfetto immediately exits the command-line interface and continues |
| recording your trace in background. |
| |
| `-o`, `--out` _OUT_FILE_ |
| : Specifies the desired path to the output trace file, or `-` for stdout. |
| `perfetto` writes the output to the file described in the flags above. |
| The output format compiles with the format defined in |
| [AOSP `trace.proto`](/protos/perfetto/trace/trace.proto). |
| |
| `--dropbox` _TAG_ |
| : Uploads your trace via the |
| [DropBoxManager API](https://developer.android.com/reference/android/os/DropBoxManager.html) |
| using the tag you specify. Android only. |
| |
| `--no-guardrails` |
| : Disables protections against excessive resource usage when enabling the |
| `--dropbox` flag during testing. |
| |
| |
| `--reset-guardrails` |
| : Resets the persistent state of the guardrails and exits (for testing). |
| |
| `--query` |
| : Queries the service state and prints it as human-readable text. |
| |
| `--query-raw` |
| : Similar to `--query`, but prints raw proto-encoded bytes of |
| `tracing_service_state.proto`. |
| |
| `-h`, `--help` |
| : Prints out help text for the `perfetto` tool. |
| |
| |
| ## SIMPLE MODE |
| |
| For ease of use, the `perfetto` command includes support for a subset of |
| configurations via command line arguments. On-device, these |
| configurations behave equivalently to the same configurations provided |
| by a *CONFIG_FILE* (see below). |
| |
| The general syntax for using `perfetto` in *simple mode* is as follows: |
| |
| ``` |
| adb shell perfetto [ --time TIMESPEC ] [ --buffer SIZE ] [ --size SIZE ] |
| [ ATRACE_CAT | FTRACE_GROUP/FTRACE_NAME]... |
| ``` |
| |
| |
| The following table lists the available options when using `perfetto` in |
| *simple mode*. |
| |
| `-t`, `--time` _TIME[s|m|h]_ |
| : Specifies the trace duration in seconds, minutes, or hours. |
| For example, `--time 1m` specifies a trace duration of 1 minute. |
| The default duration is 10 seconds. |
| |
| `-b`, `--buffer` _SIZE[mb|gb]_ |
| : Specifies the ring buffer size in megabytes (mb) or gigabytes (gb). |
| The default parameter is `--buffer 32mb`. |
| |
| `-s`, `--size` _SIZE[mb|gb]_ |
| : Specifies the max file size in megabytes (mb) or gigabytes (gb). |
| By default `perfetto` uses only in-memory ring-buffer. |
| |
| |
| This is followed by a list of event specifiers: |
| |
| `ATRACE_CAT` |
| : Specifies the atrace categories you want to record a trace for. |
| For example, the following command traces Window Manager using atrace: |
| `adb shell perfetto --out FILE wm`. To record other categories, see the |
| [list of atrace categories](https://cs.android.com/android/platform/superproject/+/main:frameworks/native/cmds/atrace/atrace.cpp). |
| Note: Available categories are Android version dependent. |
| |
| `FTRACE_GROUP/FTRACE_NAME` |
| : Specifies the ftrace events you want to record a trace for. |
| For example, the following command traces sched/sched_switch events: |
| `adb shell perfetto --out FILE sched/sched_switch` |
| |
| |
| ## NORMAL MODE |
| |
| The general syntax for using `perfetto` in *normal mode* is as follows: |
| |
| ``` |
| adb shell perfetto [ --txt ] --config CONFIG_FILE |
| ``` |
| |
| The following table lists the available options when using `perfetto` in |
| *normal* mode. |
| |
| `-c`, `--config` _CONFIG_FILE_ |
| : Specifies the path to a configuration file. In normal mode, some |
| configurations may be encoded in a configuration protocol buffer. |
| This file must comply with the protocol buffer schema defined in AOSP |
| [`trace_config.proto`](/protos/perfetto/config/data_source_config.proto). |
| You select and configure the data sources using the DataSourceConfig member |
| of the TraceConfig, as defined in AOSP |
| [`data_source_config.proto`](/protos/perfetto/config/data_source_config.proto). |
| |
| `--txt` |
| : Instructs `perfetto` to parse the config file as pbtxt. This flag is |
| experimental, and it's not recommended that you enable it for production. |