summaryrefslogtreecommitdiff
path: root/src/passes/OptimizeInstructions.cpp
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2024-05-14 10:10:54 -0700
committerGitHub <noreply@github.com>2024-05-14 10:10:54 -0700
commit4ca05f765ca6ec99b7582d357520ca217265677d (patch)
treeacedda233346f51d2314d93748209bce60f25f1e /src/passes/OptimizeInstructions.cpp
parent020d08e01ff506099c8293e69cd03f5f75f562d9 (diff)
downloadbinaryen-4ca05f765ca6ec99b7582d357520ca217265677d.tar.gz
binaryen-4ca05f765ca6ec99b7582d357520ca217265677d.tar.bz2
binaryen-4ca05f765ca6ec99b7582d357520ca217265677d.zip
LocalCSE: Check effects/generativity early (#6587)
Previously we checked late, and as a result might end up failing to optimize when a sub-pattern could have worked. E.g. (call (A) ) (call (A) ) The call cannot be optimized, but the A pattern repeats. Before this PR we'd greedily focus on the entire call and then fail. After this PR we skip the call before we commit to which patterns to try to optimize, so we succeed. Add a isShallowlyGenerative helper here as we compute this step by step as we go. Also remove a parameter to the generativity code (it did not use the features it was passed).
Diffstat (limited to 'src/passes/OptimizeInstructions.cpp')
-rw-r--r--src/passes/OptimizeInstructions.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/passes/OptimizeInstructions.cpp b/src/passes/OptimizeInstructions.cpp
index 3486fe82a..1a474be2c 100644
--- a/src/passes/OptimizeInstructions.cpp
+++ b/src/passes/OptimizeInstructions.cpp
@@ -2508,7 +2508,7 @@ private:
// To be equal, they must also be known to return the same result
// deterministically.
- return !Properties::isGenerative(left, getModule()->features);
+ return !Properties::isGenerative(left);
}
// Similar to areConsecutiveInputsEqual() but also checks if we can remove