
Current docs don't set up write permissions, so tracing may fail. Change-Id: I8bf3e36b1bd042a3e63b712d20c980b746b66c39 Reviewed-on: https://chromium-review.googlesource.com/621770 Commit-Queue: Primiano Tucci <primiano@chromium.org> Reviewed-by: Primiano Tucci <primiano@chromium.org> Cr-Commit-Position: refs/heads/master@{#497065}
88 lines
3.0 KiB
Markdown
88 lines
3.0 KiB
Markdown
# Startup Tracing with MemoryInfra
|
|
|
|
[MemoryInfra](README.md) supports startup tracing.
|
|
|
|
## The Simple Way
|
|
|
|
Start Chrome as follows:
|
|
|
|
$ chrome --no-sandbox \
|
|
--trace-startup=-*,disabled-by-default-memory-infra \
|
|
--trace-startup-file=/tmp/trace.json \
|
|
--trace-startup-duration=7
|
|
|
|
On Android, first ensure that Chrome can write output files to storage. Replace
|
|
"org.chromium.chrome" with the Chrome package you are tracing:
|
|
|
|
$ adb shell pm grant org.chromium.chrome android.permission.READ_EXTERNAL_STORAGE
|
|
$ adb shell pm grant org.chromium.chrome android.permission.WRITE_EXTERNAL_STORAGE
|
|
|
|
Then enable startup tracing and start Chrome as follows:
|
|
|
|
$ build/android/adb_chrome_public_command_line \
|
|
--trace-startup=-*,disabled-by-default-memory-infra \
|
|
--trace-startup-file=/sdcard/Download/trace.json \
|
|
--trace-startup-duration=7
|
|
|
|
$ build/android/adb_run_chrome_public
|
|
|
|
$ adb pull /sdcard/Download/trace.json # After tracing.
|
|
|
|
Note that startup tracing will be enabled upon every Chrome launch until you
|
|
delete the command-line flags:
|
|
|
|
$ build/android/adb_chrome_public_command_line ""
|
|
|
|
This will use the default configuration: one memory dump every 250 ms with a
|
|
detailed dump ever two seconds.
|
|
|
|
## The Advanced Way
|
|
|
|
If you need more control over the granularity of the memory dumps, you can
|
|
specify a custom trace config file as follows:
|
|
|
|
$ cat > /tmp/trace.config
|
|
{
|
|
"startup_duration": 4,
|
|
"result_file": "/tmp/trace.json",
|
|
"trace_config": {
|
|
"included_categories": ["disabled-by-default-memory-infra"],
|
|
"excluded_categories": ["*"],
|
|
"memory_dump_config": {
|
|
"triggers": [
|
|
{ "mode": "light", "periodic_interval_ms": 50 },
|
|
{ "mode": "detailed", "periodic_interval_ms": 1000 }
|
|
]
|
|
}
|
|
}
|
|
}
|
|
|
|
$ chrome --no-sandbox --trace-config-file=/tmp/trace.config
|
|
|
|
On Android, the config file has to be pushed to a fixed file location:
|
|
|
|
$ adb root
|
|
$ adb push /tmp/trace.config /data/local/chrome-trace-config.json
|
|
|
|
$ build/android/adb_run_chrome_public
|
|
|
|
$ adb pull /sdcard/Download/trace.json # After tracing.
|
|
|
|
Make sure that the "result_file" location is writable by the Chrome process on
|
|
Android (e.g. "/sdcard/Download/trace.json"). To ensure Chrome has permissions
|
|
to write to /sdcard, run the following, replacing "org.chromium.chrome" with
|
|
the Chrome package you are tracing:
|
|
|
|
$ adb shell pm grant org.chromium.chrome android.permission.READ_EXTERNAL_STORAGE
|
|
$ adb shell pm grant org.chromium.chrome android.permission.WRITE_EXTERNAL_STORAGE
|
|
|
|
Note that startup tracing will be enabled upon every Chrome launch until you
|
|
delete the config file:
|
|
|
|
$ adb shell rm /data/local/chrome-trace-config.json
|
|
|
|
## Related Pages
|
|
|
|
* [General information about startup tracing](https://sites.google.com/a/chromium.org/dev/developers/how-tos/trace-event-profiling-tool/recording-tracing-runs)
|
|
* [Memory tracing with MemoryInfra](README.md)
|