aboutsummaryrefslogtreecommitdiff
path: root/docs
diff options
context:
space:
mode:
authorSasha Smundak <asmundak@google.com>2022-11-18 15:32:49 -0800
committerSasha Smundak <asmundak@google.com>2022-11-21 10:56:51 -0800
commitfaa97b7eb9b3b1cd0ea1512165aa371776d39205 (patch)
tree5cd959f7d528a575c4c0dd7133c58067b230b433 /docs
parent6f235d9b3947f9a34ddf36d4632764f2327b415b (diff)
Allow profiling Soong from the full build
Test: treehugger Change-Id: I5112364fff635b856a55744457f547d3eba91391
Diffstat (limited to 'docs')
-rw-r--r--docs/perf.md21
1 files changed, 17 insertions, 4 deletions
diff --git a/docs/perf.md b/docs/perf.md
index 694dcf135..5b53c8de8 100644
--- a/docs/perf.md
+++ b/docs/perf.md
@@ -42,16 +42,29 @@ critical path:
```
If the elapsed time is much longer than the critical path then additional
-parallelism on the build machine will improve total build times. If there are
+parallelism on the build machine will improve total build times. If there are
long individual times listed in the critical path then improving build times
for those steps or adjusting dependencies so that those steps can run earlier
in the build graph will improve total build times.
### Soong
-Soong can be traced and profiled using the standard Go tools. It understands
-the `-cpuprofile`, `-trace`, and `-memprofile` command line arguments, but we
-don't currently have an easy way to enable them in the context of a full build.
+Soong proper (i.e., `soong_build` executable that processes the blueprint
+files) can be traced and profiled using the standard Go tools. It understands
+the `-trace`, `-cpuprofile`, and `-memprofile` command line arguments.
+Setting `SOONG_PROFILE_CPU` and/or `SOONG_PROFILE_MEM` environment variables
+for the build enables respective profiling, e.g., running
+
+```shell
+SOONG_PROFILE_CPU=/tmp/foo m ..._
+```
+
+saves CPU profile for each Soong invocation in /tmp/foo._step_ file, where
+_step_ is Soong execution step. The main step is `build`. The others as
+`bp2build_files`, `bp2build_workspace`, `modulegraph`, `queryview`,
+`api_bp2build`, `soong_docs` (not all of them necessarily run during the build).
+The profiles can be inspected with `go tool pprof` from the command line or
+with _Run>Open Profiler Snapshot_ in IntelliJ IDEA.
### Kati