summaryrefslogtreecommitdiff
path: root/src/passes/LoopInvariantCodeMotion.cpp
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2023-07-26 13:35:18 -0700
committerGitHub <noreply@github.com>2023-07-26 13:35:18 -0700
commit2f879c0c3089e54472860a23a27985ac687d375d (patch)
tree8e63776f5b186eb2b53247eaf9e4e8ff1f3c402f /src/passes/LoopInvariantCodeMotion.cpp
parent3ed34d275709acddb0e4ce7c4fa9ef7c6bb22f92 (diff)
downloadbinaryen-2f879c0c3089e54472860a23a27985ac687d375d.tar.gz
binaryen-2f879c0c3089e54472860a23a27985ac687d375d.tar.bz2
binaryen-2f879c0c3089e54472860a23a27985ac687d375d.zip
End the current basic block on a Call (#5823)
Before this PR, if a call had no paths to a catch in the same function then we skipped creating a new basic block right after it. As a result, we could have a call in the middle of a basic block. If EH is enabled that means we might transfer control flow out of the function from the middle of a block. But it is better to have the property that any transfer of control flow - to another basic block, or outside of the function - can only happen at the end of a basic block. This causes some overhead, but a subsequent PR (#5838) will remove that as a followup, and this PR adds a little code to pass the module and check if EH is enabled, and avoid the overhead if not, which at least avoids regressing the non-EH case until that followup lands.
Diffstat (limited to 'src/passes/LoopInvariantCodeMotion.cpp')
-rw-r--r--src/passes/LoopInvariantCodeMotion.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/passes/LoopInvariantCodeMotion.cpp b/src/passes/LoopInvariantCodeMotion.cpp
index 1329c02a1..4239e39c3 100644
--- a/src/passes/LoopInvariantCodeMotion.cpp
+++ b/src/passes/LoopInvariantCodeMotion.cpp
@@ -49,7 +49,7 @@ struct LoopInvariantCodeMotion
void doWalkFunction(Function* func) {
// Compute all local dependencies first.
- LocalGraph localGraphInstance(func);
+ LocalGraph localGraphInstance(func, getModule());
localGraph = &localGraphInstance;
// Traverse the function.
super::doWalkFunction(func);