| 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 664 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 675 } | 675 } |
| 676 | 676 |
| 677 | 677 |
| 678 void HValue::ComputeInitialRange(Zone* zone) { | 678 void HValue::ComputeInitialRange(Zone* zone) { |
| 679 ASSERT(!HasRange()); | 679 ASSERT(!HasRange()); |
| 680 range_ = InferRange(zone); | 680 range_ = InferRange(zone); |
| 681 ASSERT(HasRange()); | 681 ASSERT(HasRange()); |
| 682 } | 682 } |
| 683 | 683 |
| 684 | 684 |
| 685 void HSourcePosition::PrintTo(FILE* out) { |
| 686 if (IsUnknown()) { |
| 687 PrintF(out, "<?>"); |
| 688 } else { |
| 689 if (FLAG_hydrogen_track_positions) { |
| 690 PrintF(out, "<%d:%d>", inlining_id(), position()); |
| 691 } else { |
| 692 PrintF(out, "<0:%d>", raw()); |
| 693 } |
| 694 } |
| 695 } |
| 696 |
| 697 |
| 685 void HInstruction::PrintTo(StringStream* stream) { | 698 void HInstruction::PrintTo(StringStream* stream) { |
| 686 PrintMnemonicTo(stream); | 699 PrintMnemonicTo(stream); |
| 687 PrintDataTo(stream); | 700 PrintDataTo(stream); |
| 688 PrintRangeTo(stream); | 701 PrintRangeTo(stream); |
| 689 PrintChangesTo(stream); | 702 PrintChangesTo(stream); |
| 690 PrintTypeTo(stream); | 703 PrintTypeTo(stream); |
| 691 if (CheckFlag(HValue::kHasNoObservableSideEffects)) { | 704 if (CheckFlag(HValue::kHasNoObservableSideEffects)) { |
| 692 stream->Add(" [noOSE]"); | 705 stream->Add(" [noOSE]"); |
| 693 } | 706 } |
| 694 if (CheckFlag(HValue::kIsDead)) { | 707 if (CheckFlag(HValue::kIsDead)) { |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 731 ASSERT(!next->IsBlockEntry()); | 744 ASSERT(!next->IsBlockEntry()); |
| 732 ASSERT(!IsControlInstruction()); | 745 ASSERT(!IsControlInstruction()); |
| 733 ASSERT(!next->block()->IsStartBlock()); | 746 ASSERT(!next->block()->IsStartBlock()); |
| 734 ASSERT(next->previous_ != NULL); | 747 ASSERT(next->previous_ != NULL); |
| 735 HInstruction* prev = next->previous(); | 748 HInstruction* prev = next->previous(); |
| 736 prev->next_ = this; | 749 prev->next_ = this; |
| 737 next->previous_ = this; | 750 next->previous_ = this; |
| 738 next_ = next; | 751 next_ = next; |
| 739 previous_ = prev; | 752 previous_ = prev; |
| 740 SetBlock(next->block()); | 753 SetBlock(next->block()); |
| 741 if (position() == RelocInfo::kNoPosition && | 754 if (!has_position() && next->has_position()) { |
| 742 next->position() != RelocInfo::kNoPosition) { | |
| 743 set_position(next->position()); | 755 set_position(next->position()); |
| 744 } | 756 } |
| 745 } | 757 } |
| 746 | 758 |
| 747 | 759 |
| 748 void HInstruction::InsertAfter(HInstruction* previous) { | 760 void HInstruction::InsertAfter(HInstruction* previous) { |
| 749 ASSERT(!IsLinked()); | 761 ASSERT(!IsLinked()); |
| 750 ASSERT(!previous->IsControlInstruction()); | 762 ASSERT(!previous->IsControlInstruction()); |
| 751 ASSERT(!IsControlInstruction() || previous->next_ == NULL); | 763 ASSERT(!IsControlInstruction() || previous->next_ == NULL); |
| 752 HBasicBlock* block = previous->block(); | 764 HBasicBlock* block = previous->block(); |
| (...skipping 16 matching lines...) Expand all Loading... |
| 769 } | 781 } |
| 770 | 782 |
| 771 previous_ = previous; | 783 previous_ = previous; |
| 772 next_ = next; | 784 next_ = next; |
| 773 SetBlock(block); | 785 SetBlock(block); |
| 774 previous->next_ = this; | 786 previous->next_ = this; |
| 775 if (next != NULL) next->previous_ = this; | 787 if (next != NULL) next->previous_ = this; |
| 776 if (block->last() == previous) { | 788 if (block->last() == previous) { |
| 777 block->set_last(this); | 789 block->set_last(this); |
| 778 } | 790 } |
| 779 if (position() == RelocInfo::kNoPosition && | 791 if (!has_position() && previous->has_position()) { |
| 780 previous->position() != RelocInfo::kNoPosition) { | |
| 781 set_position(previous->position()); | 792 set_position(previous->position()); |
| 782 } | 793 } |
| 783 } | 794 } |
| 784 | 795 |
| 785 | 796 |
| 786 #ifdef DEBUG | 797 #ifdef DEBUG |
| 787 void HInstruction::Verify() { | 798 void HInstruction::Verify() { |
| 788 // Verify that input operands are defined before use. | 799 // Verify that input operands are defined before use. |
| 789 HBasicBlock* cur_block = block(); | 800 HBasicBlock* cur_block = block(); |
| 790 for (int i = 0; i < OperandCount(); ++i) { | 801 for (int i = 0; i < OperandCount(); ++i) { |
| (...skipping 851 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1642 Range* HConstant::InferRange(Zone* zone) { | 1653 Range* HConstant::InferRange(Zone* zone) { |
| 1643 if (has_int32_value_) { | 1654 if (has_int32_value_) { |
| 1644 Range* result = new(zone) Range(int32_value_, int32_value_); | 1655 Range* result = new(zone) Range(int32_value_, int32_value_); |
| 1645 result->set_can_be_minus_zero(false); | 1656 result->set_can_be_minus_zero(false); |
| 1646 return result; | 1657 return result; |
| 1647 } | 1658 } |
| 1648 return HValue::InferRange(zone); | 1659 return HValue::InferRange(zone); |
| 1649 } | 1660 } |
| 1650 | 1661 |
| 1651 | 1662 |
| 1652 int HPhi::position() const { | 1663 HSourcePosition HPhi::position() const { |
| 1653 return block()->first()->position(); | 1664 return block()->first()->position(); |
| 1654 } | 1665 } |
| 1655 | 1666 |
| 1656 | 1667 |
| 1657 Range* HPhi::InferRange(Zone* zone) { | 1668 Range* HPhi::InferRange(Zone* zone) { |
| 1658 Representation r = representation(); | 1669 Representation r = representation(); |
| 1659 if (r.IsSmiOrInteger32()) { | 1670 if (r.IsSmiOrInteger32()) { |
| 1660 if (block()->IsLoopHeader()) { | 1671 if (block()->IsLoopHeader()) { |
| 1661 Range* range = r.IsSmi() | 1672 Range* range = r.IsSmi() |
| 1662 ? new(zone) Range(Smi::kMinValue, Smi::kMaxValue) | 1673 ? new(zone) Range(Smi::kMinValue, Smi::kMaxValue) |
| (...skipping 2831 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4494 break; | 4505 break; |
| 4495 case kExternalMemory: | 4506 case kExternalMemory: |
| 4496 stream->Add("[external-memory]"); | 4507 stream->Add("[external-memory]"); |
| 4497 break; | 4508 break; |
| 4498 } | 4509 } |
| 4499 | 4510 |
| 4500 stream->Add("@%d", offset()); | 4511 stream->Add("@%d", offset()); |
| 4501 } | 4512 } |
| 4502 | 4513 |
| 4503 } } // namespace v8::internal | 4514 } } // namespace v8::internal |
| OLD | NEW |