diff options
author | Alon Zakai <azakai@google.com> | 2023-07-26 13:35:18 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-07-26 13:35:18 -0700 |
commit | 2f879c0c3089e54472860a23a27985ac687d375d (patch) | |
tree | 8e63776f5b186eb2b53247eaf9e4e8ff1f3c402f /src/passes/LoopInvariantCodeMotion.cpp | |
parent | 3ed34d275709acddb0e4ce7c4fa9ef7c6bb22f92 (diff) | |
download | binaryen-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.cpp | 2 |
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); |