d5f4a33eb8
Before fast C calls, store the current FP and PC on the isolate. When iterating frames in SafeStackFrameIterator, check if these fields are set and start iterating at the calling frame's FP instead of the current FP, which will be in C++ code. We need to do this because c_entry_fp is not set on the Isolate for Fast-C-Calls because we don't build an exit frame. This change makes stack samples that occur within 'Fast-C-Calls' iterable, meaning we can properly attribute ticks within the JS caller. Fast-C-Calls can't call back into JS code, so we can only ever have one such call on the stack at a time, allowing us to store the FP on the isolate rather than the stack. TBR=v8-mips-ports@googlegroups.com Bug: v8:8464, v8:7202 Change-Id: I7bf39eba779dad34754d5759d741c421b362a406 Reviewed-on: https://chromium-review.googlesource.com/c/1340241 Commit-Queue: Peter Marshall <petermarshall@chromium.org> Reviewed-by: Jakob Gruber <jgruber@chromium.org> Reviewed-by: Martyn Capewell <martyn.capewell@arm.com> Reviewed-by: Alexei Filippov <alph@chromium.org> Cr-Commit-Position: refs/heads/master@{#57896} |
||
---|---|---|
.. | ||
assembler-ia32-inl.h | ||
assembler-ia32.cc | ||
assembler-ia32.h | ||
code-stubs-ia32.cc | ||
codegen-ia32.cc | ||
constants-ia32.h | ||
cpu-ia32.cc | ||
deoptimizer-ia32.cc | ||
disasm-ia32.cc | ||
frame-constants-ia32.cc | ||
frame-constants-ia32.h | ||
interface-descriptors-ia32.cc | ||
macro-assembler-ia32.cc | ||
macro-assembler-ia32.h | ||
simulator-ia32.cc | ||
simulator-ia32.h | ||
sse-instr.h |