From 530e2cc616e64413576e2c3c49f5ea930bd4c961 Mon Sep 17 00:00:00 2001 From: Vedant Paranjape <22630228+VedantParanjape@users.noreply.github.com> Date: Sat, 30 Sep 2023 20:46:10 +0530 Subject: [PATCH] Improved handling of unconditional loops --- src/blocks/loops.cpp | 34 ++++++++++++++++++++-------------- 1 file changed, 20 insertions(+), 14 deletions(-) diff --git a/src/blocks/loops.cpp b/src/blocks/loops.cpp index 7294ed3..736ced0 100644 --- a/src/blocks/loops.cpp +++ b/src/blocks/loops.cpp @@ -152,17 +152,6 @@ void loop_info::analyze() { } } - // Populate loop condition block - for(auto loop: loops) { - if (!loop->header_block) - continue; - - std::shared_ptr header = loop->header_block; - assert(header->successor.size() == 1 && "loop header cannot have more than one successor"); - if (isa(header->successor[0]->parent)) - loop->condition_block = header->successor[0]; - } - // Populate the loop exits for (auto loop: loops) { if (!loop->header_block) @@ -198,6 +187,22 @@ void loop_info::analyze() { loop->unique_exit_block = dta.cfg_[unique_postdom]; } + // Populate loop condition block + for(auto loop: loops) { + if (!loop->header_block) + continue; + + // this might be an unconditional loop or + // infinite loop. + if (loop->loop_exit_blocks.empty()) + continue; + + std::shared_ptr header = loop->header_block; + assert(header->successor.size() == 1 && "loop header cannot have more than one successor"); + if (isa(header->successor[0]->parent)) + loop->condition_block = header->successor[0]; + } + // Assign id to the loops for (unsigned int i = 0; i < loops.size(); i++) { loops[i]->loop_id = i; @@ -297,7 +302,7 @@ stmt::Ptr loop::convert_to_ast_impl(dominator_analysis &dta_, std::vectorsuccessor[1], nullptr}); visited.insert(bb->successor[1]); } - else { + else if (blocks_id_map.count(bb->successor[1]->id) && !blocks_id_map.count(bb->successor[0]->id)){ std::cerr << "inserting out of loop block (0): " << bb->successor[0]->id << bb->successor[0]->is_exit_block << "\n"; worklist.push_back({bb->successor[0], nullptr}); visited.insert(bb->successor[0]); @@ -316,7 +321,8 @@ stmt::Ptr loop::convert_to_ast_impl(dominator_analysis &dta_, std::vectorsuccessor[1]); // } } - else if (bb->else_branch && blocks_id_map.count(bb->else_branch->id)) { + + if (bb->else_branch && blocks_id_map.count(bb->else_branch->id)) { not_expr::Ptr negated_cond = std::make_shared(); negated_cond->static_offset = while_block->cond->static_offset; negated_cond->expr1 = while_block->cond; @@ -340,7 +346,7 @@ stmt::Ptr loop::convert_to_ast_impl(dominator_analysis &dta_, std::vectorsuccessor[0], ast_parent_map_loop[to(while_block->body)]}); visited.insert(bb->successor[0]); } - else { + else if (!blocks_id_map.count(bb->successor[1]->id) && blocks_id_map.count(bb->successor[0]->id)) { std::cerr << "inserting out of loop block (1): " << bb->successor[1]->id << bb->successor[1]->is_exit_block << "\n"; worklist.push_back({bb->successor[1], nullptr}); visited.insert(bb->successor[1]);