processor: Translate track & chrome event timestamps to trace time

As a short-term workaround, consider timestamps inside track events as
MONOTONIC domain timestamps. Chrome writes MONOTONIC timestamps on
Android (*) and is the only real user of this timestamp field at the
moment.

Longer term, Chrome will move to writing timestamps in the trace
packet directly, and set the timestamp_clock_id accordingly.

Also includes a hack to treat chrome events / metadata timestamps as
monotonic by default. Chrome already sets these timestamp fields, but
is still missing to set the clock_id due to a bug in chrome. We will
fix this in Chrome too, but should still preserve the ability to
import the buggy trace files correctly for the time being.

(*) Note that Chrome-only traces don't contain clock snapshots right
now, so this change will only affect system + chrome traces, which are
currently only supported on Android.

Bug: 138819158
Change-Id: Ib0a1c7f37f96d6499230b0ed298d43f9b537b318
2 files changed
tree: 2730be3a50bce1ea6ade7815e1c2f67e3c4dffda
  1. bazel/
  2. build_overrides/
  3. buildtools/
  4. debian/
  5. docs/
  6. gn/
  7. include/
  8. infra/
  9. protos/
  10. src/
  11. test/
  12. tools/
  13. ui/
  14. .clang-format
  15. .gitignore
  16. .gn
  17. .style.yapf
  18. Android.bp
  19. Android.bp.extras
  20. BUILD
  21. BUILD.extras
  22. BUILD.gn
  23. codereview.settings
  24. heapprofd.rc
  25. MODULE_LICENSE_APACHE2
  26. NOTICE
  27. OWNERS
  28. perfetto.rc
  29. PRESUBMIT.py
  30. README.chromium
  31. README.md
  32. TEST_MAPPING
  33. WORKSPACE
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.

Community

You can reach us on our Discord channel. If you prefer using IRC we have an experimental Discord <> IRC bridge synced with #perfetto-dev on Freenode.