Chromium Code Reviews| 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 891 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 902 block->set_argument_count(argument_count_); | 902 block->set_argument_count(argument_count_); |
| 903 next_block_ = NULL; | 903 next_block_ = NULL; |
| 904 current_block_ = NULL; | 904 current_block_ = NULL; |
| 905 } | 905 } |
| 906 | 906 |
| 907 | 907 |
| 908 void LChunkBuilder::VisitInstruction(HInstruction* current) { | 908 void LChunkBuilder::VisitInstruction(HInstruction* current) { |
| 909 HInstruction* old_current = current_instruction_; | 909 HInstruction* old_current = current_instruction_; |
| 910 current_instruction_ = current; | 910 current_instruction_ = current; |
| 911 if (current->has_position()) position_ = current->position(); | 911 if (current->has_position()) position_ = current->position(); |
| 912 LInstruction* instr = current->CompileToLithium(this); | 912 |
| 913 LInstruction* instr = NULL; | |
| 914 if (current->CanReplaceWithDummyUses()) { | |
| 915 HValue* first_operand = current->OperandCount() == 0 | |
| 916 ? graph()->GetConstant1() : | |
|
Jakob Kummerow
2013/10/01 11:59:20
nit: please put the ':' in the next line, under th
danno
2013/10/23 11:46:51
Done.
| |
| 917 current->OperandAt(0); | |
| 918 instr = DefineAsRegister(new(zone()) LDummyUse(UseAny(first_operand))); | |
| 919 for (int i = 1; i < current->OperandCount(); ++i) { | |
| 920 LInstruction* dummy = | |
| 921 new(zone()) LDummyUse(UseAny(current->OperandAt(1))); | |
|
Jakob Kummerow
2013/10/01 11:59:20
bug: OperandAt(i)!
danno
2013/10/23 11:46:51
Done.
| |
| 922 dummy->set_hydrogen_value(current); | |
| 923 chunk_->AddInstruction(dummy, current_block_); | |
| 924 } | |
| 925 } else { | |
| 926 instr = current->CompileToLithium(this); | |
| 927 } | |
| 913 | 928 |
| 914 if (instr != NULL) { | 929 if (instr != NULL) { |
| 915 #if DEBUG | 930 #if DEBUG |
| 916 // Make sure that the lithium instruction has either no fixed register | 931 // Make sure that the lithium instruction has either no fixed register |
| 917 // constraints in temps or the result OR no uses that are only used at | 932 // constraints in temps or the result OR no uses that are only used at |
| 918 // start. If this invariant doesn't hold, the register allocator can decide | 933 // start. If this invariant doesn't hold, the register allocator can decide |
| 919 // to insert a split of a range immediately before the instruction due to an | 934 // to insert a split of a range immediately before the instruction due to an |
| 920 // already allocated register needing to be used for the instruction's fixed | 935 // already allocated register needing to be used for the instruction's fixed |
| 921 // register constraint. In this case, The register allocator won't see an | 936 // register constraint. In this case, The register allocator won't see an |
| 922 // interference between the split child and the use-at-start (it would if | 937 // interference between the split child and the use-at-start (it would if |
| (...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1048 return result; | 1063 return result; |
| 1049 } | 1064 } |
| 1050 | 1065 |
| 1051 | 1066 |
| 1052 LInstruction* LChunkBuilder::DoGoto(HGoto* instr) { | 1067 LInstruction* LChunkBuilder::DoGoto(HGoto* instr) { |
| 1053 return new(zone()) LGoto(instr->FirstSuccessor()); | 1068 return new(zone()) LGoto(instr->FirstSuccessor()); |
| 1054 } | 1069 } |
| 1055 | 1070 |
| 1056 | 1071 |
| 1057 LInstruction* LChunkBuilder::DoBranch(HBranch* instr) { | 1072 LInstruction* LChunkBuilder::DoBranch(HBranch* instr) { |
| 1058 HValue* value = instr->value(); | 1073 LInstruction* goto_instr = CheckElideControlInstruction(instr); |
| 1059 if (value->EmitAtUses()) { | 1074 if (goto_instr != NULL) return goto_instr; |
| 1060 ASSERT(value->IsConstant()); | |
| 1061 ASSERT(!value->representation().IsDouble()); | |
| 1062 HBasicBlock* successor = HConstant::cast(value)->BooleanValue() | |
| 1063 ? instr->FirstSuccessor() | |
| 1064 : instr->SecondSuccessor(); | |
| 1065 return new(zone()) LGoto(successor); | |
| 1066 } | |
| 1067 | 1075 |
| 1068 ToBooleanStub::Types expected = instr->expected_input_types(); | 1076 ToBooleanStub::Types expected = instr->expected_input_types(); |
| 1069 | 1077 |
| 1070 // Tagged values that are not known smis or booleans require a | 1078 // Tagged values that are not known smis or booleans require a |
| 1071 // deoptimization environment. If the instruction is generic no | 1079 // deoptimization environment. If the instruction is generic no |
| 1072 // environment is needed since all cases are handled. | 1080 // environment is needed since all cases are handled. |
| 1081 HValue* value = instr->value(); | |
| 1073 Representation rep = value->representation(); | 1082 Representation rep = value->representation(); |
| 1074 HType type = value->type(); | 1083 HType type = value->type(); |
| 1075 if (!rep.IsTagged() || type.IsSmi() || type.IsBoolean()) { | 1084 if (!rep.IsTagged() || type.IsSmi() || type.IsBoolean()) { |
| 1076 return new(zone()) LBranch(UseRegister(value), NULL); | 1085 return new(zone()) LBranch(UseRegister(value), NULL); |
| 1077 } | 1086 } |
| 1078 | 1087 |
| 1079 bool needs_temp = expected.NeedsMap() || expected.IsEmpty(); | 1088 bool needs_temp = expected.NeedsMap() || expected.IsEmpty(); |
| 1080 LOperand* temp = needs_temp ? TempRegister() : NULL; | 1089 LOperand* temp = needs_temp ? TempRegister() : NULL; |
| 1081 | 1090 |
| 1082 // The Generic stub does not have a deopt, so we need no environment. | 1091 // The Generic stub does not have a deopt, so we need no environment. |
| (...skipping 651 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1734 left = UseRegisterAtStart(instr->left()); | 1743 left = UseRegisterAtStart(instr->left()); |
| 1735 right = UseRegisterAtStart(instr->right()); | 1744 right = UseRegisterAtStart(instr->right()); |
| 1736 } | 1745 } |
| 1737 return new(zone()) LCompareNumericAndBranch(left, right); | 1746 return new(zone()) LCompareNumericAndBranch(left, right); |
| 1738 } | 1747 } |
| 1739 } | 1748 } |
| 1740 | 1749 |
| 1741 | 1750 |
| 1742 LInstruction* LChunkBuilder::DoCompareObjectEqAndBranch( | 1751 LInstruction* LChunkBuilder::DoCompareObjectEqAndBranch( |
| 1743 HCompareObjectEqAndBranch* instr) { | 1752 HCompareObjectEqAndBranch* instr) { |
| 1753 LInstruction* goto_instr = CheckElideControlInstruction(instr); | |
| 1754 if (goto_instr != NULL) return goto_instr; | |
| 1744 LOperand* left = UseRegisterAtStart(instr->left()); | 1755 LOperand* left = UseRegisterAtStart(instr->left()); |
| 1745 LOperand* right = UseOrConstantAtStart(instr->right()); | 1756 LOperand* right = UseOrConstantAtStart(instr->right()); |
| 1746 return new(zone()) LCmpObjectEqAndBranch(left, right); | 1757 return new(zone()) LCmpObjectEqAndBranch(left, right); |
| 1747 } | 1758 } |
| 1748 | 1759 |
| 1749 | 1760 |
| 1750 LInstruction* LChunkBuilder::DoCompareHoleAndBranch( | 1761 LInstruction* LChunkBuilder::DoCompareHoleAndBranch( |
| 1751 HCompareHoleAndBranch* instr) { | 1762 HCompareHoleAndBranch* instr) { |
| 1752 LOperand* value = UseRegisterAtStart(instr->value()); | 1763 LOperand* value = UseRegisterAtStart(instr->value()); |
| 1753 return new(zone()) LCmpHoleAndBranch(value); | 1764 return new(zone()) LCmpHoleAndBranch(value); |
| (...skipping 973 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2727 LInstruction* LChunkBuilder::DoLoadFieldByIndex(HLoadFieldByIndex* instr) { | 2738 LInstruction* LChunkBuilder::DoLoadFieldByIndex(HLoadFieldByIndex* instr) { |
| 2728 LOperand* object = UseRegister(instr->object()); | 2739 LOperand* object = UseRegister(instr->object()); |
| 2729 LOperand* index = UseTempRegister(instr->index()); | 2740 LOperand* index = UseTempRegister(instr->index()); |
| 2730 return DefineSameAsFirst(new(zone()) LLoadFieldByIndex(object, index)); | 2741 return DefineSameAsFirst(new(zone()) LLoadFieldByIndex(object, index)); |
| 2731 } | 2742 } |
| 2732 | 2743 |
| 2733 | 2744 |
| 2734 } } // namespace v8::internal | 2745 } } // namespace v8::internal |
| 2735 | 2746 |
| 2736 #endif // V8_TARGET_ARCH_IA32 | 2747 #endif // V8_TARGET_ARCH_IA32 |
| OLD | NEW |