| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 #ifndef V8_X64_MACRO_ASSEMBLER_X64_H_ | 5 #ifndef V8_X64_MACRO_ASSEMBLER_X64_H_ |
| 6 #define V8_X64_MACRO_ASSEMBLER_X64_H_ | 6 #define V8_X64_MACRO_ASSEMBLER_X64_H_ |
| 7 | 7 |
| 8 #include "src/assembler.h" | 8 #include "src/assembler.h" |
| 9 #include "src/bailout-reason.h" | 9 #include "src/bailout-reason.h" |
| 10 #include "src/base/flags.h" | 10 #include "src/base/flags.h" |
| (...skipping 939 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 950 #define AVX_OP2_O(macro_name, name) \ | 950 #define AVX_OP2_O(macro_name, name) \ |
| 951 AVX_OP2_WITH_TYPE(macro_name, name, const Operand&) | 951 AVX_OP2_WITH_TYPE(macro_name, name, const Operand&) |
| 952 #define AVX_OP2_XO(macro_name, name) \ | 952 #define AVX_OP2_XO(macro_name, name) \ |
| 953 AVX_OP2_X(macro_name, name) \ | 953 AVX_OP2_X(macro_name, name) \ |
| 954 AVX_OP2_O(macro_name, name) | 954 AVX_OP2_O(macro_name, name) |
| 955 | 955 |
| 956 AVX_OP2_XO(Addsd, addsd) | 956 AVX_OP2_XO(Addsd, addsd) |
| 957 AVX_OP2_XO(Subsd, subsd) | 957 AVX_OP2_XO(Subsd, subsd) |
| 958 AVX_OP2_XO(Mulsd, mulsd) | 958 AVX_OP2_XO(Mulsd, mulsd) |
| 959 AVX_OP2_XO(Divsd, divsd) | 959 AVX_OP2_XO(Divsd, divsd) |
| 960 AVX_OP2_X(Andpd, andpd) | 960 AVX_OP2_XO(Andps, andps) |
| 961 AVX_OP2_X(Orpd, orpd) | 961 AVX_OP2_XO(Andpd, andpd) |
| 962 AVX_OP2_X(Xorpd, xorpd) | 962 AVX_OP2_XO(Orpd, orpd) |
| 963 AVX_OP2_XO(Xorpd, xorpd) |
| 963 AVX_OP2_X(Pcmpeqd, pcmpeqd) | 964 AVX_OP2_X(Pcmpeqd, pcmpeqd) |
| 964 AVX_OP2_WITH_TYPE(Psllq, psllq, byte) | 965 AVX_OP2_WITH_TYPE(Psllq, psllq, byte) |
| 965 AVX_OP2_WITH_TYPE(Psrlq, psrlq, byte) | 966 AVX_OP2_WITH_TYPE(Psrlq, psrlq, byte) |
| 966 | 967 |
| 967 #undef AVX_OP2_O | 968 #undef AVX_OP2_O |
| 968 #undef AVX_OP2_X | 969 #undef AVX_OP2_X |
| 969 #undef AVX_OP2_XO | 970 #undef AVX_OP2_XO |
| 970 #undef AVX_OP2_WITH_TYPE | 971 #undef AVX_OP2_WITH_TYPE |
| 971 | 972 |
| 972 void Movsd(XMMRegister dst, XMMRegister src); | 973 void Movsd(XMMRegister dst, XMMRegister src); |
| 973 void Movsd(XMMRegister dst, const Operand& src); | 974 void Movsd(XMMRegister dst, const Operand& src); |
| 974 void Movsd(const Operand& dst, XMMRegister src); | 975 void Movsd(const Operand& dst, XMMRegister src); |
| 975 void Movss(XMMRegister dst, XMMRegister src); | 976 void Movss(XMMRegister dst, XMMRegister src); |
| 976 void Movss(XMMRegister dst, const Operand& src); | 977 void Movss(XMMRegister dst, const Operand& src); |
| 977 void Movss(const Operand& dst, XMMRegister src); | 978 void Movss(const Operand& dst, XMMRegister src); |
| 978 | 979 |
| 979 void Movd(XMMRegister dst, Register src); | 980 void Movd(XMMRegister dst, Register src); |
| 980 void Movd(XMMRegister dst, const Operand& src); | 981 void Movd(XMMRegister dst, const Operand& src); |
| 981 void Movd(Register dst, XMMRegister src); | 982 void Movd(Register dst, XMMRegister src); |
| 982 void Movq(XMMRegister dst, Register src); | 983 void Movq(XMMRegister dst, Register src); |
| 983 void Movq(Register dst, XMMRegister src); | 984 void Movq(Register dst, XMMRegister src); |
| 984 | 985 |
| 985 void Movaps(XMMRegister dst, XMMRegister src); | 986 void Movaps(XMMRegister dst, XMMRegister src); |
| 986 void Movups(XMMRegister dst, XMMRegister src); | 987 void Movups(XMMRegister dst, XMMRegister src); |
| 987 void Movups(XMMRegister dst, const Operand& src); | 988 void Movups(XMMRegister dst, const Operand& src); |
| 988 void Movups(const Operand& dst, XMMRegister src); | 989 void Movups(const Operand& dst, XMMRegister src); |
| 989 void Movapd(XMMRegister dst, XMMRegister src); | 990 void Movapd(XMMRegister dst, XMMRegister src); |
| 991 void Movupd(XMMRegister dst, const Operand& src); |
| 992 void Movupd(const Operand& dst, XMMRegister src); |
| 990 void Movmskpd(Register dst, XMMRegister src); | 993 void Movmskpd(Register dst, XMMRegister src); |
| 991 | 994 |
| 992 void Xorps(XMMRegister dst, XMMRegister src); | 995 void Xorps(XMMRegister dst, XMMRegister src); |
| 993 void Xorps(XMMRegister dst, const Operand& src); | 996 void Xorps(XMMRegister dst, const Operand& src); |
| 994 | 997 |
| 995 void Roundss(XMMRegister dst, XMMRegister src, RoundingMode mode); | 998 void Roundss(XMMRegister dst, XMMRegister src, RoundingMode mode); |
| 996 void Roundsd(XMMRegister dst, XMMRegister src, RoundingMode mode); | 999 void Roundsd(XMMRegister dst, XMMRegister src, RoundingMode mode); |
| 997 void Sqrtsd(XMMRegister dst, XMMRegister src); | 1000 void Sqrtsd(XMMRegister dst, XMMRegister src); |
| 998 void Sqrtsd(XMMRegister dst, const Operand& src); | 1001 void Sqrtsd(XMMRegister dst, const Operand& src); |
| 999 | 1002 |
| 1000 void Ucomiss(XMMRegister src1, XMMRegister src2); | 1003 void Ucomiss(XMMRegister src1, XMMRegister src2); |
| 1001 void Ucomiss(XMMRegister src1, const Operand& src2); | 1004 void Ucomiss(XMMRegister src1, const Operand& src2); |
| 1002 void Ucomisd(XMMRegister src1, XMMRegister src2); | 1005 void Ucomisd(XMMRegister src1, XMMRegister src2); |
| 1003 void Ucomisd(XMMRegister src1, const Operand& src2); | 1006 void Ucomisd(XMMRegister src1, const Operand& src2); |
| 1004 | 1007 |
| 1008 // --------------------------------------------------------------------------- |
| 1009 // SIMD macros. |
| 1010 void Absps(XMMRegister dst); |
| 1011 void Negps(XMMRegister dst); |
| 1012 void Abspd(XMMRegister dst); |
| 1013 void Negpd(XMMRegister dst); |
| 1014 |
| 1005 // Control Flow | 1015 // Control Flow |
| 1006 void Jump(Address destination, RelocInfo::Mode rmode); | 1016 void Jump(Address destination, RelocInfo::Mode rmode); |
| 1007 void Jump(ExternalReference ext); | 1017 void Jump(ExternalReference ext); |
| 1008 void Jump(const Operand& op); | 1018 void Jump(const Operand& op); |
| 1009 void Jump(Handle<Code> code_object, RelocInfo::Mode rmode); | 1019 void Jump(Handle<Code> code_object, RelocInfo::Mode rmode); |
| 1010 | 1020 |
| 1011 void Call(Address destination, RelocInfo::Mode rmode); | 1021 void Call(Address destination, RelocInfo::Mode rmode); |
| 1012 void Call(ExternalReference ext); | 1022 void Call(ExternalReference ext); |
| 1013 void Call(const Operand& op); | 1023 void Call(const Operand& op); |
| 1014 void Call(Handle<Code> code_object, | 1024 void Call(Handle<Code> code_object, |
| (...skipping 769 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1784 } \ | 1794 } \ |
| 1785 masm-> | 1795 masm-> |
| 1786 #else | 1796 #else |
| 1787 #define ACCESS_MASM(masm) masm-> | 1797 #define ACCESS_MASM(masm) masm-> |
| 1788 #endif | 1798 #endif |
| 1789 | 1799 |
| 1790 } // namespace internal | 1800 } // namespace internal |
| 1791 } // namespace v8 | 1801 } // namespace v8 |
| 1792 | 1802 |
| 1793 #endif // V8_X64_MACRO_ASSEMBLER_X64_H_ | 1803 #endif // V8_X64_MACRO_ASSEMBLER_X64_H_ |
| OLD | NEW |