UI: seamlessly migrate to catapult UI for legacy traces

- Add UI code for loading traces in catapult, specifically:
  A) For legacy JSON traces, pass them directly to the old UI.
  B) For newer perfetto traces, convert them to JSON invoking
     trace_to_text into the controller worker and then pass
     them back to the main thread and pass the over to the old
     Catapult UI.
- Build trace_to_text as a WASM module.
- Tweak WASM build files to support >1 wasm targets.
- Add a script to roll Catapult's trace viewer into
  GCS and build it as part of assets.
- Fix some bugs in trace_to_text when building for a
  32-bit target.

Bug: 117977226
Change-Id: I5dced437677b8b978707de5bcef6b02785f32786
23 files changed
tree: d85c545a7f072e7bd44494ad21322a4c6be974b1
  1. build_overrides/
  2. buildtools/
  3. debian/
  4. docs/
  5. gn/
  6. include/
  7. infra/
  8. protos/
  9. src/
  10. test/
  11. tools/
  12. ui/
  13. .clang-format
  14. .gitignore
  15. .gn
  16. .travis.yml
  17. Android.bp
  18. Android.bp.extras
  19. BUILD.gn
  20. codereview.settings
  21. heapprofd.rc
  22. MODULE_LICENSE_APACHE2
  23. NOTICE
  24. OWNERS
  25. perfetto.rc
  26. PRESUBMIT.py
  27. README.chromium
  28. README.md
README.md

Perfetto - Performance instrumentation and tracing

Perfetto is an open-source project for performance instrumentation and tracing of Linux/Android/Chrome platforms and user-space apps.

See www.perfetto.dev for docs.

Bugs

  • For bugs affecting Android or the tracing internals use the internal bug tracker (go/perfetto-bugs).
  • For bugs affecting Chrome use http://crbug.com, Component:Speed>Tracing label:Perfetto.