summaryrefslogtreecommitdiff
path: root/src/passes/RedundantSetElimination.cpp
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2021-06-18 11:32:44 -0700
committerGitHub <noreply@github.com>2021-06-18 11:32:44 -0700
commite1586984480daf475d0941d6b6b5640fbec80558 (patch)
tree83683e095f51acf35ec2f2a438d04fc20adb46dc /src/passes/RedundantSetElimination.cpp
parentea0b9ee1e1083962da9bfa52fa09870fcc4f72bb (diff)
downloadbinaryen-e1586984480daf475d0941d6b6b5640fbec80558.tar.gz
binaryen-e1586984480daf475d0941d6b6b5640fbec80558.tar.bz2
binaryen-e1586984480daf475d0941d6b6b5640fbec80558.zip
[Wasm GC] Fix RSE on non-nullable locals (#3943)
RedundantSetElimination checks if a local already has the default value when we assign the default to it. For a non-nullable local, however, there is no initial value - it cannot be used before it is assigned to. So we just need to skip such locals, and not assume they contain a default value we can compare against (we would assert on trying to create a "zero" for such a non-nullable type). Fixes #3942
Diffstat (limited to 'src/passes/RedundantSetElimination.cpp')
-rw-r--r--src/passes/RedundantSetElimination.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/passes/RedundantSetElimination.cpp b/src/passes/RedundantSetElimination.cpp
index 8b0914ecf..ccf6e6ac2 100644
--- a/src/passes/RedundantSetElimination.cpp
+++ b/src/passes/RedundantSetElimination.cpp
@@ -184,14 +184,19 @@ struct RedundantSetElimination
if (block.get() == entry) {
// params are complex values we can't optimize; vars are zeros
for (Index i = 0; i < numLocals; i++) {
+ auto type = func->getLocalType(i);
if (func->isParam(i)) {
#ifdef RSE_DEBUG
std::cout << "new param value for " << i << '\n';
#endif
start[i] = getUniqueValue();
+ } else if (type.isRef() && !type.isNullable()) {
+#ifdef RSE_DEBUG
+ std::cout << "new unique value for non-nullable " << i << '\n';
+#endif
+ start[i] = getUniqueValue();
} else {
- start[i] =
- getLiteralValue(Literal::makeZeros(func->getLocalType(i)));
+ start[i] = getLiteralValue(Literal::makeZeros(type));
}
}
} else {