diff options
author | Heejin Ahn <aheejin@gmail.com> | 2022-07-25 15:16:43 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-07-25 15:16:43 -0700 |
commit | c40b402aaffa24c641cbb0e8efd0019c5c4a68b6 (patch) | |
tree | 0594369dd49ac2511c80bf440932300d9bb9b8f3 /src/ir/drop.h | |
parent | 7c2b3ebd518b26c01fda9db8cb2a1911c23bed2a (diff) | |
download | binaryen-c40b402aaffa24c641cbb0e8efd0019c5c4a68b6.tar.gz binaryen-c40b402aaffa24c641cbb0e8efd0019c5c4a68b6.tar.bz2 binaryen-c40b402aaffa24c641cbb0e8efd0019c5c4a68b6.zip |
Move method implementations to drop.cpp (#4823)
Now that we have `getDroppedUnconditionalChildrenAndAppend`, all passes
need to use it rather than the old `getDroppedChildrenAndAppend`, which
is used within the new method
`getDroppedUnconditionalChildrenAndAppend`.
This creates `drop.cpp` and move method implementations in drop.h there,
and merge two methods given that the old method is not supposed to be
used from outside anyway, and drops `Unconditional` from the new method
name because this is the only method and doesn't have to be specific
about that.
Diffstat (limited to 'src/ir/drop.h')
-rw-r--r-- | src/ir/drop.h | 91 |
1 files changed, 18 insertions, 73 deletions
diff --git a/src/ir/drop.h b/src/ir/drop.h index a13b83332..78ff98c66 100644 --- a/src/ir/drop.h +++ b/src/ir/drop.h @@ -17,52 +17,26 @@ #ifndef wasm_ir_drop_h #define wasm_ir_drop_h -#include "ir/branch-utils.h" -#include "ir/effects.h" -#include "ir/iteration.h" -#include "wasm-builder.h" #include "wasm.h" namespace wasm { +struct PassOptions; + // Given an expression, returns a new expression that drops the given -// expression's children that cannot be removed outright due to their side -// effects. This is useful if we know the node is not needed but may need to -// keep the children around; this utility will automatically remove any children -// we do not actually need to keep, based on their effects. +// expression's unconditional children that cannot be removed outright due to +// their side effects. This is useful if we know the node is not needed but may +// need to keep the children around; this utility will automatically remove any +// children we do not actually need to keep, based on their effects. // // The caller must also pass in a last item to append to the output (which is // typically what the original expression is replaced with). -inline Expression* getDroppedChildrenAndAppend(Expression* curr, - Module& wasm, - const PassOptions& options, - Expression* last) { - Builder builder(wasm); - std::vector<Expression*> contents; - for (auto* child : ChildIterator(curr)) { - if (!EffectAnalyzer(options, wasm, child).hasUnremovableSideEffects()) { - continue; - } - if (child->type.isConcrete()) { - contents.push_back(builder.makeDrop(child)); - } else { - // The child is unreachable, or none (none is possible as a child of a - // block or loop, etc.); in both cases we do not need a drop. - contents.push_back(child); - } - } - contents.push_back(last); - if (contents.size() == 1) { - return contents[0]; - } - return builder.makeBlock(contents); -} - -// As the above, but only operates on children that execute unconditionally. -// That is the case in almost all expressions, except for those with -// conditional execution, like if, which unconditionally executes the condition -// but then conditionally executes one of the two arms. The above function -// simply returns all children in order, so it does this to if: +// +// This function only operates on children that executes unconditionally. That +// is the case in almost all expressions, except for those with conditional +// execution, like if, which unconditionally executes the condition but then +// conditionally executes one of the two arms. The above function simply returns +// all children in order, so it does this to if: // // (if // (condition) @@ -96,41 +70,12 @@ inline Expression* getDroppedChildrenAndAppend(Expression* curr, // ) // (appended last item) // -// Also this function preserves other unremovable expressions like trys and -// pops. -inline Expression* -getDroppedUnconditionalChildrenAndAppend(Expression* curr, - Module& wasm, - const PassOptions& options, - Expression* last) { - // We check for shallow effects here, since we may be able to remove |curr| - // itself but keep its children around - we don't want effects in the children - // to stop us from improving the code. Note that there are cases where the - // combined curr+children has fewer effects than curr itself, such as if curr - // is a block and the child branches to it, but in such cases we cannot remove - // curr anyhow (those cases are ruled out below), so looking at non-shallow - // effects would never help us (and would be slower to run). - ShallowEffectAnalyzer effects(options, wasm, curr); - // Ignore a trap, as the unreachable replacement would trap too. - if (last->type == Type::unreachable) { - effects.trap = false; - } - - // We cannot remove - // 1. Expressions with unremovable side effects - // 2. if: 'if's contains conditional expressions - // 3. try: Removing a try could leave a pop without a proper parent - // 4. pop: Pops are struturally necessary in catch bodies - // 5. Branch targets: We will need the target for the branches to it to - // validate. - if (effects.hasUnremovableSideEffects() || curr->is<If>() || - curr->is<Try>() || curr->is<Pop>() || - BranchUtils::getDefinedName(curr).is()) { - Builder builder(wasm); - return builder.makeSequence(builder.makeDrop(curr), last); - } - return getDroppedChildrenAndAppend(curr, wasm, options, last); -} +// Also this function preserves other unremovable expressions like trys, pops, +// and named blocks. +Expression* getDroppedChildrenAndAppend(Expression* curr, + Module& wasm, + const PassOptions& options, + Expression* last); } // namespace wasm |