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 915 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
926 } | 926 } |
927 | 927 |
928 | 928 |
929 #if V8_TARGET_ARCH_PPC64 | 929 #if V8_TARGET_ARCH_PPC64 |
930 void InstructionSelector::VisitTruncateFloat32ToInt64(Node* node) { | 930 void InstructionSelector::VisitTruncateFloat32ToInt64(Node* node) { |
931 VisitRR(this, kPPC_DoubleToInt64, node); | 931 VisitRR(this, kPPC_DoubleToInt64, node); |
932 } | 932 } |
933 | 933 |
934 | 934 |
935 void InstructionSelector::VisitTryTruncateFloat64ToInt64(Node* node) { | 935 void InstructionSelector::VisitTryTruncateFloat64ToInt64(Node* node) { |
936 if (NodeProperties::FindProjection(node, 1)) { | 936 PPCOperandGenerator g(this); |
937 // TODO(ppc): implement the second return value. | 937 |
938 UNIMPLEMENTED(); | 938 InstructionOperand inputs[] = {g.UseRegister(node->InputAt(0))}; |
| 939 InstructionOperand outputs[2]; |
| 940 size_t output_count = 0; |
| 941 outputs[output_count++] = g.DefineAsRegister(node); |
| 942 |
| 943 Node* success_output = NodeProperties::FindProjection(node, 1); |
| 944 if (success_output) { |
| 945 outputs[output_count++] = g.DefineAsRegister(success_output); |
939 } | 946 } |
940 VisitRR(this, kPPC_DoubleToInt64, node); | 947 |
| 948 Emit(kPPC_DoubleToInt64, output_count, outputs, 1, inputs); |
941 } | 949 } |
942 | 950 |
943 | 951 |
944 void InstructionSelector::VisitTruncateFloat32ToUint64(Node* node) { | 952 void InstructionSelector::VisitTruncateFloat32ToUint64(Node* node) { |
945 VisitRR(this, kPPC_DoubleToUint64, node); | 953 VisitRR(this, kPPC_DoubleToUint64, node); |
946 } | 954 } |
947 | 955 |
948 | 956 |
949 void InstructionSelector::VisitTruncateFloat64ToUint64(Node* node) { | 957 void InstructionSelector::VisitTruncateFloat64ToUint64(Node* node) { |
950 VisitRR(this, kPPC_DoubleToUint64, node); | 958 VisitRR(this, kPPC_DoubleToUint64, node); |
(...skipping 748 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1699 MachineOperatorBuilder::kFloat64RoundTruncate | | 1707 MachineOperatorBuilder::kFloat64RoundTruncate | |
1700 MachineOperatorBuilder::kFloat64RoundTiesAway | | 1708 MachineOperatorBuilder::kFloat64RoundTiesAway | |
1701 MachineOperatorBuilder::kWord32Popcnt | | 1709 MachineOperatorBuilder::kWord32Popcnt | |
1702 MachineOperatorBuilder::kWord64Popcnt; | 1710 MachineOperatorBuilder::kWord64Popcnt; |
1703 // We omit kWord32ShiftIsSafe as s[rl]w use 0x3f as a mask rather than 0x1f. | 1711 // We omit kWord32ShiftIsSafe as s[rl]w use 0x3f as a mask rather than 0x1f. |
1704 } | 1712 } |
1705 | 1713 |
1706 } // namespace compiler | 1714 } // namespace compiler |
1707 } // namespace internal | 1715 } // namespace internal |
1708 } // namespace v8 | 1716 } // namespace v8 |
OLD | NEW |