diff options
Diffstat (limited to 'compiler/optimizing')
| -rw-r--r-- | compiler/optimizing/inliner.cc | 7 | ||||
| -rw-r--r-- | compiler/optimizing/nodes.cc | 3 | 
2 files changed, 10 insertions, 0 deletions
| diff --git a/compiler/optimizing/inliner.cc b/compiler/optimizing/inliner.cc index e3926c58c4..0b96005a17 100644 --- a/compiler/optimizing/inliner.cc +++ b/compiler/optimizing/inliner.cc @@ -1380,6 +1380,13 @@ bool HInliner::TryBuildAndInlineHelper(HInvoke* invoke_instruction,                         << " could not be inlined because one branch always throws and"                         << " caller does not have an exit block";          return false; +      } else if (graph_->HasIrreducibleLoops()) { +        // TODO(ngeoffray): Support re-computing loop information to graphs with +        // irreducible loops? +        VLOG(compiler) << "Method " << callee_dex_file.PrettyMethod(method_index) +                       << " could not be inlined because one branch always throws and" +                       << " caller has irreducible loops"; +        return false;        }      } else {        has_one_return = true; diff --git a/compiler/optimizing/nodes.cc b/compiler/optimizing/nodes.cc index 62c89100eb..020e4463d4 100644 --- a/compiler/optimizing/nodes.cc +++ b/compiler/optimizing/nodes.cc @@ -2179,6 +2179,9 @@ HInstruction* HGraph::InlineInto(HGraph* outer_graph, HInvoke* invoke) {        }      }      if (rerun_loop_analysis) { +      DCHECK(!outer_graph->HasIrreducibleLoops()) +          << "Recomputing loop information in graphs with irreducible loops " +          << "is unsupported, as it could lead to loop header changes";        outer_graph->ClearLoopInformation();        outer_graph->ClearDominanceInformation();        outer_graph->BuildDominatorTree(); |