aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorSteve Ellcey <sellcey@imgtec.com>2015-12-07 20:39:04 +0000
committerSteve Ellcey <sje@gcc.gnu.org>2015-12-07 20:39:04 +0000
commitbcaddce275310a711890b4a39b6834d642d94d6c (patch)
tree2f3e0384df7d3b4f15916eb1420fe7fa3b8efbcd /gcc
parent1167d047bce1b342c82f18195247d218942b0262 (diff)
downloadgcc-bcaddce275310a711890b4a39b6834d642d94d6c.zip
gcc-bcaddce275310a711890b4a39b6834d642d94d6c.tar.gz
gcc-bcaddce275310a711890b4a39b6834d642d94d6c.tar.bz2
wrap-delay.c: New test.
2015-12-07 Steve Ellcey <sellcey@imgtec.com> * gcc.target/mips/wrap-delay.c: New test. From-SVN: r231383
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.target/mips/wrap-delay.c42
2 files changed, 46 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 7088835..9361cee 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2015-12-07 Steve Ellcey <sellcey@imgtec.com>
+
+ * gcc.target/mips/wrap-delay.c: New test.
+
2015-12-07 Jason Merrill <jason@redhat.com>
* lib/g++.exp: Also find -std list in GXX_TESTSUITE_STDS
diff --git a/gcc/testsuite/gcc.target/mips/wrap-delay.c b/gcc/testsuite/gcc.target/mips/wrap-delay.c
new file mode 100644
index 0000000..1332a68
--- /dev/null
+++ b/gcc/testsuite/gcc.target/mips/wrap-delay.c
@@ -0,0 +1,42 @@
+/* { dg-do compile } */
+/* { dg-options "-g -mframe-header-opt -mbranch-likely" } */
+
+/* GCC was generating an ICE with the above options and -Os because
+ it was putting the save of $31 in two annulled delay slots but
+ there was only one restore since only one of the two saves could be
+ executed. This was correct code but it confused dwarf2cfi and
+ caused it to ICE when using the -g option. */
+
+
+enum demangle_component_type
+{
+ DEMANGLE_COMPONENT_TRINARY_ARG2,
+};
+struct demangle_component
+{
+ enum demangle_component_type type;
+};
+struct d_info
+{
+ int next_comp;
+ int num_comps;
+};
+struct demangle_component * d_make_empty (struct d_info *di)
+{
+ if (di->next_comp >= di->num_comps) return ((void *)0);
+ ++di->next_comp;
+}
+struct demangle_component *d_make_comp (
+ struct d_info *di,
+ enum demangle_component_type type,
+ struct demangle_component *left)
+{
+ struct demangle_component *p;
+ switch (type)
+ {
+ case DEMANGLE_COMPONENT_TRINARY_ARG2:
+ if (left == ((void *)0)) return ((void *)0);
+ }
+ p = d_make_empty (di);
+ p->type = type;
+}