summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlon Zakai (kripken) <alonzakai@gmail.com>2017-07-09 20:39:12 -0700
committerAlon Zakai (kripken) <alonzakai@gmail.com>2017-07-11 10:40:17 -0700
commitee7538a3e912b20bf295cdfce81a531fafb0bb7c (patch)
treeeaad928526c4a015ff79571b0795d74e69d00734
parent812943d51bac4767c4b7f749f17c26277e27f796 (diff)
downloadbinaryen-ee7538a3e912b20bf295cdfce81a531fafb0bb7c.tar.gz
binaryen-ee7538a3e912b20bf295cdfce81a531fafb0bb7c.tar.bz2
binaryen-ee7538a3e912b20bf295cdfce81a531fafb0bb7c.zip
don't remove unreachable nodes in vaccuum, it can alter types, and dce does that anyhow, let it do it's thing
-rw-r--r--src/passes/Vacuum.cpp2
-rw-r--r--test/passes/vacuum.txt29
-rw-r--r--test/passes/vacuum.wast11
3 files changed, 39 insertions, 3 deletions
diff --git a/src/passes/Vacuum.cpp b/src/passes/Vacuum.cpp
index 4e47ad9a3..64c7f276a 100644
--- a/src/passes/Vacuum.cpp
+++ b/src/passes/Vacuum.cpp
@@ -49,6 +49,8 @@ struct Vacuum : public WalkerPass<PostWalker<Vacuum>> {
// returns nullptr if curr is dead, curr if it must stay as is, or another node if it can be replaced
Expression* optimize(Expression* curr, bool resultUsed) {
+ // an unreachable node must not be changed
+ if (curr->type == unreachable) return curr;
while (1) {
switch (curr->_id) {
case Expression::Id::NopId: return nullptr; // never needed
diff --git a/test/passes/vacuum.txt b/test/passes/vacuum.txt
index d1a388333..ec6e3ad44 100644
--- a/test/passes/vacuum.txt
+++ b/test/passes/vacuum.txt
@@ -28,16 +28,25 @@
(nop)
)
(func $unary (type $2) (result f32)
- (unreachable)
+ (f32.abs
+ (unreachable)
+ )
)
(func $binary (type $2) (result f32)
(drop
- (unreachable)
+ (f32.add
+ (unreachable)
+ (f32.const 3)
+ )
)
)
(func $select (type $3) (result i32)
(drop
- (unreachable)
+ (select
+ (unreachable)
+ (i32.const 4)
+ (i32.const 5)
+ )
)
)
(func $block-to-one (type $0)
@@ -198,4 +207,18 @@
(local $2 i32)
(nop)
)
+ (func $a (type $0)
+ (block $block
+ (i32.store
+ (i32.const 1)
+ (i32.const 2)
+ )
+ (f64.div
+ (f64.const -nan:0xfffffffffa361)
+ (loop $label$1
+ (br $label$1)
+ )
+ )
+ )
+ )
)
diff --git a/test/passes/vacuum.wast b/test/passes/vacuum.wast
index c1a84d646..20bbfe625 100644
--- a/test/passes/vacuum.wast
+++ b/test/passes/vacuum.wast
@@ -509,4 +509,15 @@
)
)
)
+ (func $a
+ (block
+ (i32.store (i32.const 1) (i32.const 2))
+ (f64.div
+ (f64.const -nan:0xfffffffffa361)
+ (loop $label$1 ;; unreachable, so the div is too. keep
+ (br $label$1)
+ )
+ )
+ )
+ )
)