diff options
Diffstat (limited to 'compiler/optimizing')
| -rw-r--r-- | compiler/optimizing/ssa_liveness_analysis.cc | 2 | ||||
| -rw-r--r-- | compiler/optimizing/ssa_liveness_analysis.h | 8 | 
2 files changed, 8 insertions, 2 deletions
| diff --git a/compiler/optimizing/ssa_liveness_analysis.cc b/compiler/optimizing/ssa_liveness_analysis.cc index 701dbb019b..40502c173b 100644 --- a/compiler/optimizing/ssa_liveness_analysis.cc +++ b/compiler/optimizing/ssa_liveness_analysis.cc @@ -225,7 +225,7 @@ void SsaLivenessAnalysis::ComputeLiveRanges() {          // SsaLivenessAnalysis.          for (size_t i = 0, e = environment->Size(); i < e; ++i) {            HInstruction* instruction = environment->GetInstructionAt(i); -          bool should_be_live = ShouldBeLiveForEnvironment(instruction); +          bool should_be_live = ShouldBeLiveForEnvironment(current, instruction);            if (should_be_live) {              DCHECK(instruction->HasSsaIndex());              live_in->SetBit(instruction->GetSsaIndex()); diff --git a/compiler/optimizing/ssa_liveness_analysis.h b/compiler/optimizing/ssa_liveness_analysis.h index 220ee6a8d0..a7044de850 100644 --- a/compiler/optimizing/ssa_liveness_analysis.h +++ b/compiler/optimizing/ssa_liveness_analysis.h @@ -1201,8 +1201,14 @@ class SsaLivenessAnalysis : public ValueObject {    // Update the live_out set of the block and returns whether it has changed.    bool UpdateLiveOut(const HBasicBlock& block); -  static bool ShouldBeLiveForEnvironment(HInstruction* instruction) { +  // Returns whether `instruction` in an HEnvironment held by `env_holder` +  // should be kept live by the HEnvironment. +  static bool ShouldBeLiveForEnvironment(HInstruction* env_holder, +                                         HInstruction* instruction) {      if (instruction == nullptr) return false; +    // A value that's not live in compiled code may still be needed in interpreter, +    // due to code motion, etc. +    if (env_holder->IsDeoptimize()) return true;      if (instruction->GetBlock()->GetGraph()->IsDebuggable()) return true;      return instruction->GetType() == Primitive::kPrimNot;    } |