Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2155)

Unified Diff: runtime/vm/assembler_x64_test.cc

Issue 10701147: Implement more intrinisification for x64 (not as inlined code but as header of the target). (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 8 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « runtime/vm/assembler_x64.cc ('k') | runtime/vm/intrinsifier_ia32.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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
« no previous file with comments | « runtime/vm/assembler_x64.cc ('k') | runtime/vm/intrinsifier_ia32.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698