trap-1.c, [...]: New tests.
authorHans-Peter Nilsson <hp@axis.com>
Tue, 29 May 2012 01:54:09 +0000 (01:54 +0000)
committerHans-Peter Nilsson <hp@gcc.gnu.org>
Tue, 29 May 2012 01:54:09 +0000 (01:54 +0000)
* gcc.target/cris/torture/trap-1.c,
gcc.target/cris/torture/trap-2.c,
gcc.target/cris/torture/trap-3.c,
gcc.target/cris/torture/trap-v0.c,
gcc.target/cris/torture/trap-v3.c: New tests.

From-SVN: r187943

gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/cris/torture/trap-1.c [new file with mode: 0644]
gcc/testsuite/gcc.target/cris/torture/trap-2.c [new file with mode: 0644]
gcc/testsuite/gcc.target/cris/torture/trap-3.c [new file with mode: 0644]
gcc/testsuite/gcc.target/cris/torture/trap-v0.c [new file with mode: 0644]
gcc/testsuite/gcc.target/cris/torture/trap-v3.c [new file with mode: 0644]

index fa1ef57707400eed8651fc12c02c3f707d7f40b8..b08556c348ac30742c8da261e61a31823c1f77d1 100644 (file)
@@ -1,3 +1,11 @@
+2012-05-29  Hans-Peter Nilsson  <hp@axis.com>
+
+       * gcc.target/cris/torture/trap-1.c,
+       gcc.target/cris/torture/trap-2.c,
+       gcc.target/cris/torture/trap-3.c,
+       gcc.target/cris/torture/trap-v0.c,
+       gcc.target/cris/torture/trap-v3.c: New tests.
+
 2012-05-28  Paolo Carlini  <paolo.carlini@oracle.com>
 
        PR c++/25137
diff --git a/gcc/testsuite/gcc.target/cris/torture/trap-1.c b/gcc/testsuite/gcc.target/cris/torture/trap-1.c
new file mode 100644 (file)
index 0000000..48363fb
--- /dev/null
@@ -0,0 +1,13 @@
+/* Check that "break 8" defaults according to CPU version.  */
+/* { dg-do compile } */
+/* { dg-skip-if "" { "*-*-*" } { "-march*" } { "" } } */
+/* { dg-final { scan-assembler "break 8" { target { ! cris-*-elf } } } } */
+/* { dg-final { scan-assembler-not "bsr" { target { ! cris-*-elf } } } } */
+/* { dg-final { scan-assembler-not "jsr" { target { ! cris-*-elf } } } } */
+/* { dg-final { scan-assembler-not "break\[ \t\]" { target cris-*-elf } } } */
+/* { dg-final { scan-assembler "\[jb\]sr \[_\]\?abort" { target cris-*-elf } } } */
+
+void do_trap (void)
+{
+  __builtin_trap ();
+}
diff --git a/gcc/testsuite/gcc.target/cris/torture/trap-2.c b/gcc/testsuite/gcc.target/cris/torture/trap-2.c
new file mode 100644 (file)
index 0000000..155d5fe
--- /dev/null
@@ -0,0 +1,11 @@
+/* As trap-1.c but forcing on.  */
+/* { dg-do compile } */
+/* { dg-options "-mtrap-using-break8" } */
+/* { dg-final { scan-assembler "break 8" } } */
+/* { dg-final { scan-assembler-not "bsr" } } */
+/* { dg-final { scan-assembler-not "jsr" } } */
+
+void do_trap (void)
+{
+  __builtin_trap ();
+}
diff --git a/gcc/testsuite/gcc.target/cris/torture/trap-3.c b/gcc/testsuite/gcc.target/cris/torture/trap-3.c
new file mode 100644 (file)
index 0000000..dfa0924
--- /dev/null
@@ -0,0 +1,10 @@
+/* Like trap-1.c and trap-2.c but force calls to abort.  */
+/* { dg-do compile } */
+/* { dg-options "-mno-trap-using-break8" } */
+/* { dg-final { scan-assembler-not "break\[ \t\]" } } */
+/* { dg-final { scan-assembler "\[jb\]sr \[_\]\?abort" } } */
+
+void do_trap (void)
+{
+  __builtin_trap ();
+}
diff --git a/gcc/testsuite/gcc.target/cris/torture/trap-v0.c b/gcc/testsuite/gcc.target/cris/torture/trap-v0.c
new file mode 100644 (file)
index 0000000..084fb28
--- /dev/null
@@ -0,0 +1,11 @@
+/* As trap-1.c but with CPU version specified, excluding.  */
+/* { dg-do compile } */
+/* { dg-skip-if "" { "*-*-*" } { "-march=*" } { "" } } */
+/* { dg-options "-march=v0" } */
+/* { dg-final { scan-assembler-not "break\[ \t\]" } } */
+/* { dg-final { scan-assembler "\[jb\]sr \[_\]\?abort" } } */
+
+void do_trap (void)
+{
+  __builtin_trap ();
+}
diff --git a/gcc/testsuite/gcc.target/cris/torture/trap-v3.c b/gcc/testsuite/gcc.target/cris/torture/trap-v3.c
new file mode 100644 (file)
index 0000000..e004c5b
--- /dev/null
@@ -0,0 +1,12 @@
+/* As trap-1.c but with CPU version specified, including.  */
+/* { dg-do compile } */
+/* { dg-skip-if "" { "*-*-*" } { "-march=*" } { "" } } */
+/* { dg-options "-march=v3" } */
+/* { dg-final { scan-assembler "break 8" } } */
+/* { dg-final { scan-assembler-not "bsr" } } */
+/* { dg-final { scan-assembler-not "jsr" } } */
+
+void do_trap (void)
+{
+  __builtin_trap ();
+}