mirror of
https://github.com/python/cpython.git
synced 2025-12-07 13:50:06 +00:00
This PR implements frame caching in the RemoteUnwinder class to significantly reduce memory reads when profiling remote processes with deep call stacks. When cache_frames=True, the unwinder stores the frame chain from each sample and reuses unchanged portions in subsequent samples. Since most profiling samples capture similar call stacks (especially the parent frames), this optimization avoids repeatedly reading the same frame data from the target process. The implementation adds a last_profiled_frame field to the thread state that tracks where the previous sample stopped. On the next sample, if the current frame chain reaches this marker, the cached frames from that point onward are reused instead of being re-read from remote memory. The sampling profiler now enables frame caching by default.
5 lines
317 B
ReStructuredText
5 lines
317 B
ReStructuredText
The ``_remote_debugging`` module now implements frame caching in the
|
|
``RemoteUnwinder`` class to reduce memory reads when profiling remote
|
|
processes. When ``cache_frames=True``, unchanged portions of the call stack
|
|
are reused from previous samples, significantly improving profiling
|
|
performance for deep call stacks.
|