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 #include "src/ppc/frames-ppc.h" | 9 #include "src/ppc/frames-ppc.h" |
10 | 10 |
(...skipping 859 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
870 #endif | 870 #endif |
871 | 871 |
872 #if V8_TARGET_ARCH_PPC64 | 872 #if V8_TARGET_ARCH_PPC64 |
873 void InstructionSelector::VisitWord64Sar(Node* node) { | 873 void InstructionSelector::VisitWord64Sar(Node* node) { |
874 PPCOperandGenerator g(this); | 874 PPCOperandGenerator g(this); |
875 Int64BinopMatcher m(node); | 875 Int64BinopMatcher m(node); |
876 if (CanCover(m.node(), m.left().node()) && m.left().IsLoad() && | 876 if (CanCover(m.node(), m.left().node()) && m.left().IsLoad() && |
877 m.right().Is(32)) { | 877 m.right().Is(32)) { |
878 // Just load and sign-extend the interesting 4 bytes instead. This happens, | 878 // Just load and sign-extend the interesting 4 bytes instead. This happens, |
879 // for example, when we're loading and untagging SMIs. | 879 // for example, when we're loading and untagging SMIs. |
880 BaseWithIndexAndDisplacement64Matcher mleft(m.left().node(), true); | 880 BaseWithIndexAndDisplacement64Matcher mleft(m.left().node(), |
| 881 AddressOption::kAllowAll); |
881 if (mleft.matches() && mleft.index() == nullptr) { | 882 if (mleft.matches() && mleft.index() == nullptr) { |
882 int64_t offset = 0; | 883 int64_t offset = 0; |
883 Node* displacement = mleft.displacement(); | 884 Node* displacement = mleft.displacement(); |
884 if (displacement != nullptr) { | 885 if (displacement != nullptr) { |
885 Int64Matcher mdisplacement(displacement); | 886 Int64Matcher mdisplacement(displacement); |
886 DCHECK(mdisplacement.HasValue()); | 887 DCHECK(mdisplacement.HasValue()); |
887 offset = mdisplacement.Value(); | 888 offset = mdisplacement.Value(); |
888 } | 889 } |
889 offset = SmiWordOffset(offset); | 890 offset = SmiWordOffset(offset); |
890 if (g.CanBeImmediate(offset, kInt16Imm_4ByteAligned)) { | 891 if (g.CanBeImmediate(offset, kInt16Imm_4ByteAligned)) { |
(...skipping 1147 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2038 // static | 2039 // static |
2039 MachineOperatorBuilder::AlignmentRequirements | 2040 MachineOperatorBuilder::AlignmentRequirements |
2040 InstructionSelector::AlignmentRequirements() { | 2041 InstructionSelector::AlignmentRequirements() { |
2041 return MachineOperatorBuilder::AlignmentRequirements:: | 2042 return MachineOperatorBuilder::AlignmentRequirements:: |
2042 FullUnalignedAccessSupport(); | 2043 FullUnalignedAccessSupport(); |
2043 } | 2044 } |
2044 | 2045 |
2045 } // namespace compiler | 2046 } // namespace compiler |
2046 } // namespace internal | 2047 } // namespace internal |
2047 } // namespace v8 | 2048 } // namespace v8 |
OLD | NEW |