summaryrefslogtreecommitdiff
path: root/src/passes/SimplifyGlobals.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/passes/SimplifyGlobals.cpp')
-rw-r--r--src/passes/SimplifyGlobals.cpp27
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);
+ }
}
}