Fix variable decl scope issue in DeadCodeEliminator

FoorLoopInitRewriter needs to be run before DeadCodeEliminator.
This commit is contained in:
mingchuan 2019-04-09 17:11:38 +08:00
parent ef3a18999c
commit d49733dfc3
No known key found for this signature in database
GPG Key ID: 607CD25FA2D03651
10 changed files with 24 additions and 7 deletions

View File

@ -38,6 +38,10 @@ namespace yul
* Function definitions are retained as they might be called by earlier * Function definitions are retained as they might be called by earlier
* code and thus are considered reachable. * code and thus are considered reachable.
* *
* Because variables declared in a for loop's init block have their scope extended to the loop body,
* we require ForLoopInitRewriter to run before this step.
*
* Prerequisite: ForLoopInitRewriter
*/ */
class DeadCodeEliminator: public ASTModifier class DeadCodeEliminator: public ASTModifier
{ {

View File

@ -71,11 +71,11 @@ void OptimiserSuite::run(
VarDeclInitializer{}(ast); VarDeclInitializer{}(ast);
FunctionHoister{}(ast); FunctionHoister{}(ast);
BlockFlattener{}(ast); BlockFlattener{}(ast);
ForLoopInitRewriter{}(ast);
DeadCodeEliminator{}(ast); DeadCodeEliminator{}(ast);
FunctionGrouper{}(ast); FunctionGrouper{}(ast);
EquivalentFunctionCombiner::run(ast); EquivalentFunctionCombiner::run(ast);
UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers); UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers);
ForLoopInitRewriter{}(ast);
BlockFlattener{}(ast); BlockFlattener{}(ast);
StructuralSimplifier{*_dialect}(ast); StructuralSimplifier{*_dialect}(ast);
BlockFlattener{}(ast); BlockFlattener{}(ast);

View File

@ -207,6 +207,7 @@ bool YulOptimizerTest::run(ostream& _stream, string const& _linePrefix, bool con
else if (m_optimizerStep == "deadCodeEliminator") else if (m_optimizerStep == "deadCodeEliminator")
{ {
disambiguate(); disambiguate();
ForLoopInitRewriter{}(*m_ast);
DeadCodeEliminator{}(*m_ast); DeadCodeEliminator{}(*m_ast);
} }
else if (m_optimizerStep == "ssaTransform") else if (m_optimizerStep == "ssaTransform")

View File

@ -17,8 +17,8 @@
// step: deadCodeEliminator // step: deadCodeEliminator
// ---- // ----
// { // {
// for {
// let a := 20 // let a := 20
// for {
// } // }
// lt(a, 40) // lt(a, 40)
// { // {

View File

@ -18,8 +18,8 @@
// step: deadCodeEliminator // step: deadCodeEliminator
// ---- // ----
// { // {
// for {
// let a := 20 // let a := 20
// for {
// } // }
// lt(a, 40) // lt(a, 40)
// { // {

View File

@ -18,8 +18,8 @@
// step: deadCodeEliminator // step: deadCodeEliminator
// ---- // ----
// { // {
// for {
// let a := 20 // let a := 20
// for {
// } // }
// lt(a, 40) // lt(a, 40)
// { // {

View File

@ -0,0 +1,12 @@
{
for { stop() let i_0 := 0 } lt(i_0,2) { i_0 := add(i_0,1) }
{
let i_1 := i_0
}
}
// ====
// step: deadCodeEliminator
// ----
// {
// stop()
// }

View File

@ -16,8 +16,8 @@
// step: deadCodeEliminator // step: deadCodeEliminator
// ---- // ----
// { // {
// for {
// let a := 20 // let a := 20
// for {
// } // }
// lt(a, 40) // lt(a, 40)
// { // {

View File

@ -16,8 +16,8 @@
// step: deadCodeEliminator // step: deadCodeEliminator
// ---- // ----
// { // {
// for {
// let a := 20 // let a := 20
// for {
// } // }
// lt(a, 40) // lt(a, 40)
// { // {

View File

@ -20,8 +20,8 @@
// ---- // ----
// { // {
// let b := 20 // let b := 20
// for {
// let a := 20 // let a := 20
// for {
// } // }
// lt(a, 40) // lt(a, 40)
// { // {