traced: Send empty OnTraceData response if tracing not started

Currently if a consumer attempts to ReadBuffers and tracing has not
started the service never returns a response. This commonly occurs when
the consumer fails to start tracing: the service sends OnTracingDisabled
the consumer can't distinguish between this failure and a legitimate
OnTracingDisabled and so calls ReadBuffers and waits forever for
OnTracePacket.

This:
- Changes the service to send an empty response to OnTraceData
  allowing finalization in the client to proceed as normal
- Updates perfetto_cmd to be more robust to these kinds of problems
  by adding a duration guardrail for background traces
- Updates a log message to make sense for indefinite traces
- Bumps the amount of leeway in the guardrail from 10s to 60s:
  finalizing the trace can take some time especially if compression
  is enabled

Bug: 137831924
Change-Id: Ie5c48cbd9fd93834d27cee7e0adc1a763d8ac1f0
5 files changed
tree: 696c0818c500cfdda9f79dd339c038c8962d1ba2
  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
  20. BUILD.extras
  21. BUILD.gn
  22. codereview.settings
  23. heapprofd.rc
  24. MODULE_LICENSE_APACHE2
  25. NOTICE
  26. OWNERS
  27. perfetto.rc
  28. PRESUBMIT.py
  29. README.chromium
  30. README.md
  31. TEST_MAPPING
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.