| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/base/adapters.h" | 5 #include "src/base/adapters.h" |
| 6 #include "src/compiler/instruction-selector-impl.h" | 6 #include "src/compiler/instruction-selector-impl.h" |
| 7 #include "src/compiler/node-matchers.h" | 7 #include "src/compiler/node-matchers.h" |
| 8 #include "src/compiler/node-properties.h" | 8 #include "src/compiler/node-properties.h" |
| 9 | 9 |
| 10 namespace v8 { | 10 namespace v8 { |
| (...skipping 1498 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1509 kNotEqual, DeoptimizeReasonOf(node->op()), node->InputAt(1)); | 1509 kNotEqual, DeoptimizeReasonOf(node->op()), node->InputAt(1)); |
| 1510 VisitWordCompareZero(this, node, node->InputAt(0), &cont); | 1510 VisitWordCompareZero(this, node, node->InputAt(0), &cont); |
| 1511 } | 1511 } |
| 1512 | 1512 |
| 1513 void InstructionSelector::VisitDeoptimizeUnless(Node* node) { | 1513 void InstructionSelector::VisitDeoptimizeUnless(Node* node) { |
| 1514 FlagsContinuation cont = FlagsContinuation::ForDeoptimize( | 1514 FlagsContinuation cont = FlagsContinuation::ForDeoptimize( |
| 1515 kEqual, DeoptimizeReasonOf(node->op()), node->InputAt(1)); | 1515 kEqual, DeoptimizeReasonOf(node->op()), node->InputAt(1)); |
| 1516 VisitWordCompareZero(this, node, node->InputAt(0), &cont); | 1516 VisitWordCompareZero(this, node, node->InputAt(0), &cont); |
| 1517 } | 1517 } |
| 1518 | 1518 |
| 1519 void InstructionSelector::VisitTrapIf(Node* node) { UNREACHABLE(); } |
| 1520 |
| 1521 void InstructionSelector::VisitTrapUnless(Node* node) { UNREACHABLE(); } |
| 1522 |
| 1519 void InstructionSelector::VisitSwitch(Node* node, const SwitchInfo& sw) { | 1523 void InstructionSelector::VisitSwitch(Node* node, const SwitchInfo& sw) { |
| 1520 IA32OperandGenerator g(this); | 1524 IA32OperandGenerator g(this); |
| 1521 InstructionOperand value_operand = g.UseRegister(node->InputAt(0)); | 1525 InstructionOperand value_operand = g.UseRegister(node->InputAt(0)); |
| 1522 | 1526 |
| 1523 // Emit either ArchTableSwitch or ArchLookupSwitch. | 1527 // Emit either ArchTableSwitch or ArchLookupSwitch. |
| 1524 size_t table_space_cost = 4 + sw.value_range; | 1528 size_t table_space_cost = 4 + sw.value_range; |
| 1525 size_t table_time_cost = 3; | 1529 size_t table_time_cost = 3; |
| 1526 size_t lookup_space_cost = 3 + 2 * sw.case_count; | 1530 size_t lookup_space_cost = 3 + 2 * sw.case_count; |
| 1527 size_t lookup_time_cost = sw.case_count; | 1531 size_t lookup_time_cost = sw.case_count; |
| 1528 if (sw.case_count > 4 && | 1532 if (sw.case_count > 4 && |
| (...skipping 233 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1762 // static | 1766 // static |
| 1763 MachineOperatorBuilder::AlignmentRequirements | 1767 MachineOperatorBuilder::AlignmentRequirements |
| 1764 InstructionSelector::AlignmentRequirements() { | 1768 InstructionSelector::AlignmentRequirements() { |
| 1765 return MachineOperatorBuilder::AlignmentRequirements:: | 1769 return MachineOperatorBuilder::AlignmentRequirements:: |
| 1766 FullUnalignedAccessSupport(); | 1770 FullUnalignedAccessSupport(); |
| 1767 } | 1771 } |
| 1768 | 1772 |
| 1769 } // namespace compiler | 1773 } // namespace compiler |
| 1770 } // namespace internal | 1774 } // namespace internal |
| 1771 } // namespace v8 | 1775 } // namespace v8 |
| OLD | NEW |