• jarin's avatar
    Linux perf integration with the new support for JIT. · 82e95f59
    jarin authored
    Difference from --perf-basic-prof:
    - correctly attributes samples when code space gets reused (when unused code object dies and a new code objects is allocated at the same place).
    - outputs compiled machine code for instruction-level profile.
    
    Just like --perf-basic-prof, the file writer is not synchronized (even worse, there is a per-isolate file handle), so we will run into trouble with multiple isolates. However, this patch is still an improvement on --perf-basic-prof, and it should be fine to replace ll-prof.
    
    The patch also introduces experimental support for debug info, but it does not seem to be picked by the perf tool.
    
    Usage:
    
    You need the perf tool from Linux kernel >4.5. Then run:
    
    $ perf record -k mono d8 --perf-prof <your JS file>
    $ perf inject -j -i perf.data -o perf.data.jitted
    $ perf report -i perf.data.jitted
    
    Some explanations:
    The "-k mono" switch from "perf record" tells the perf tool to use the monotonic clock for perf sample timestamping. The "perf inject -j" command injects the collected code events into the perf data file, writing the output into perf.data.jitted. The perf report command then creates the report.
    
    Review URL: https://codereview.chromium.org/1809203007
    
    Cr-Commit-Position: refs/heads/master@{#35091}
    82e95f59
Name
Last commit
Last update
..
platform Loading commit data...
utils Loading commit data...
DEPS Loading commit data...
OWNERS Loading commit data...
adapters.h Loading commit data...
atomicops.h Loading commit data...
atomicops_internals_arm64_gcc.h Loading commit data...
atomicops_internals_arm_gcc.h Loading commit data...
atomicops_internals_atomicword_compat.h Loading commit data...
atomicops_internals_mac.h Loading commit data...
atomicops_internals_mips64_gcc.h Loading commit data...
atomicops_internals_mips_gcc.h Loading commit data...
atomicops_internals_portable.h Loading commit data...
atomicops_internals_ppc_gcc.h Loading commit data...
atomicops_internals_s390_gcc.h Loading commit data...
atomicops_internals_tsan.h Loading commit data...
atomicops_internals_x86_gcc.cc Loading commit data...
atomicops_internals_x86_gcc.h Loading commit data...
atomicops_internals_x86_msvc.h Loading commit data...
bits.cc Loading commit data...
bits.h Loading commit data...
build_config.h Loading commit data...
compiler-specific.h Loading commit data...
cpu.cc Loading commit data...
cpu.h Loading commit data...
division-by-constant.cc Loading commit data...
division-by-constant.h Loading commit data...
flags.h Loading commit data...
functional.cc Loading commit data...
functional.h Loading commit data...
iterator.h Loading commit data...
lazy-instance.h Loading commit data...
logging.cc Loading commit data...
logging.h Loading commit data...
macros.h Loading commit data...
once.cc Loading commit data...
once.h Loading commit data...
qnx-math.h Loading commit data...
safe_conversions.h Loading commit data...
safe_conversions_impl.h Loading commit data...
safe_math.h Loading commit data...
safe_math_impl.h Loading commit data...
smart-pointers.h Loading commit data...
sys-info.cc Loading commit data...
sys-info.h Loading commit data...
win32-headers.h Loading commit data...