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 1334 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1345 // Match memory operands on left side of comparison. | 1345 // Match memory operands on left side of comparison. |
1346 if (g.CanBeMemoryOperand(narrowed_opcode, node, left, effect_level)) { | 1346 if (g.CanBeMemoryOperand(narrowed_opcode, node, left, effect_level)) { |
1347 bool needs_byte_register = | 1347 bool needs_byte_register = |
1348 narrowed_opcode == kIA32Test8 || narrowed_opcode == kIA32Cmp8; | 1348 narrowed_opcode == kIA32Test8 || narrowed_opcode == kIA32Cmp8; |
1349 return VisitCompareWithMemoryOperand( | 1349 return VisitCompareWithMemoryOperand( |
1350 selector, narrowed_opcode, left, | 1350 selector, narrowed_opcode, left, |
1351 needs_byte_register ? g.UseByteRegister(right) : g.UseRegister(right), | 1351 needs_byte_register ? g.UseByteRegister(right) : g.UseRegister(right), |
1352 cont); | 1352 cont); |
1353 } | 1353 } |
1354 | 1354 |
1355 if (g.CanBeBetterLeftOperand(right)) { | |
1356 if (!node->op()->HasProperty(Operator::kCommutative)) cont->Commute(); | |
1357 std::swap(left, right); | |
1358 } | |
1359 | |
1360 return VisitCompare(selector, opcode, left, right, cont, | 1355 return VisitCompare(selector, opcode, left, right, cont, |
1361 node->op()->HasProperty(Operator::kCommutative)); | 1356 node->op()->HasProperty(Operator::kCommutative)); |
1362 } | 1357 } |
1363 | 1358 |
1364 void VisitWordCompare(InstructionSelector* selector, Node* node, | 1359 void VisitWordCompare(InstructionSelector* selector, Node* node, |
1365 FlagsContinuation* cont) { | 1360 FlagsContinuation* cont) { |
1366 IA32OperandGenerator g(selector); | 1361 IA32OperandGenerator g(selector); |
1367 Int32BinopMatcher m(node); | 1362 Int32BinopMatcher m(node); |
1368 if (m.left().IsLoad() && m.right().IsLoadStackPointer()) { | 1363 if (m.left().IsLoad() && m.right().IsLoadStackPointer()) { |
1369 LoadMatcher<ExternalReferenceMatcher> mleft(m.left().node()); | 1364 LoadMatcher<ExternalReferenceMatcher> mleft(m.left().node()); |
(...skipping 377 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1747 // static | 1742 // static |
1748 MachineOperatorBuilder::AlignmentRequirements | 1743 MachineOperatorBuilder::AlignmentRequirements |
1749 InstructionSelector::AlignmentRequirements() { | 1744 InstructionSelector::AlignmentRequirements() { |
1750 return MachineOperatorBuilder::AlignmentRequirements:: | 1745 return MachineOperatorBuilder::AlignmentRequirements:: |
1751 FullUnalignedAccessSupport(); | 1746 FullUnalignedAccessSupport(); |
1752 } | 1747 } |
1753 | 1748 |
1754 } // namespace compiler | 1749 } // namespace compiler |
1755 } // namespace internal | 1750 } // namespace internal |
1756 } // namespace v8 | 1751 } // namespace v8 |
OLD | NEW |