OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 419 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
430 HBasicBlock* next = NULL; | 430 HBasicBlock* next = NULL; |
431 if (i < blocks->length() - 1) next = blocks->at(i + 1); | 431 if (i < blocks->length() - 1) next = blocks->at(i + 1); |
432 DoBasicBlock(blocks->at(i), next); | 432 DoBasicBlock(blocks->at(i), next); |
433 if (is_aborted()) return NULL; | 433 if (is_aborted()) return NULL; |
434 } | 434 } |
435 status_ = DONE; | 435 status_ = DONE; |
436 return chunk_; | 436 return chunk_; |
437 } | 437 } |
438 | 438 |
439 | 439 |
440 void LChunkBuilder::Abort(const char* reason) { | 440 void LChunkBuilder::Abort(BailoutReason reason) { |
441 info()->set_bailout_reason(reason); | 441 info()->set_bailout_reason(reason); |
442 status_ = ABORTED; | 442 status_ = ABORTED; |
443 } | 443 } |
444 | 444 |
445 | 445 |
446 LUnallocated* LChunkBuilder::ToUnallocated(Register reg) { | 446 LUnallocated* LChunkBuilder::ToUnallocated(Register reg) { |
447 return new(zone()) LUnallocated(LUnallocated::FIXED_REGISTER, | 447 return new(zone()) LUnallocated(LUnallocated::FIXED_REGISTER, |
448 Register::ToAllocationIndex(reg)); | 448 Register::ToAllocationIndex(reg)); |
449 } | 449 } |
450 | 450 |
(...skipping 187 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
638 instr->set_pointer_map(new(zone()) LPointerMap(position_, zone())); | 638 instr->set_pointer_map(new(zone()) LPointerMap(position_, zone())); |
639 return instr; | 639 return instr; |
640 } | 640 } |
641 | 641 |
642 | 642 |
643 LUnallocated* LChunkBuilder::TempRegister() { | 643 LUnallocated* LChunkBuilder::TempRegister() { |
644 LUnallocated* operand = | 644 LUnallocated* operand = |
645 new(zone()) LUnallocated(LUnallocated::MUST_HAVE_REGISTER); | 645 new(zone()) LUnallocated(LUnallocated::MUST_HAVE_REGISTER); |
646 int vreg = allocator_->GetVirtualRegister(); | 646 int vreg = allocator_->GetVirtualRegister(); |
647 if (!allocator_->AllocationOk()) { | 647 if (!allocator_->AllocationOk()) { |
648 Abort("Out of virtual registers while trying to allocate temp register."); | 648 Abort(kOutOfVirtualRegistersWhileTryingToAllocateTempRegister); |
649 vreg = 0; | 649 vreg = 0; |
650 } | 650 } |
651 operand->set_virtual_register(vreg); | 651 operand->set_virtual_register(vreg); |
652 return operand; | 652 return operand; |
653 } | 653 } |
654 | 654 |
655 | 655 |
656 LOperand* LChunkBuilder::FixedTemp(Register reg) { | 656 LOperand* LChunkBuilder::FixedTemp(Register reg) { |
657 LUnallocated* operand = ToUnallocated(reg); | 657 LUnallocated* operand = ToUnallocated(reg); |
658 ASSERT(operand->HasFixedPolicy()); | 658 ASSERT(operand->HasFixedPolicy()); |
(...skipping 1776 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2435 int index = static_cast<int>(instr->index()); | 2435 int index = static_cast<int>(instr->index()); |
2436 Register reg = DESCRIPTOR_GET_PARAMETER_REGISTER(descriptor, index); | 2436 Register reg = DESCRIPTOR_GET_PARAMETER_REGISTER(descriptor, index); |
2437 return DefineFixed(result, reg); | 2437 return DefineFixed(result, reg); |
2438 } | 2438 } |
2439 } | 2439 } |
2440 | 2440 |
2441 | 2441 |
2442 LInstruction* LChunkBuilder::DoUnknownOSRValue(HUnknownOSRValue* instr) { | 2442 LInstruction* LChunkBuilder::DoUnknownOSRValue(HUnknownOSRValue* instr) { |
2443 int spill_index = chunk()->GetNextSpillIndex(false); // Not double-width. | 2443 int spill_index = chunk()->GetNextSpillIndex(false); // Not double-width. |
2444 if (spill_index > LUnallocated::kMaxFixedSlotIndex) { | 2444 if (spill_index > LUnallocated::kMaxFixedSlotIndex) { |
2445 Abort("Too many spill slots needed for OSR"); | 2445 Abort(kTooManySpillSlotsNeededForOSR); |
2446 spill_index = 0; | 2446 spill_index = 0; |
2447 } | 2447 } |
2448 return DefineAsSpilled(new(zone()) LUnknownOSRValue, spill_index); | 2448 return DefineAsSpilled(new(zone()) LUnknownOSRValue, spill_index); |
2449 } | 2449 } |
2450 | 2450 |
2451 | 2451 |
2452 LInstruction* LChunkBuilder::DoCallStub(HCallStub* instr) { | 2452 LInstruction* LChunkBuilder::DoCallStub(HCallStub* instr) { |
2453 argument_count_ -= instr->argument_count(); | 2453 argument_count_ -= instr->argument_count(); |
2454 return MarkAsCall(DefineFixed(new(zone()) LCallStub, r0), instr); | 2454 return MarkAsCall(DefineFixed(new(zone()) LCallStub, r0), instr); |
2455 } | 2455 } |
(...skipping 152 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2608 | 2608 |
2609 | 2609 |
2610 LInstruction* LChunkBuilder::DoLoadFieldByIndex(HLoadFieldByIndex* instr) { | 2610 LInstruction* LChunkBuilder::DoLoadFieldByIndex(HLoadFieldByIndex* instr) { |
2611 LOperand* object = UseRegister(instr->object()); | 2611 LOperand* object = UseRegister(instr->object()); |
2612 LOperand* index = UseRegister(instr->index()); | 2612 LOperand* index = UseRegister(instr->index()); |
2613 return DefineAsRegister(new(zone()) LLoadFieldByIndex(object, index)); | 2613 return DefineAsRegister(new(zone()) LLoadFieldByIndex(object, index)); |
2614 } | 2614 } |
2615 | 2615 |
2616 | 2616 |
2617 } } // namespace v8::internal | 2617 } } // namespace v8::internal |
OLD | NEW |