diff options
author | Vladimir Marko <vmarko@google.com> | 2014-09-30 18:09:14 +0100 |
---|---|---|
committer | Vladimir Marko <vmarko@google.com> | 2014-10-17 15:16:08 +0100 |
commit | 415ac88a6471792a28cf2b457fe4ba9dc099396e (patch) | |
tree | 1a83ac3a5f224568af19fc4bf148d352a1a4e49c /compiler/dex/local_value_numbering.cc | |
parent | 02e7d4e802248574cee7224fea3352b6e558e4ee (diff) | |
download | art-415ac88a6471792a28cf2b457fe4ba9dc099396e.zip art-415ac88a6471792a28cf2b457fe4ba9dc099396e.tar.gz art-415ac88a6471792a28cf2b457fe4ba9dc099396e.tar.bz2 |
Quick: In GVN, apply modifications early if outside loop.
To improve GVN performance, apply modifications to blocks
outside loops during the initial convergence phase. During
the post processing phase, apply modifications only to the
blocks belonging to loops.
Also clean up the check whether to run the LVN and add the
capability to limit the maximum number of nested loops we
allow the GVN to process.
Change-Id: Ie7f1254f91a442397c06a325d5d314d8f58e5012
Diffstat (limited to 'compiler/dex/local_value_numbering.cc')
-rw-r--r-- | compiler/dex/local_value_numbering.cc | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/compiler/dex/local_value_numbering.cc b/compiler/dex/local_value_numbering.cc index 0fb5e48..8b7ae20 100644 --- a/compiler/dex/local_value_numbering.cc +++ b/compiler/dex/local_value_numbering.cc @@ -1413,8 +1413,8 @@ uint16_t LocalValueNumbering::GetValueNumber(MIR* mir) { case Instruction::MONITOR_EXIT: HandleNullCheck(mir, GetOperandValue(mir->ssa_rep->uses[0])); // If we're running GVN and CanModify(), uneliminated null check indicates bytecode error. - if ((gvn_->GetCompilationUnit()->disable_opt & (1u << kGlobalValueNumbering)) == 0u && - gvn_->CanModify() && (mir->optimization_flags & MIR_IGNORE_NULL_CHECK) == 0) { + if ((mir->optimization_flags & MIR_IGNORE_NULL_CHECK) == 0 && + gvn_->work_lvn_ != nullptr && gvn_->CanModify()) { LOG(WARNING) << "Bytecode error: MONITOR_EXIT is still null checked at 0x" << std::hex << mir->offset << " in " << PrettyMethod(gvn_->cu_->method_idx, *gvn_->cu_->dex_file); } |