| 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/base/bits.h" | 6 #include "src/base/bits.h" |
| 7 #include "src/compiler/instruction-selector-impl.h" | 7 #include "src/compiler/instruction-selector-impl.h" |
| 8 #include "src/compiler/node-matchers.h" | 8 #include "src/compiler/node-matchers.h" |
| 9 #include "src/compiler/node-properties.h" | 9 #include "src/compiler/node-properties.h" |
| 10 | 10 |
| (...skipping 818 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 829 return; | 829 return; |
| 830 case IrOpcode::kFloat64RoundTiesEven: | 830 case IrOpcode::kFloat64RoundTiesEven: |
| 831 Emit(kMips64RoundWD, g.DefineAsRegister(node), | 831 Emit(kMips64RoundWD, g.DefineAsRegister(node), |
| 832 g.UseRegister(value->InputAt(0))); | 832 g.UseRegister(value->InputAt(0))); |
| 833 return; | 833 return; |
| 834 case IrOpcode::kFloat64RoundTruncate: | 834 case IrOpcode::kFloat64RoundTruncate: |
| 835 Emit(kMips64TruncWD, g.DefineAsRegister(node), | 835 Emit(kMips64TruncWD, g.DefineAsRegister(node), |
| 836 g.UseRegister(value->InputAt(0))); | 836 g.UseRegister(value->InputAt(0))); |
| 837 return; | 837 return; |
| 838 default: | 838 default: |
| 839 VisitRR(this, kMips64TruncWD, node); | 839 break; |
| 840 } |
| 841 if (value->opcode() == IrOpcode::kChangeFloat32ToFloat64) { |
| 842 Node* next = value->InputAt(0); |
| 843 if (CanCover(value, next)) { |
| 844 // Match ChangeFloat64ToInt32(ChangeFloat32ToFloat64(Float64Round##OP)) |
| 845 switch (next->opcode()) { |
| 846 case IrOpcode::kFloat32RoundDown: |
| 847 Emit(kMips64FloorWS, g.DefineAsRegister(node), |
| 848 g.UseRegister(next->InputAt(0))); |
| 849 return; |
| 850 case IrOpcode::kFloat32RoundUp: |
| 851 Emit(kMips64CeilWS, g.DefineAsRegister(node), |
| 852 g.UseRegister(next->InputAt(0))); |
| 853 return; |
| 854 case IrOpcode::kFloat32RoundTiesEven: |
| 855 Emit(kMips64RoundWS, g.DefineAsRegister(node), |
| 856 g.UseRegister(next->InputAt(0))); |
| 857 return; |
| 858 case IrOpcode::kFloat32RoundTruncate: |
| 859 Emit(kMips64TruncWS, g.DefineAsRegister(node), |
| 860 g.UseRegister(next->InputAt(0))); |
| 861 return; |
| 862 default: |
| 863 Emit(kMips64TruncWS, g.DefineAsRegister(node), |
| 864 g.UseRegister(value->InputAt(0))); |
| 865 return; |
| 866 } |
| 867 } else { |
| 868 // Match float32 -> float64 -> int32 representation change path. |
| 869 Emit(kMips64TruncWS, g.DefineAsRegister(node), |
| 870 g.UseRegister(value->InputAt(0))); |
| 840 return; | 871 return; |
| 872 } |
| 841 } | 873 } |
| 842 } | 874 } |
| 843 VisitRR(this, kMips64TruncWD, node); | 875 VisitRR(this, kMips64TruncWD, node); |
| 844 } | 876 } |
| 845 | 877 |
| 846 | 878 |
| 847 void InstructionSelector::VisitChangeFloat64ToUint32(Node* node) { | 879 void InstructionSelector::VisitChangeFloat64ToUint32(Node* node) { |
| 848 VisitRR(this, kMips64TruncUwD, node); | 880 VisitRR(this, kMips64TruncUwD, node); |
| 849 } | 881 } |
| 850 | 882 |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 947 default: | 979 default: |
| 948 break; | 980 break; |
| 949 } | 981 } |
| 950 } | 982 } |
| 951 Emit(kMips64Ext, g.DefineAsRegister(node), g.UseRegister(node->InputAt(0)), | 983 Emit(kMips64Ext, g.DefineAsRegister(node), g.UseRegister(node->InputAt(0)), |
| 952 g.TempImmediate(0), g.TempImmediate(32)); | 984 g.TempImmediate(0), g.TempImmediate(32)); |
| 953 } | 985 } |
| 954 | 986 |
| 955 | 987 |
| 956 void InstructionSelector::VisitTruncateFloat64ToFloat32(Node* node) { | 988 void InstructionSelector::VisitTruncateFloat64ToFloat32(Node* node) { |
| 989 Mips64OperandGenerator g(this); |
| 990 Node* value = node->InputAt(0); |
| 991 // Match TruncateFloat64ToFloat32(ChangeInt32ToFloat64) to corresponding |
| 992 // instruction. |
| 993 if (CanCover(node, value) && |
| 994 value->opcode() == IrOpcode::kChangeInt32ToFloat64) { |
| 995 Emit(kMips64CvtSW, g.DefineAsRegister(node), |
| 996 g.UseRegister(value->InputAt(0))); |
| 997 return; |
| 998 } |
| 957 VisitRR(this, kMips64CvtSD, node); | 999 VisitRR(this, kMips64CvtSD, node); |
| 958 } | 1000 } |
| 959 | 1001 |
| 960 | 1002 |
| 961 void InstructionSelector::VisitTruncateFloat64ToInt32(Node* node) { | 1003 void InstructionSelector::VisitTruncateFloat64ToInt32(Node* node) { |
| 962 switch (TruncationModeOf(node->op())) { | 1004 switch (TruncationModeOf(node->op())) { |
| 963 case TruncationMode::kJavaScript: | 1005 case TruncationMode::kJavaScript: |
| 964 return VisitRR(this, kArchTruncateDoubleToI, node); | 1006 return VisitRR(this, kArchTruncateDoubleToI, node); |
| 965 case TruncationMode::kRoundToZero: | 1007 case TruncationMode::kRoundToZero: |
| 966 return VisitRR(this, kMips64TruncWD, node); | 1008 return VisitRR(this, kMips64TruncWD, node); |
| (...skipping 819 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1786 MachineOperatorBuilder::kFloat32RoundUp | | 1828 MachineOperatorBuilder::kFloat32RoundUp | |
| 1787 MachineOperatorBuilder::kFloat64RoundTruncate | | 1829 MachineOperatorBuilder::kFloat64RoundTruncate | |
| 1788 MachineOperatorBuilder::kFloat32RoundTruncate | | 1830 MachineOperatorBuilder::kFloat32RoundTruncate | |
| 1789 MachineOperatorBuilder::kFloat64RoundTiesEven | | 1831 MachineOperatorBuilder::kFloat64RoundTiesEven | |
| 1790 MachineOperatorBuilder::kFloat32RoundTiesEven; | 1832 MachineOperatorBuilder::kFloat32RoundTiesEven; |
| 1791 } | 1833 } |
| 1792 | 1834 |
| 1793 } // namespace compiler | 1835 } // namespace compiler |
| 1794 } // namespace internal | 1836 } // namespace internal |
| 1795 } // namespace v8 | 1837 } // namespace v8 |
| OLD | NEW |