Optimization: Do not assign an environment to LBranch when are sure that we will never deopt later.
Review URL: http://codereview.chromium.org/7524025 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@8760 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
d9c2e28a32
commit
3ce397f975
@ -1042,9 +1042,15 @@ LInstruction* LChunkBuilder::DoBranch(HBranch* instr) {
|
|||||||
return new LGoto(successor->block_id());
|
return new LGoto(successor->block_id());
|
||||||
}
|
}
|
||||||
ToBooleanStub::Types expected = instr->expected_input_types();
|
ToBooleanStub::Types expected = instr->expected_input_types();
|
||||||
|
// We need a temporary register when we have to access the map *or* we have
|
||||||
|
// no type info yet, in which case we handle all cases (including the ones
|
||||||
|
// involving maps).
|
||||||
bool needs_temp = expected.NeedsMap() || expected.IsEmpty();
|
bool needs_temp = expected.NeedsMap() || expected.IsEmpty();
|
||||||
LOperand* temp = needs_temp ? TempRegister() : NULL;
|
LOperand* temp = needs_temp ? TempRegister() : NULL;
|
||||||
return AssignEnvironment(new LBranch(UseRegister(v), temp));
|
LInstruction* branch = new LBranch(UseRegister(v), temp);
|
||||||
|
// When we handle all cases, we never deopt, so we don't need to assign the
|
||||||
|
// environment then.
|
||||||
|
return expected.IsAll() ? branch : AssignEnvironment(branch);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user