X87: Simplify known successor block lowering.
Port r21589 (a9f3228) BUG= R=danno@chromium.org Review URL: https://codereview.chromium.org/309043002 git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@21611 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
e4215c6a54
commit
5cb7e512ec
@ -868,7 +868,14 @@ void LChunkBuilder::VisitInstruction(HInstruction* current) {
|
|||||||
chunk_->AddInstruction(dummy, current_block_);
|
chunk_->AddInstruction(dummy, current_block_);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
instr = current->CompileToLithium(this);
|
HBasicBlock* successor;
|
||||||
|
if (current->IsControlInstruction() &&
|
||||||
|
HControlInstruction::cast(current)->KnownSuccessorBlock(&successor) &&
|
||||||
|
successor != NULL) {
|
||||||
|
instr = new(zone()) LGoto(successor);
|
||||||
|
} else {
|
||||||
|
instr = current->CompileToLithium(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
argument_count_ += current->argument_delta();
|
argument_count_ += current->argument_delta();
|
||||||
@ -963,9 +970,6 @@ LInstruction* LChunkBuilder::DoGoto(HGoto* instr) {
|
|||||||
|
|
||||||
|
|
||||||
LInstruction* LChunkBuilder::DoBranch(HBranch* instr) {
|
LInstruction* LChunkBuilder::DoBranch(HBranch* instr) {
|
||||||
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
|
||||||
if (goto_instr != NULL) return goto_instr;
|
|
||||||
|
|
||||||
HValue* value = instr->value();
|
HValue* value = instr->value();
|
||||||
Representation r = value->representation();
|
Representation r = value->representation();
|
||||||
HType type = value->type();
|
HType type = value->type();
|
||||||
@ -991,9 +995,6 @@ LInstruction* LChunkBuilder::DoDebugBreak(HDebugBreak* instr) {
|
|||||||
|
|
||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareMap(HCompareMap* instr) {
|
LInstruction* LChunkBuilder::DoCompareMap(HCompareMap* instr) {
|
||||||
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
|
||||||
if (goto_instr != NULL) return goto_instr;
|
|
||||||
|
|
||||||
ASSERT(instr->value()->representation().IsTagged());
|
ASSERT(instr->value()->representation().IsTagged());
|
||||||
LOperand* value = UseRegisterAtStart(instr->value());
|
LOperand* value = UseRegisterAtStart(instr->value());
|
||||||
return new(zone()) LCmpMapAndBranch(value);
|
return new(zone()) LCmpMapAndBranch(value);
|
||||||
@ -1630,8 +1631,6 @@ LInstruction* LChunkBuilder::DoCompareGeneric(HCompareGeneric* instr) {
|
|||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
||||||
HCompareNumericAndBranch* instr) {
|
HCompareNumericAndBranch* instr) {
|
||||||
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
|
||||||
if (goto_instr != NULL) return goto_instr;
|
|
||||||
Representation r = instr->representation();
|
Representation r = instr->representation();
|
||||||
if (r.IsSmiOrInteger32()) {
|
if (r.IsSmiOrInteger32()) {
|
||||||
ASSERT(instr->left()->representation().Equals(r));
|
ASSERT(instr->left()->representation().Equals(r));
|
||||||
@ -1662,8 +1661,6 @@ LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
|||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareObjectEqAndBranch(
|
LInstruction* LChunkBuilder::DoCompareObjectEqAndBranch(
|
||||||
HCompareObjectEqAndBranch* instr) {
|
HCompareObjectEqAndBranch* instr) {
|
||||||
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
|
||||||
if (goto_instr != NULL) return goto_instr;
|
|
||||||
LOperand* left = UseRegisterAtStart(instr->left());
|
LOperand* left = UseRegisterAtStart(instr->left());
|
||||||
LOperand* right = UseOrConstantAtStart(instr->right());
|
LOperand* right = UseOrConstantAtStart(instr->right());
|
||||||
return new(zone()) LCmpObjectEqAndBranch(left, right);
|
return new(zone()) LCmpObjectEqAndBranch(left, right);
|
||||||
@ -1679,8 +1676,6 @@ LInstruction* LChunkBuilder::DoCompareHoleAndBranch(
|
|||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareMinusZeroAndBranch(
|
LInstruction* LChunkBuilder::DoCompareMinusZeroAndBranch(
|
||||||
HCompareMinusZeroAndBranch* instr) {
|
HCompareMinusZeroAndBranch* instr) {
|
||||||
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
|
||||||
if (goto_instr != NULL) return goto_instr;
|
|
||||||
LOperand* value = UseRegister(instr->value());
|
LOperand* value = UseRegister(instr->value());
|
||||||
LOperand* scratch = TempRegister();
|
LOperand* scratch = TempRegister();
|
||||||
return new(zone()) LCompareMinusZeroAndBranch(value, scratch);
|
return new(zone()) LCompareMinusZeroAndBranch(value, scratch);
|
||||||
@ -2545,8 +2540,6 @@ LInstruction* LChunkBuilder::DoTypeof(HTypeof* instr) {
|
|||||||
|
|
||||||
|
|
||||||
LInstruction* LChunkBuilder::DoTypeofIsAndBranch(HTypeofIsAndBranch* instr) {
|
LInstruction* LChunkBuilder::DoTypeofIsAndBranch(HTypeofIsAndBranch* instr) {
|
||||||
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
|
||||||
if (goto_instr != NULL) return goto_instr;
|
|
||||||
return new(zone()) LTypeofIsAndBranch(UseTempRegister(instr->value()));
|
return new(zone()) LTypeofIsAndBranch(UseTempRegister(instr->value()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2704,8 +2704,6 @@ class LChunkBuilder V8_FINAL : public LChunkBuilderBase {
|
|||||||
// Build the sequence for the graph.
|
// Build the sequence for the graph.
|
||||||
LPlatformChunk* Build();
|
LPlatformChunk* Build();
|
||||||
|
|
||||||
LInstruction* CheckElideControlInstruction(HControlInstruction* instr);
|
|
||||||
|
|
||||||
// Declare methods that deal with the individual node types.
|
// Declare methods that deal with the individual node types.
|
||||||
#define DECLARE_DO(type) LInstruction* Do##type(H##type* node);
|
#define DECLARE_DO(type) LInstruction* Do##type(H##type* node);
|
||||||
HYDROGEN_CONCRETE_INSTRUCTION_LIST(DECLARE_DO)
|
HYDROGEN_CONCRETE_INSTRUCTION_LIST(DECLARE_DO)
|
||||||
|
Loading…
Reference in New Issue
Block a user