ui: optimize BreakdownTracks and AndroidBinderViz performance
Significantly reduce the time it takes to load traces with large breakdown
track hierarchies (like Android Binder) through three optimizations:
1. Projected Path for BreakdownTracks: Instead of running the expensive
intervals_overlap_count macro O(N) times (once per track node), pre-
calculate all intersections upfront into a shared temporary table.
Individual tracks now just run a cheap filter/aggregation against this
table. This is enabled for standard count-based breakdown tracks without
pivots or complex joins.
2. Batch SQL Table Creation: On the legacy path, CREATE PERFETTO TABLE
statements for counter tracks are now accumulated during the hierarchy
walk and flushed to the engine in a single batched query, reducing IPC
overhead.
3. Parallelize Binder Tracks: The AndroidBinderViz plugin now uses
Promise.all to kick off the generation of both server and client track
hierarchies concurrently rather than sequentially.
Perfetto is an open-source suite of SDKs, daemons and tools which use tracing to help developers understand the behaviour of complex systems and root-cause functional and performance issues on client and embedded systems.
It is a production-grade tool that is the default tracing system for the Android operating system and the Chromium browser.
Perfetto is not a single tool, but a collection of components that work together:
Perfetto was designed to be a versatile and powerful tracing system for a wide range of use cases.
ftrace, allowing you to visualize scheduling, syscalls, interrupts, and custom kernel tracepoints on a timeline.chrome://tracing. Use it to debug and root-cause issues in the browser, V8, and Blink.We‘ve designed our documentation to guide you to the right information as quickly as possible, whether you’re a newcomer to performance analysis or an experienced developer.
New to tracing? If you're unfamiliar with concepts like tracing and profiling, start here:
Ready to dive in? Our “Getting Started” guide is the main entry point for all users. It will help you find the right tutorials and documentation for your specific needs:
Want the full overview? For a comprehensive look at what Perfetto is, why it's useful, and who uses it, see our main documentation page:
For users interested in the Debian distribution of Perfetto, the official source of truth and packaging efforts are maintained at Debian Perfetto Salsa Repository
Have questions? Need help?
We follow Google's Open Source Community Guidelines.