probes: fix premature flush ack if a data source acks synchronously

While iterating on the num_data_sources we populate the
pending_flushes_ map. The intended use of that map is:
- Every time a data source acks the flush, we clear
  the correponding entry in the map.
- Once the map is empty, we know all data sources have acked,
  and we can give the cumulative Flush response to traced.
- HOWEVER: if a data source invokes the flush_callback directly
  in the it->second->Flush(...) call we end up nesting a call
  to OnDataSourceFlushComplete while still in the first
  iteration of the Flush loop.
- The final effect is that while we are in the first iteration
  of the Flush loop, we temporarily empty the map and send a
  confirmation straight-away to traced (which then will snapshot
  the trace ahead of time) while we are still flushing.

Bug: 295189870
Bug: 290213426
Test: unfortunately this bug is so subtle and required the alignment
      on so many unfavorable conditions that I struggle to write a
      meaningful test for it.
      PerfettoFtraceIntegrationTest.TestFtraceFlush was intending to
      unveil this sort of bug, but didn't have all the triggering
      conditions.
Change-Id: I84a3f1a89b0c7dddffaef6cccca8f21febf5519a
1 file changed
tree: 7a89ed29b00a70e5db9b0e656e95e6109cae91db
  1. .github/
  2. bazel/
  3. build_overrides/
  4. buildtools/
  5. debian/
  6. docs/
  7. examples/
  8. gn/
  9. include/
  10. infra/
  11. protos/
  12. python/
  13. src/
  14. test/
  15. third_party/
  16. tools/
  17. ui/
  18. .clang-format
  19. .clang-tidy
  20. .git-blame-ignore-revs
  21. .gitattributes
  22. .gitignore
  23. .gn
  24. .style.yapf
  25. Android.bp
  26. Android.bp.extras
  27. BUILD
  28. BUILD.extras
  29. BUILD.gn
  30. CHANGELOG
  31. codereview.settings
  32. DIR_METADATA
  33. heapprofd.rc
  34. LICENSE
  35. meson.build
  36. METADATA
  37. MODULE_LICENSE_APACHE2
  38. OWNERS
  39. perfetto.rc
  40. PerfettoIntegrationTests.xml
  41. PRESUBMIT.py
  42. README.chromium
  43. README.md
  44. TEST_MAPPING
  45. traced_perf.rc
  46. 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.