diff options
| author | 2015-04-26 18:23:01 +0000 | |
|---|---|---|
| committer | 2015-04-26 18:23:02 +0000 | |
| commit | f382eff130a5d90c34b3f09c4c61cb50cacd4c54 (patch) | |
| tree | 07dd1b8e0cdf5c078776d6b64aa3813a80182bb6 /compiler/optimizing/nodes.cc | |
| parent | adf15974e0a0a2b0e6dc311ff5701b87ca15964a (diff) | |
| parent | 206d6fd6cae5ba8c4d5f0e230111fe77b9d5c0a5 (diff) | |
Merge "Deoptimization-based BCE for unknown loop bounds."
Diffstat (limited to 'compiler/optimizing/nodes.cc')
| -rw-r--r-- | compiler/optimizing/nodes.cc | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/compiler/optimizing/nodes.cc b/compiler/optimizing/nodes.cc index c158ddf4ee..ca470f4988 100644 --- a/compiler/optimizing/nodes.cc +++ b/compiler/optimizing/nodes.cc @@ -498,6 +498,28 @@ void HEnvironment::CopyFrom(HEnvironment* env) {    }  } +void HEnvironment::CopyFromWithLoopPhiAdjustment(HEnvironment* env, +                                                 HBasicBlock* loop_header) { +  DCHECK(loop_header->IsLoopHeader()); +  for (size_t i = 0; i < env->Size(); i++) { +    HInstruction* instruction = env->GetInstructionAt(i); +    SetRawEnvAt(i, instruction); +    if (instruction == nullptr) { +      continue; +    } +    if (instruction->IsLoopHeaderPhi() && (instruction->GetBlock() == loop_header)) { +      // At the end of the loop pre-header, the corresponding value for instruction +      // is the first input of the phi. +      HInstruction* initial = instruction->AsPhi()->InputAt(0); +      DCHECK(initial->GetBlock()->Dominates(loop_header)); +      SetRawEnvAt(i, initial); +      initial->AddEnvUseAt(this, i); +    } else { +      instruction->AddEnvUseAt(this, i); +    } +  } +} +  void HEnvironment::RemoveAsUserOfInput(size_t index) const {    const HUserRecord<HEnvironment*> user_record = vregs_.Get(index);    user_record.GetInstruction()->RemoveEnvironmentUser(user_record.GetUseNode()); |