trace_processor: rewrite raw table to systrace conversion code

This CL overhauls the code which converts the lines of the raw table
into legacy systrace format.

Until this point, we were using a very fragile mechanism where we relied
on the fact that the ordering of proto fields == the ordering in the
args table. However, after aosp/1232520 we started sorting args based on
key id. While generally this won't cause breakage, in some subtle cases
(e.g. for binder_transaction), this was causing a reordering of the
fields and thus crashes on debug and wrong output on release.

Change this system to properly create a mapping between the order in
the proto and the args table. We assume that for each event type, we
will always get the same mapping of rows - this is a reasonable
assumption as we do not expect the fields of ftrace to change
mid-trace. Caching the ordering is necessary to get good performance.

While there is a small performance hit by doing this, it is pretty
negligible in the grand scheme of things (1% over for a 16GB trace).

Bug: 150919723
Change-Id: I5b8eff0c2f528f882428019bd9f448fed738733c
6 files changed
tree: f3fc41a3186373c9b6c50892b476eb2f988048b0
  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. LICENSE
  26. MODULE_LICENSE_APACHE2
  27. NOTICE
  28. OWNERS
  29. perfetto.rc
  30. PRESUBMIT.py
  31. README.chromium
  32. README.md
  33. TEST_MAPPING
  34. traced_perf.rc
  35. 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.

Contributing

See /docs/contributing.md for instructions.

The source-of-truth repo is Android's Gerrit. The GitHub repo is a read-only mirror.

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.