summaryrefslogtreecommitdiff
path: root/src/passes/RemoveUnusedBrs.cpp
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2016-06-11 19:21:48 -0700
committerGitHub <noreply@github.com>2016-06-11 19:21:48 -0700
commit24fa19071d309c59eee5c2bd966139eaab45b5ba (patch)
tree97ce18d123b666e4650728d1538cb990c3e877a3 /src/passes/RemoveUnusedBrs.cpp
parent996262dcdb88388717aab72bd8f37841aaabb24c (diff)
parent9a4007e0ba7a77e1eed742278cd24a3914daae30 (diff)
downloadbinaryen-24fa19071d309c59eee5c2bd966139eaab45b5ba.tar.gz
binaryen-24fa19071d309c59eee5c2bd966139eaab45b5ba.tar.bz2
binaryen-24fa19071d309c59eee5c2bd966139eaab45b5ba.zip
Merge pull request #583 from WebAssembly/br-more
Fix and improve br optimizations
Diffstat (limited to 'src/passes/RemoveUnusedBrs.cpp')
-rw-r--r--src/passes/RemoveUnusedBrs.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/passes/RemoveUnusedBrs.cpp b/src/passes/RemoveUnusedBrs.cpp
index ffdba0768..3f909c32e 100644
--- a/src/passes/RemoveUnusedBrs.cpp
+++ b/src/passes/RemoveUnusedBrs.cpp
@@ -128,6 +128,13 @@ struct RemoveUnusedBrs : public WalkerPass<PostWalker<RemoveUnusedBrs, Visitor<R
// if without an else. try to reduce if (condition) br => br_if (condition)
Break* br = curr->ifTrue->dynCast<Break>();
if (br && !br->condition) { // TODO: if there is a condition, join them
+ // if the br has a value, then if => br_if means we always execute the value, and also the order is value,condition vs condition,value
+ if (br->value) {
+ EffectAnalyzer value(br->value);
+ if (value.hasSideEffects()) return;
+ EffectAnalyzer condition(curr->condition);
+ if (condition.invalidates(value)) return;
+ }
br->condition = curr->condition;
replaceCurrent(br);
anotherCycle = true;