trace_processor: perf sample counter tracking and distinguishing between multiple data sources

Primary additions:
* perf_session_id, which distinguishes individual profiling data sources.
* perf_counter_track, which both names the timebase for a
  per-{cpu, perf_session_id} sampling stream, and tracks the sampled
  counts themselves (now inserted into |counter| table).

The is_timebase column is added prematurely, but should become relevant
once we start supporting multi-counter sampling.

See go/perf-counters-tp for overall plan.
Will send a difftest in a separate patch once we agree that this
implementation makes sense.

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