• jarin's avatar
    [turbofan] Variable liveness analysis for deopt. · ca3abde2
    jarin authored
    This change introduces a liveness analyzer for local variables in frame states.
    
    The main idea is to use the AstGraphBuilder::Environment class to build the control flow graph, and record local variable loads, stores and checkpoints in the CFG basic blocks (LivenessAnalyzerBlock class).
    
    After the graph building finishes, we run a simple data flow analysis over the CFG to figure out liveness of each local variable at each checkpoint. Finally, we run a pass over all the checkpoints and replace dead local variables in the frame states with the 'undefined' value.
    
    Performance numbers for Embenchen are below.
    
    ----------- box2d.js
    Current --turbo-deoptimization: EmbenchenBox2d(RunTime): 11265 ms.
    d8-master --turbo-deoptimization: EmbenchenBox2d(RunTime): 11768 ms.
    d8-master: EmbenchenBox2d(RunTime): 10996 ms.
    ----------- bullet.js
    Current --turbo-deoptimization: EmbenchenBullet(RunTime): 17049 ms.
    d8-master --turbo-deoptimization: EmbenchenBullet(RunTime): 17384 ms.
    d8-master: EmbenchenBullet(RunTime): 16153 ms.
    ----------- copy.js
    Current --turbo-deoptimization: EmbenchenCopy(RunTime): 4877 ms.
    d8-master --turbo-deoptimization: EmbenchenCopy(RunTime): 4938 ms.
    d8-master: EmbenchenCopy(RunTime): 4940 ms.
    ----------- corrections.js
    Current --turbo-deoptimization: EmbenchenCorrections(RunTime): 7068 ms.
    d8-master --turbo-deoptimization: EmbenchenCorrections(RunTime): 6718 ms.
    d8-master: EmbenchenCorrections(RunTime): 6858 ms.
    ----------- fannkuch.js
    Current --turbo-deoptimization: EmbenchenFannkuch(RunTime): 4167 ms.
    d8-master --turbo-deoptimization: EmbenchenFannkuch(RunTime): 4608 ms.
    d8-master: EmbenchenFannkuch(RunTime): 4149 ms.
    ----------- fasta.js
    Current --turbo-deoptimization: EmbenchenFasta(RunTime): 9981 ms.
    d8-master --turbo-deoptimization: EmbenchenFasta(RunTime): 9848 ms.
    d8-master: EmbenchenFasta(RunTime): 9640 ms.
    ----------- lua_binarytrees.js
    Current --turbo-deoptimization: EmbenchenLuaBinaryTrees(RunTime): 11571 ms.
    d8-master --turbo-deoptimization: EmbenchenLuaBinaryTrees(RunTime): 13089 ms.
    d8-master: EmbenchenLuaBinaryTrees(RunTime): 10957 ms.
    ----------- memops.js
    Current --turbo-deoptimization: EmbenchenMemOps(RunTime): 7766 ms.
    d8-master --turbo-deoptimization: EmbenchenMemOps(RunTime): 7346 ms.
    d8-master: EmbenchenMemOps(RunTime): 7738 ms.
    ----------- primes.js
    Current --turbo-deoptimization: EmbenchenPrimes(RunTime): 7459 ms.
    d8-master --turbo-deoptimization: EmbenchenPrimes(RunTime): 7453 ms.
    d8-master: EmbenchenPrimes(RunTime): 7451 ms.
    ----------- skinning.js
    Current --turbo-deoptimization: EmbenchenSkinning(RunTime): 15564 ms.
    d8-master --turbo-deoptimization: EmbenchenSkinning(RunTime): 15611 ms.
    d8-master: EmbenchenSkinning(RunTime): 15583 ms.
    ----------- zlib.js
    Current --turbo-deoptimization: EmbenchenZLib(RunTime): 10825 ms.
    d8-master --turbo-deoptimization: EmbenchenZLib(RunTime): 11180 ms.
    d8-master: EmbenchenZLib(RunTime): 10823 ms.
    
    BUG=
    
    Review URL: https://codereview.chromium.org/949743002
    
    Cr-Commit-Position: refs/heads/master@{#27232}
    ca3abde2
Name
Last commit
Last update
..
arm Loading commit data...
arm64 Loading commit data...
ia32 Loading commit data...
mips Loading commit data...
mips64 Loading commit data...
ppc Loading commit data...
x64 Loading commit data...
change-lowering-unittest.cc Loading commit data...
common-operator-reducer-unittest.cc Loading commit data...
common-operator-unittest.cc Loading commit data...
compiler-test-utils.h Loading commit data...
control-equivalence-unittest.cc Loading commit data...
control-flow-optimizer-unittest.cc Loading commit data...
control-reducer-unittest.cc Loading commit data...
diamond-unittest.cc Loading commit data...
graph-reducer-unittest.cc Loading commit data...
graph-unittest.cc Loading commit data...
graph-unittest.h Loading commit data...
instruction-selector-unittest.cc Loading commit data...
instruction-selector-unittest.h Loading commit data...
instruction-sequence-unittest.cc Loading commit data...
instruction-sequence-unittest.h Loading commit data...
js-builtin-reducer-unittest.cc Loading commit data...
js-intrinsic-lowering-unittest.cc Loading commit data...
js-operator-unittest.cc Loading commit data...
js-typed-lowering-unittest.cc Loading commit data...
liveness-analyzer-unittest.cc Loading commit data...
load-elimination-unittest.cc Loading commit data...
loop-peeling-unittest.cc Loading commit data...
machine-operator-reducer-unittest.cc Loading commit data...
machine-operator-unittest.cc Loading commit data...
move-optimizer-unittest.cc Loading commit data...
node-matchers-unittest.cc Loading commit data...
node-properties-unittest.cc Loading commit data...
node-test-utils.cc Loading commit data...
node-test-utils.h Loading commit data...
node-unittest.cc Loading commit data...
opcodes-unittest.cc Loading commit data...
register-allocator-unittest.cc Loading commit data...
schedule-unittest.cc Loading commit data...
scheduler-unittest.cc Loading commit data...
select-lowering-unittest.cc Loading commit data...
simplified-operator-reducer-unittest.cc Loading commit data...
simplified-operator-unittest.cc Loading commit data...
state-values-utils-unittest.cc Loading commit data...
typer-unittest.cc Loading commit data...
value-numbering-reducer-unittest.cc Loading commit data...
zone-pool-unittest.cc Loading commit data...