Testcases for mips conditional move patterns.
authorJames E Wilson <wilson@specifixinc.com>
Tue, 17 Aug 2004 21:19:49 +0000 (21:19 +0000)
committerJim Wilson <wilson@gcc.gnu.org>
Tue, 17 Aug 2004 21:19:49 +0000 (14:19 -0700)
* gcc.dg/mips-movcc-1.c: New test.
* gcc.dg/mips-movcc-2.c: New test.
* gcc.dg/mips-movcc-3.c: New test.

From-SVN: r86146

gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/mips-movcc-1.c [new file with mode: 0644]
gcc/testsuite/gcc.dg/mips-movcc-2.c [new file with mode: 0644]
gcc/testsuite/gcc.dg/mips-movcc-3.c [new file with mode: 0644]

index 621d0cf2969a9b2be56d009e37ef8c87fa9848f1..74abe0e465712e81653de000815bffba56c60df5 100644 (file)
@@ -1,3 +1,9 @@
+2004-08-17  James E Wilson  <wilson@specifixinc.com>
+
+       * gcc.dg/mips-movcc-1.c: New test.
+       * gcc.dg/mips-movcc-2.c: New test.
+       * gcc.dg/mips-movcc-3.c: New test.
+
 2004-08-17  Mark Mitchell  <mark@codesourcery.com>
 
        PR c++/15871
diff --git a/gcc/testsuite/gcc.dg/mips-movcc-1.c b/gcc/testsuite/gcc.dg/mips-movcc-1.c
new file mode 100644 (file)
index 0000000..b433a4d
--- /dev/null
@@ -0,0 +1,23 @@
+/* { dg-do compile { target "mips*-*-*" } } */
+/* { dg-options "-O2 -mips4" } */
+/* { dg-final { scan-assembler "movz" } } */
+/* { dg-final { scan-assembler "movn" } } */
+/* { dg-final { scan-assembler "movt" } } */
+
+int
+sub1 (int i, int j, int k)
+{
+  return k ? i : j;
+}
+
+int
+sub2 (int i, int j, long l)
+{
+  return !l ? i : j;
+}
+
+int
+sub3 (int i, int j, float f)
+{
+  return f ? i : j;
+}
diff --git a/gcc/testsuite/gcc.dg/mips-movcc-2.c b/gcc/testsuite/gcc.dg/mips-movcc-2.c
new file mode 100644 (file)
index 0000000..d8ea4cc
--- /dev/null
@@ -0,0 +1,23 @@
+/* { dg-do compile { target "mips*-*-*" } } */
+/* { dg-options "-O2 -mips4" } */
+/* { dg-final { scan-assembler "movz" } } */
+/* { dg-final { scan-assembler "movn" } } */
+/* { dg-final { scan-assembler "movf" } } */
+
+long
+sub4 (long i, long j, long k)
+{
+  return k ? i : j;
+}
+
+long
+sub5 (long i, long j, int k)
+{
+  return !k ? i : j;
+}
+
+long
+sub6 (long i, long j, float f)
+{
+  return !f ? i : j;
+}
diff --git a/gcc/testsuite/gcc.dg/mips-movcc-3.c b/gcc/testsuite/gcc.dg/mips-movcc-3.c
new file mode 100644 (file)
index 0000000..9e515fa
--- /dev/null
@@ -0,0 +1,44 @@
+/* { dg-do compile { target "mips*-*-*" } } */
+/* { dg-options "-O2 -mips4" } */
+/* { dg-final { scan-assembler "movz.s" } } */
+/* { dg-final { scan-assembler "movn.s" } } */
+/* { dg-final { scan-assembler "movt.s" } } */
+/* { dg-final { scan-assembler "movz.d" } } */
+/* { dg-final { scan-assembler "movn.d" } } */
+/* { dg-final { scan-assembler "movf.d" } } */
+
+float
+sub7 (float f, float g, int i)
+{
+  return i ? f : g;
+}
+
+float
+sub8 (float f, float g, long l)
+{
+  return !l ? f : g;
+}
+
+float
+sub9 (float f, float g, float h)
+{
+  return h ? f : g;
+}
+
+double
+suba (double f, double g, int i)
+{
+  return i ? f : g;
+}
+
+double
+subb (double f, double g, long l)
+{
+  return !l ? f : g;
+}
+
+double
+subc (double f, double g, double h)
+{
+  return !h ? f : g;
+}