Add android_jank_cuj metric

It's a rewrite of android_sysui_cuj metric with support for processing
>1 CUJ per trace. At the same time the queries were cleaned up and
simplified (e.g. matching of slices to frames), I added some docs to
make it possible for a motivated person to actually follow the flow.

Creating a separate metric to not break downstream consumers and to
allow running both metrics side by side to compare results while we are
migrating from one to the other.

SF tables will be rewritten in a similar manner in a future CL.

Change-Id: I5c341ab4a4a6439cc11f286b29d12624d5938222
22 files changed
tree: 10ad31f553689774860cb67fd579a011dc4ccd53
  1. .github/
  2. bazel/
  3. build_overrides/
  4. buildtools/
  5. debian/
  6. docs/
  7. examples/
  8. gn/
  9. include/
  10. infra/
  11. protos/
  12. python/
  13. src/
  14. test/
  15. tools/
  16. ui/
  17. .clang-format
  18. .clang-tidy
  19. .gitattributes
  20. .gitignore
  21. .gn
  22. .style.yapf
  23. Android.bp
  24. Android.bp.extras
  25. BUILD
  26. BUILD.extras
  27. BUILD.gn
  28. CHANGELOG
  29. codereview.settings
  30. DIR_METADATA
  31. heapprofd.rc
  32. LICENSE
  33. meson.build
  34. METADATA
  35. MODULE_LICENSE_APACHE2
  36. OWNERS
  37. perfetto.rc
  38. PerfettoIntegrationTests.xml
  39. PRESUBMIT.py
  40. README.chromium
  41. README.md
  42. TEST_MAPPING
  43. traced_perf.rc
  44. WORKSPACE
README.md

Perfetto - System profiling, app tracing and trace analysis

Perfetto is a production-grade open-source stack for performance instrumentation and trace analysis. It offers services and libraries and for recording system-level and app-level traces, native + java heap profiling, a library for analyzing traces using SQL and a web-based UI to visualize and explore multi-GB traces.

See https://perfetto.dev/docs or the /docs/ directory for documentation.