| Index: runtime/vm/assembler_x64_test.cc
|
| ===================================================================
|
| --- runtime/vm/assembler_x64_test.cc (revision 9572)
|
| +++ runtime/vm/assembler_x64_test.cc (working copy)
|
| @@ -1292,6 +1292,19 @@
|
| }
|
|
|
|
|
| +ASSEMBLER_TEST_GENERATE(XorpdZeroing2, assembler) {
|
| + __ xorpd(XMM0, XMM0);
|
| + __ ret();
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_RUN(XorpdZeroing2, entry) {
|
| + typedef double (*XorpdZeroing2Code)(double d);
|
| + double res = reinterpret_cast<XorpdZeroing2Code>(entry)(12.56e3);
|
| + EXPECT_FLOAT_EQ(0.0, res, 0.0001);
|
| +}
|
| +
|
| +
|
| ASSEMBLER_TEST_GENERATE(SquareRootDouble, assembler) {
|
| __ sqrtsd(XMM0, XMM0);
|
| __ ret();
|
| @@ -1317,6 +1330,113 @@
|
| __ ret();
|
| }
|
|
|
| +
|
| +ASSEMBLER_TEST_GENERATE(DoubleFPUStackMoves, assembler) {
|
| + int64_t l = bit_cast<int64_t, double>(1024.67);
|
| + __ movq(RAX, Immediate(l));
|
| + __ pushq(RAX);
|
| + __ fldl(Address(RSP, 0));
|
| + __ movq(Address(RSP, 0), Immediate(0));
|
| + __ fstpl(Address(RSP, 0));
|
| + __ popq(RAX);
|
| + __ ret();
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_RUN(DoubleFPUStackMoves, entry) {
|
| + typedef int64_t (*DoubleFPUStackMovesCode)();
|
| + int64_t res = reinterpret_cast<DoubleFPUStackMovesCode>(entry)();
|
| + EXPECT_FLOAT_EQ(1024.67, (bit_cast<double, int64_t>(res)), 0.001);
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_GENERATE(Sine, assembler) {
|
| + __ pushq(RAX);
|
| + __ movsd(Address(RSP, 0), XMM0);
|
| + __ fldl(Address(RSP, 0));
|
| + __ fsin();
|
| + __ fstpl(Address(RSP, 0));
|
| + __ movsd(XMM0, Address(RSP, 0));
|
| + __ popq(RAX);
|
| + __ ret();
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_RUN(Sine, entry) {
|
| + typedef double (*SineCode)(double d);
|
| + const double kDoubleConst = 0.7;
|
| + double res = reinterpret_cast<SineCode>(entry)(kDoubleConst);
|
| + EXPECT_FLOAT_EQ(sin(kDoubleConst), res, 0.0001);
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_GENERATE(Cosine, assembler) {
|
| + __ pushq(RAX);
|
| + __ movsd(Address(RSP, 0), XMM0);
|
| + __ fldl(Address(RSP, 0));
|
| + __ fcos();
|
| + __ fstpl(Address(RSP, 0));
|
| + __ movsd(XMM0, Address(RSP, 0));
|
| + __ popq(RAX);
|
| + __ ret();
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_RUN(Cosine, entry) {
|
| + typedef double (*CosineCode)(double f);
|
| + const double kDoubleConst = 0.7;
|
| + double res = reinterpret_cast<CosineCode>(entry)(kDoubleConst);
|
| + EXPECT_FLOAT_EQ(cos(kDoubleConst), res, 0.0001);
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_GENERATE(IntToDoubleConversion, assembler) {
|
| + __ movq(RDX, Immediate(6));
|
| + __ cvtsi2sd(XMM0, RDX);
|
| + __ ret();
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_RUN(IntToDoubleConversion, entry) {
|
| + typedef double (*IntToDoubleConversionCode)();
|
| + double res = reinterpret_cast<IntToDoubleConversionCode>(entry)();
|
| + EXPECT_FLOAT_EQ(6.0, res, 0.001);
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_GENERATE(IntToDoubleConversion2, assembler) {
|
| + __ pushq(RDI);
|
| + __ fildl(Address(RSP, 0));
|
| + __ fstpl(Address(RSP, 0));
|
| + __ movsd(XMM0, Address(RSP, 0));
|
| + __ popq(RAX);
|
| + __ ret();
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_RUN(IntToDoubleConversion2, entry) {
|
| + typedef double (*IntToDoubleConversion2Code)(int i);
|
| + double res = reinterpret_cast<IntToDoubleConversion2Code>(entry)(3);
|
| + EXPECT_FLOAT_EQ(3.0, res, 0.001);
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_GENERATE(ExtractSignBits, assembler) {
|
| + __ movmskpd(RAX, XMM0);
|
| + __ ret();
|
| +}
|
| +
|
| +
|
| +ASSEMBLER_TEST_RUN(ExtractSignBits, entry) {
|
| + typedef int (*ExtractSignBits)(double d);
|
| + int res = reinterpret_cast<ExtractSignBits>(entry)(1.0);
|
| + EXPECT_EQ(0, res);
|
| + res = reinterpret_cast<ExtractSignBits>(entry)(-1.0);
|
| + EXPECT_EQ(1, res);
|
| + res = reinterpret_cast<ExtractSignBits>(entry)(-0.0);
|
| + EXPECT_EQ(1, res);
|
| +}
|
| +
|
| } // namespace dart
|
|
|
| #endif // defined TARGET_ARCH_X64
|
|
|