diff options
author | Alon Zakai <azakai@google.com> | 2024-01-18 11:08:56 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-18 19:08:56 +0000 |
commit | 3049fb83c3f9c17e78157c43b5592055732db8ff (patch) | |
tree | 2a511c97e7153d978eea8b5dcf6b564b30651d3d /src | |
parent | 823bf60c7eb78cd345e1f29fd1fff186194655d8 (diff) | |
download | binaryen-3049fb83c3f9c17e78157c43b5592055732db8ff.tar.gz binaryen-3049fb83c3f9c17e78157c43b5592055732db8ff.tar.bz2 binaryen-3049fb83c3f9c17e78157c43b5592055732db8ff.zip |
SimplifyGlobals: Apply constant globals to segment offsets (#6226)
We already applied such globals to other globals, but can do the same to offsets
of data and element segments.
Suggested in #6220
Diffstat (limited to 'src')
-rw-r--r-- | src/passes/SimplifyGlobals.cpp | 40 |
1 files changed, 32 insertions, 8 deletions
diff --git a/src/passes/SimplifyGlobals.cpp b/src/passes/SimplifyGlobals.cpp index 0e66b5926..3baec4409 100644 --- a/src/passes/SimplifyGlobals.cpp +++ b/src/passes/SimplifyGlobals.cpp @@ -646,23 +646,47 @@ struct SimplifyGlobals : public Pass { // since we do know the value during startup, it can't be modified until // code runs. void propagateConstantsToGlobals() { - // Go over the list of globals in order, which is the order of - // initialization as well, tracking their constant values. + Builder builder(*module); + + // We will note constant globals here as we compute them. std::map<Name, Literals> constantGlobals; + + // Given an init expression (something like the init of a global or a + // segment), see if it is a simple global.get of a constant that we can + // apply. + auto applyGlobals = [&](Expression*& init) { + if (!init) { + // This is the init of a passive segment, which is null. + return; + } + if (auto* get = init->dynCast<GlobalGet>()) { + auto iter = constantGlobals.find(get->name); + if (iter != constantGlobals.end()) { + init = builder.makeConstantExpression(iter->second); + } + } + }; + + // Go over the list of globals first, and note their constant values as we + // go, as well as applying them where possible. for (auto& global : module->globals) { if (!global->imported()) { if (Properties::isConstantExpression(global->init)) { constantGlobals[global->name] = getLiteralsFromConstExpression(global->init); - } else if (auto* get = global->init->dynCast<GlobalGet>()) { - auto iter = constantGlobals.find(get->name); - if (iter != constantGlobals.end()) { - Builder builder(*module); - global->init = builder.makeConstantExpression(iter->second); - } + } else { + applyGlobals(global->init); } } } + + // Go over other things with inits and apply globals there. + for (auto& elementSegment : module->elementSegments) { + applyGlobals(elementSegment->offset); + } + for (auto& dataSegment : module->dataSegments) { + applyGlobals(dataSegment->offset); + } } // Constant propagation part 2: apply the values of immutable globals |