diff options
Diffstat (limited to 'src/passes/SimplifyGlobals.cpp')
-rw-r--r-- | src/passes/SimplifyGlobals.cpp | 27 |
1 files changed, 23 insertions, 4 deletions
diff --git a/src/passes/SimplifyGlobals.cpp b/src/passes/SimplifyGlobals.cpp index f9bccab23..97e91bbab 100644 --- a/src/passes/SimplifyGlobals.cpp +++ b/src/passes/SimplifyGlobals.cpp @@ -328,6 +328,10 @@ struct ConstantGlobalApplier : public WalkerPass< LinearExecutionWalker<ConstantGlobalApplier, UnifiedExpressionVisitor<ConstantGlobalApplier>>> { + using super = WalkerPass< + LinearExecutionWalker<ConstantGlobalApplier, + UnifiedExpressionVisitor<ConstantGlobalApplier>>>; + bool isFunctionParallel() override { return true; } ConstantGlobalApplier(NameSet* constantGlobals, bool optimize) @@ -337,6 +341,16 @@ struct ConstantGlobalApplier return std::make_unique<ConstantGlobalApplier>(constantGlobals, optimize); } + bool refinalize = false; + + void replaceCurrent(Expression* rep) { + if (rep->type != getCurrent()->type) { + // This operation will change the type, so refinalize. + refinalize = true; + } + super::replaceCurrent(rep); + } + void visitExpression(Expression* curr) { if (auto* set = curr->dynCast<GlobalSet>()) { if (Properties::isConstantExpression(set->value)) { @@ -386,10 +400,15 @@ struct ConstantGlobalApplier } void visitFunction(Function* curr) { - if (replaced && optimize) { - PassRunner runner(getPassRunner()); - runner.addDefaultFunctionOptimizationPasses(); - runner.runOnFunction(curr); + if (replaced) { + if (refinalize) { + ReFinalize().walkFunctionInModule(curr, this->getModule()); + } + if (optimize) { + PassRunner runner(getPassRunner()); + runner.addDefaultFunctionOptimizationPasses(); + runner.runOnFunction(curr); + } } } |