 Chromium Code Reviews
 Chromium Code Reviews Issue 165237:
  Factored out common Instruction code in the CFG builder that depends only...  (Closed) 
  Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/
    
  
    Issue 165237:
  Factored out common Instruction code in the CFG builder that depends only...  (Closed) 
  Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/| Index: src/cfg.cc | 
| =================================================================== | 
| --- src/cfg.cc (revision 2654) | 
| +++ src/cfg.cc (working copy) | 
| @@ -200,46 +200,25 @@ | 
| } | 
| -void MoveInstr::FastAllocate(TempLocation* temp) { | 
| - ASSERT(temp->where() == TempLocation::NOT_ALLOCATED); | 
| - if (temp == value()) { | 
| - temp->set_where(TempLocation::ACCUMULATOR); | 
| - } else { | 
| - temp->set_where(TempLocation::STACK); | 
| - } | 
| +void ZeroOperandInstruction::FastAllocate(TempLocation* temp) { | 
| + temp->set_where(TempLocation::STACK); | 
| } | 
| -void PropLoadInstr::FastAllocate(TempLocation* temp) { | 
| - ASSERT(temp->where() == TempLocation::NOT_ALLOCATED); | 
| - if (temp == object() || temp == key()) { | 
| - temp->set_where(TempLocation::ACCUMULATOR); | 
| - } else { | 
| - temp->set_where(TempLocation::STACK); | 
| - } | 
| +void OneOperandInstruction::FastAllocate(TempLocation* temp) { | 
| + temp->set_where((temp == value_) | 
| + ? TempLocation::ACCUMULATOR | 
| + : TempLocation::STACK); | 
| } | 
| -void BinaryOpInstr::FastAllocate(TempLocation* temp) { | 
| - ASSERT(temp->where() == TempLocation::NOT_ALLOCATED); | 
| - if (temp == left() || temp == right()) { | 
| - temp->set_where(TempLocation::ACCUMULATOR); | 
| - } else { | 
| - temp->set_where(TempLocation::STACK); | 
| - } | 
| +void TwoOperandInstruction::FastAllocate(TempLocation* temp) { | 
| + temp->set_where((temp == value0_ || temp == value1_) | 
| + ? TempLocation::ACCUMULATOR | 
| + : TempLocation::STACK); | 
| } | 
| -void ReturnInstr::FastAllocate(TempLocation* temp) { | 
| - ASSERT(temp->where() == TempLocation::NOT_ALLOCATED); | 
| - if (temp == value()) { | 
| - temp->set_where(TempLocation::ACCUMULATOR); | 
| - } else { | 
| - temp->set_where(TempLocation::STACK); | 
| - } | 
| -} | 
| - | 
| - | 
| void PositionInstr::Compile(MacroAssembler* masm) { | 
| if (FLAG_debug_info && pos_ != RelocInfo::kNoPosition) { | 
| masm->RecordStatementPosition(pos_); | 
| @@ -639,9 +618,8 @@ | 
| void Constant::Print() { | 
| - PrintF("Constant("); | 
| + PrintF("Constant "); | 
| handle_->Print(); | 
| - PrintF(")"); | 
| } | 
| @@ -651,13 +629,13 @@ | 
| void SlotLocation::Print() { | 
| - PrintF("Slot("); | 
| + PrintF("Slot "); | 
| switch (type_) { | 
| case Slot::PARAMETER: | 
| - PrintF("PARAMETER, %d)", index_); | 
| + PrintF("(PARAMETER, %d)", index_); | 
| break; | 
| case Slot::LOCAL: | 
| - PrintF("LOCAL, %d)", index_); | 
| + PrintF("(LOCAL, %d)", index_); | 
| break; | 
| default: | 
| UNREACHABLE(); | 
| @@ -666,45 +644,87 @@ | 
| void TempLocation::Print() { | 
| - PrintF("Temp(%d)", number()); | 
| + PrintF("Temp %d", number()); | 
| } | 
| -void MoveInstr::Print() { | 
| - PrintF("Move("); | 
| +void OneOperandInstruction::Print() { | 
| + PrintF("("); | 
| location()->Print(); | 
| PrintF(", "); | 
| value_->Print(); | 
| - PrintF(")\n"); | 
| + PrintF(")"); | 
| } | 
| -void PropLoadInstr::Print() { | 
| - PrintF("PropLoad("); | 
| +void TwoOperandInstruction::Print() { | 
| + PrintF("("); | 
| location()->Print(); | 
| PrintF(", "); | 
| - object()->Print(); | 
| + value0_->Print(); | 
| PrintF(", "); | 
| - key()->Print(); | 
| - PrintF(")\n"); | 
| + value1_->Print(); | 
| + PrintF(")"); | 
| } | 
| +void MoveInstr::Print() { | 
| + PrintF("Move "); | 
| + OneOperandInstruction::Print(); | 
| + PrintF("\n"); | 
| +} | 
| + | 
| + | 
| +void PropLoadInstr::Print() { | 
| + PrintF("PropLoad "); | 
| + TwoOperandInstruction::Print(); | 
| + PrintF("\n"); | 
| +} | 
| + | 
| + | 
| void BinaryOpInstr::Print() { | 
| - PrintF("BinaryOp("); | 
| - location()->Print(); | 
| - PrintF(", %s, ", Token::Name(op())); | 
| - left()->Print(); | 
| - PrintF(", "); | 
| - right()->Print(); | 
| - PrintF(")\n"); | 
| + switch (op()) { | 
| + case Token::OR: | 
| + // Two character operand. | 
| + PrintF("BinaryOp[OR] "); | 
| + break; | 
| + case Token::AND: | 
| + case Token::SHL: | 
| + case Token::SAR: | 
| + case Token::SHR: | 
| + case Token::ADD: | 
| + case Token::SUB: | 
| + case Token::MUL: | 
| + case Token::DIV: | 
| + case Token::MOD: | 
| + // Three character operands. | 
| + PrintF("BinaryOp[%s] ", Token::Name(op())); | 
| + break; | 
| + case Token::COMMA: | 
| + // Five character operand. | 
| + PrintF("BinaryOp[COMMA] "); | 
| + break; | 
| + case Token::BIT_OR: | 
| + // Six character operand. | 
| + PrintF("BinaryOp[BIT_OR] "); | 
| + break; | 
| + case Token::BIT_XOR: | 
| + case Token::BIT_AND: | 
| + // Seven character operands. | 
| + PrintF("BinaryOp[%s] ", Token::Name(op())); | 
| 
William Hesse
2009/08/10 12:47:08
If we print this on two lines, or don't print "Bin
 
Kevin Millikin (Chromium)
2009/08/10 12:59:11
Printing on two lines seems annoying.  I'd much ra
 | 
| + break; | 
| + default: | 
| + UNREACHABLE(); | 
| + } | 
| + TwoOperandInstruction::Print(); | 
| + PrintF("\n"); | 
| } | 
| void ReturnInstr::Print() { | 
| - PrintF("Return("); | 
| - value_->Print(); | 
| - PrintF(")\n"); | 
| + PrintF("Return "); | 
| + OneOperandInstruction::Print(); | 
| + PrintF("\n"); | 
| } | 
| @@ -715,7 +735,7 @@ | 
| for (int i = 0, len = instructions_.length(); i < len; i++) { | 
| instructions_[i]->Print(); | 
| } | 
| - PrintF("Goto L%d\n\n", successor_->number()); | 
| + PrintF("Goto L%d\n\n", successor_->number()); | 
| successor_->Print(); | 
| } | 
| } |