aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJames E Wilson <wilson@specifixinc.com>2004-08-17 21:19:49 +0000
committerJim Wilson <wilson@gcc.gnu.org>2004-08-17 14:19:49 -0700
commit67e90093984469e9d9b8573092e09d5ef47decc5 (patch)
treeadb13dd6ad0625ac186da86faa196dc0ec61df00
parent4ef47bd8e00785f76cdd08aad06c5a7ffe161804 (diff)
downloadgcc-67e90093984469e9d9b8573092e09d5ef47decc5.zip
gcc-67e90093984469e9d9b8573092e09d5ef47decc5.tar.gz
gcc-67e90093984469e9d9b8573092e09d5ef47decc5.tar.bz2
Testcases for mips conditional move patterns.
* 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
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/gcc.dg/mips-movcc-1.c23
-rw-r--r--gcc/testsuite/gcc.dg/mips-movcc-2.c23
-rw-r--r--gcc/testsuite/gcc.dg/mips-movcc-3.c44
4 files changed, 96 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 621d0cf..74abe0e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -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
index 0000000..b433a4d
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/mips-movcc-1.c
@@ -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
index 0000000..d8ea4cc
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/mips-movcc-2.c
@@ -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
index 0000000..9e515fa
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/mips-movcc-3.c
@@ -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;
+}