diff options
author | 2018-04-17 19:14:36 +0000 | |
---|---|---|
committer | 2018-04-17 19:14:36 +0000 | |
commit | 8f669504a1c4646501a2cf5d090597f9fed59f70 (patch) | |
tree | 763f65382b960cc867074ef78f0e63ca98c19569 /compiler/optimizing/superblock_cloner.cc | |
parent | 596f6b118acde4be2ff8042d126b70c27d84d8d6 (diff) | |
parent | 72411e6b3b286d91e4da894cd5b12e7a3dc88f40 (diff) |
Merge "ART: Implement scalar loop peeling."
Diffstat (limited to 'compiler/optimizing/superblock_cloner.cc')
-rw-r--r-- | compiler/optimizing/superblock_cloner.cc | 21 |
1 files changed, 9 insertions, 12 deletions
diff --git a/compiler/optimizing/superblock_cloner.cc b/compiler/optimizing/superblock_cloner.cc index ee74f1001f..fad7729956 100644 --- a/compiler/optimizing/superblock_cloner.cc +++ b/compiler/optimizing/superblock_cloner.cc @@ -28,11 +28,6 @@ using HInstructionMap = SuperblockCloner::HInstructionMap; using HBasicBlockSet = SuperblockCloner::HBasicBlockSet; using HEdgeSet = SuperblockCloner::HEdgeSet; -// When doing peeling we can choose whether to keep original loop (made of original basic blocks) -// and form a peeled iteration of the copy blocks (preserve the header) or transfer original loop -// blocks to the peeled iteration and create new loop from the copy blocks. Similar for unrolling. -static const bool kPeelUnrollPreserveHeader = true; - void HEdge::Dump(std::ostream& stream) const { stream << "(" << from_ << "->" << to_ << ")"; } @@ -926,16 +921,12 @@ void CollectRemappingInfoForPeelUnroll(bool to_unroll, remap_orig_internal->Insert(e); remap_copy_internal->Insert(e); } else { - if (kPeelUnrollPreserveHeader) { - remap_copy_internal->Insert(e); - } else { - remap_orig_internal->Insert(e); - } + remap_copy_internal->Insert(e); } } // Set up remap_incoming edges set. - if (to_unroll != kPeelUnrollPreserveHeader) { + if (!to_unroll) { remap_incoming->Insert(HEdge(loop_info->GetPreHeader(), loop_header)); } } @@ -992,6 +983,9 @@ HBasicBlock* PeelUnrollHelper::DoPeelUnrollImpl(bool to_unroll) { DCHECK(!loop_info_->IsIrreducible()); HBasicBlock* loop_header = loop_info_->GetHeader(); + // Check that loop info is up-to-date. + DCHECK(loop_info_ == loop_header->GetLoopInformation()); + HGraph* graph = loop_header->GetGraph(); ArenaAllocator allocator(graph->GetAllocator()->GetArenaPool()); @@ -1009,7 +1003,10 @@ HBasicBlock* PeelUnrollHelper::DoPeelUnrollImpl(bool to_unroll) { cloner_.Run(); cloner_.CleanUp(); - return kPeelUnrollPreserveHeader ? loop_header : cloner_.GetBlockCopy(loop_header); + // Check that loop info is preserved. + DCHECK(loop_info_ == loop_header->GetLoopInformation()); + + return loop_header; } PeelUnrollSimpleHelper::PeelUnrollSimpleHelper(HLoopInformation* info) |