re PR target/25718 (invalid assembly for unsigned-minimum expressions.)
authorHans-Peter Nilsson <hp@axis.com>
Tue, 10 Jan 2006 18:14:42 +0000 (18:14 +0000)
committerHans-Peter Nilsson <hp@gcc.gnu.org>
Tue, 10 Jan 2006 18:14:42 +0000 (18:14 +0000)
PR target/25718
* gcc.dg/torture/pr25718-1.c: New test.

From-SVN: r109549

gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/torture/pr25718-1.c [new file with mode: 0644]

index 6d9f4286f761cc6b783b5f0d9e37e10e8c74f426..b8d1bba48c5995b93f4e691a8f41113de1a68792 100644 (file)
@@ -1,3 +1,8 @@
+2006-01-10  Hans-Peter Nilsson  <hp@axis.com>
+
+       PR target/25718
+       * gcc.dg/torture/pr25718-1.c: New test.
+
 2006-01-10  Bernhard Fischer  <rep.nop@aon.at>
 
        * gfortran.dg/list_read_2.f90: Fix typo in description.
diff --git a/gcc/testsuite/gcc.dg/torture/pr25718-1.c b/gcc/testsuite/gcc.dg/torture/pr25718-1.c
new file mode 100644 (file)
index 0000000..8333a33
--- /dev/null
@@ -0,0 +1,27 @@
+/* { dg-do run } */
+/* PR 25718: invalid constant operand to the "bound" insn; error at
+   assembly time.  We'll make sure the code is correct to: run a few
+   example values.  */
+
+extern void exit (int);
+extern void abort (void);
+unsigned __attribute__ ((__noinline__)) foo(unsigned a)
+{
+  unsigned l;
+  l = (a >= (~0u - 512) ? (~0u - 512) : a);
+  return l;
+}
+
+int
+main (void)
+{
+  if (foo ((unsigned) -512) != (unsigned) -513
+      || foo ((unsigned) -514) != (unsigned) -514
+      || foo ((unsigned) -513) != (unsigned) -513
+      || foo ((unsigned) -1) != (unsigned) -513
+      || foo (513) != 513
+      || foo (0) != 0)
+    abort ();
+
+  exit (0);
+}