summaryrefslogtreecommitdiff
path: root/src/passes/MergeBlocks.cpp
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2016-11-25 17:13:24 -0800
committerGitHub <noreply@github.com>2016-11-25 17:13:24 -0800
commit3da6038303d25ffa2599971c94967a86a2300886 (patch)
tree1bcb3030275ccf4be424e0c87707a53310aeb39c /src/passes/MergeBlocks.cpp
parentd9e318c9d8228212ea83cf3baad38db88852ff1a (diff)
downloadbinaryen-3da6038303d25ffa2599971c94967a86a2300886.tar.gz
binaryen-3da6038303d25ffa2599971c94967a86a2300886.tar.bz2
binaryen-3da6038303d25ffa2599971c94967a86a2300886.zip
fix a reordering bug in merge-blocks (#846)
Diffstat (limited to 'src/passes/MergeBlocks.cpp')
-rw-r--r--src/passes/MergeBlocks.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/passes/MergeBlocks.cpp b/src/passes/MergeBlocks.cpp
index 95d680ec7..467ffb4ed 100644
--- a/src/passes/MergeBlocks.cpp
+++ b/src/passes/MergeBlocks.cpp
@@ -214,8 +214,12 @@ struct MergeBlocks : public WalkerPass<PostWalker<MergeBlocks, Visitor<MergeBloc
Block* optimize(Expression* curr, Expression*& child, Block* outer = nullptr, Expression** dependency1 = nullptr, Expression** dependency2 = nullptr) {
if (!child) return outer;
- if (dependency1 && *dependency1 && EffectAnalyzer(*dependency1).hasSideEffects()) return outer;
- if (dependency2 && *dependency2 && EffectAnalyzer(*dependency2).hasSideEffects()) return outer;
+ if ((dependency1 && *dependency1) || (dependency2 && *dependency2)) {
+ // there are dependencies, things we must be reordered through. make sure no problems there
+ EffectAnalyzer childEffects(child);
+ if (dependency1 && *dependency1 && EffectAnalyzer(*dependency1).invalidates(childEffects)) return outer;
+ if (dependency2 && *dependency2 && EffectAnalyzer(*dependency2).invalidates(childEffects)) return outer;
+ }
if (auto* block = child->dynCast<Block>()) {
if (!block->name.is() && block->list.size() >= 2) {
child = block->list.back();