blob: bd0707e721a723e96e47252a9f2fe03f503978e8 [file] [log] [blame] [view]
# Perfetto SDK example project
This directory contains an example project using the [Perfetto
SDK](https://perfetto.dev/docs/instrumentation/tracing-sdk). It demonstrates
how to instrument your application with track events to give more context in
developing, debugging and performance analysis.
Dependencies:
- [CMake](https://cmake.org/)
- C++17
## Building
First, check out the latest Perfetto release:
```bash
git clone https://android.googlesource.com/platform/external/perfetto -b v45.0
```
Then, build using CMake:
```bash
cd perfetto/examples/sdk
cmake -B build
cmake --build build
```
Note: If amalgamated source files are not present, generate them using
`cd perfetto ; tools/gen_amalgamated --output sdk/perfetto`.
[Learn more](https://perfetto.dev/docs/contributing/sdk-releasing#building-and-tagging-the-release)
at the release section.
## Track event example
The [basic example](example.cc) shows how to instrument an app with track
events. Run it with:
```bash
build/example
```
The program will create a trace file in `example.perfetto-trace`, which can be
directly opened in the [Perfetto UI](https://ui.perfetto.dev). The result
should look like this:
![Example trace loaded in the Perfetto UI](
example.png "Example trace loaded in the Perfetto UI")
## System-wide example
While the above example only records events from the program itself, with
Perfetto it's also possible to combine app trace events with system-wide
profiling data (e.g., ftrace on Linux). The repository has a [second
example](example_system_wide.cc) which demonstrates this on Android.
Requirements:
- [Android NDK](https://developer.android.com/ndk)
- A device running Android Pie or newer
> Tip: It's also possible to sideload Perfetto on pre-Pie Android devices.
> See the [build
> instructions](https://perfetto.dev/docs/contributing/build-instructions).
To build:
```bash
export NDK=/path/to/ndk
cmake -DCMAKE_TOOLCHAIN_FILE=$NDK/build/cmake/android.toolchain.cmake \
-DANDROID_ABI=arm64-v8a \
-DANDROID_PLATFORM=android-21 \
-DANDROID_LD=lld \
-DCMAKE_BUILD_TYPE=Release \
-B build_android
cmake --build build_android
```
Next, plug in an Android device into a USB port, download the example and run
it while simultaneously recording a trace using the `perfetto` command line
tool:
```bash
adb push build_android/example_system_wide ../system_wide_trace_cfg.pbtxt \
/data/local/tmp/
adb shell "\
cd /data/local/tmp; \
rm -f /data/misc/perfetto-traces/example_system_wide.perfetto-trace; \
cat system_wide_trace_cfg.pbtxt | \
perfetto --config - --txt --background \
-o
/data/misc/perfetto-traces/example_system_wide.perfetto-trace; \
./example_system_wide"
```
Finally, retrieve the resulting trace:
```bash
adb pull /data/misc/perfetto-traces/example_system_wide.perfetto-trace
```
When opened in the Perfetto UI, the trace now shows additional contextual
information such as CPU frequencies and kernel scheduler information.
![Example system wide-trace loaded in the Perfetto UI](
example_system_wide.png "Example system-wide trace in the Perfetto UI")
> Tip: You can generate a new trace config with additional data sources using
> the [Perfetto UI](https://ui.perfetto.dev/#!/record) and replace
> `system_wide_trace_cfg.pbtxt` with the [generated config](
> https://ui.perfetto.dev/#!/record/instructions).
## Custom data source example
The [final example](example_custom_data_source.cc) shows how to use an
application defined data source to emit custom, strongly typed data into a
trace. Run it with:
```bash
build/example_custom_data_source
```
The program generates a trace file in `example_custom_data_source.perfetto-trace`,
which we can examine using Perfetto's `traceconv` tool to show the trace
packet written by the custom data source:
```bash
traceconv text example_custom_data_source.perfetto-trace
...
packet {
trusted_uid: 0
timestamp: 42
trusted_packet_sequence_id: 2
previous_packet_dropped: true
for_testing {
str: "Hello world!"
}
}
...
```