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 <algorithm> | 5 #include <algorithm> |
6 | 6 |
7 #include "src/base/adapters.h" | 7 #include "src/base/adapters.h" |
8 #include "src/compiler/instruction-selector-impl.h" | 8 #include "src/compiler/instruction-selector-impl.h" |
9 #include "src/compiler/node-matchers.h" | 9 #include "src/compiler/node-matchers.h" |
10 #include "src/compiler/node-properties.h" | 10 #include "src/compiler/node-properties.h" |
(...skipping 953 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
964 Emit(kSSEInt64ToFloat32, g.DefineAsRegister(node), g.Use(node->InputAt(0))); | 964 Emit(kSSEInt64ToFloat32, g.DefineAsRegister(node), g.Use(node->InputAt(0))); |
965 } | 965 } |
966 | 966 |
967 | 967 |
968 void InstructionSelector::VisitRoundInt64ToFloat64(Node* node) { | 968 void InstructionSelector::VisitRoundInt64ToFloat64(Node* node) { |
969 X64OperandGenerator g(this); | 969 X64OperandGenerator g(this); |
970 Emit(kSSEInt64ToFloat64, g.DefineAsRegister(node), g.Use(node->InputAt(0))); | 970 Emit(kSSEInt64ToFloat64, g.DefineAsRegister(node), g.Use(node->InputAt(0))); |
971 } | 971 } |
972 | 972 |
973 | 973 |
| 974 void InstructionSelector::VisitRoundUint64ToFloat64(Node* node) { |
| 975 X64OperandGenerator g(this); |
| 976 Emit(kSSEUint64ToFloat64, g.DefineAsRegister(node), g.Use(node->InputAt(0))); |
| 977 } |
| 978 |
| 979 |
974 void InstructionSelector::VisitBitcastFloat32ToInt32(Node* node) { | 980 void InstructionSelector::VisitBitcastFloat32ToInt32(Node* node) { |
975 X64OperandGenerator g(this); | 981 X64OperandGenerator g(this); |
976 Emit(kX64BitcastFI, g.DefineAsRegister(node), g.Use(node->InputAt(0))); | 982 Emit(kX64BitcastFI, g.DefineAsRegister(node), g.Use(node->InputAt(0))); |
977 } | 983 } |
978 | 984 |
979 | 985 |
980 void InstructionSelector::VisitBitcastFloat64ToInt64(Node* node) { | 986 void InstructionSelector::VisitBitcastFloat64ToInt64(Node* node) { |
981 X64OperandGenerator g(this); | 987 X64OperandGenerator g(this); |
982 Emit(kX64BitcastDL, g.DefineAsRegister(node), g.Use(node->InputAt(0))); | 988 Emit(kX64BitcastDL, g.DefineAsRegister(node), g.Use(node->InputAt(0))); |
983 } | 989 } |
(...skipping 671 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1655 if (CpuFeatures::IsSupported(SSE4_1)) { | 1661 if (CpuFeatures::IsSupported(SSE4_1)) { |
1656 flags |= MachineOperatorBuilder::kFloat64RoundDown | | 1662 flags |= MachineOperatorBuilder::kFloat64RoundDown | |
1657 MachineOperatorBuilder::kFloat64RoundTruncate; | 1663 MachineOperatorBuilder::kFloat64RoundTruncate; |
1658 } | 1664 } |
1659 return flags; | 1665 return flags; |
1660 } | 1666 } |
1661 | 1667 |
1662 } // namespace compiler | 1668 } // namespace compiler |
1663 } // namespace internal | 1669 } // namespace internal |
1664 } // namespace v8 | 1670 } // namespace v8 |
OLD | NEW |