Have separate sampler per heap.

This will allow us to have separate sampling rates per heap (e.g. ART
Allocation Tracking could be higher volume, so we want a higher
interval).  This also is necessary if we want to allow clients to report
samples rather than allocations for their heap, because that will cause
that heap to have a separate (implicit) sampler, while all the others
share one.

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