aboutsummaryrefslogtreecommitdiffstats
path: root/lib/compiler/src/cerl_sets.erl
diff options
context:
space:
mode:
authorBjörn Gustavsson <[email protected]>2018-08-21 08:58:15 +0200
committerBjörn Gustavsson <[email protected]>2018-09-17 06:41:02 +0200
commit70bb14fe3fd27e8c429bf402e364b144a5807d9a (patch)
treec8c86337d5324e900ce483eb49b32227a3a314d2 /lib/compiler/src/cerl_sets.erl
parentec1f35c9f52be894ba295b9a48237020855e3c46 (diff)
downloadotp-70bb14fe3fd27e8c429bf402e364b144a5807d9a.tar.gz
otp-70bb14fe3fd27e8c429bf402e364b144a5807d9a.tar.bz2
otp-70bb14fe3fd27e8c429bf402e364b144a5807d9a.zip
Add beam_ssa_dead.erl
Add beam_ssa_dead to perform the main optimizations done by beam_dead: * Shortcut branches that jump to another block with a branch. If it can be seen that the second branch will always branch to a specific block, replace the target of the first branch. * Combined nested sequences of '=:=' tests and switch instructions operating on the same variable to a single switch. Diffing the compiler output, it seems that beam_ssa_dead finds many more opportunities for optimizations than beam_dead, although it does not find all opportunities that beam_dead does. In total, beam_ssa_dead is such improvement over beam_dead that there is no reason to keep beam_dead as well as beam_ssa_dead. Note that beam_ssa_dead does not attempt to optimize away redundant bs_context_binary instructions, because that instruction will be superseded by new instructions in the near future.
Diffstat (limited to 'lib/compiler/src/cerl_sets.erl')
0 files changed, 0 insertions, 0 deletions