summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authoraoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4>2007-10-15 17:07:20 +0000
committeraoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4>2007-10-15 17:07:20 +0000
commite782a3103d62909b6c94c7957de5274666be4d66 (patch)
treeb276d85de8d5be7b2524553d3b57869d69c66a04 /gcc
parent58047c1717785b31671bb3495ccd64926d36f0f3 (diff)
downloadgcc-e782a3103d62909b6c94c7957de5274666be4d66.tar.gz
gcc/ChangeLog:
PR tree-optimization/33735 PR tree-optimization/33572 * tree-inline.c (update_ssa_across_abnormal_edges): Revert 2007-10-09's change. * except.c (duplicate_eh_regions): Don't look for prev_try beyond ERT_ALLOWED_EXCEPTIONS with an empty list. gcc/testsuite/ChangeLog: PR tree-optimization/33735 * g++.dg/torture/pr33735.C: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@129356 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog9
-rw-r--r--gcc/except.c4
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/torture/pr33735.C21
-rw-r--r--gcc/tree-inline.c3
5 files changed, 39 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f627ef7d157..2348ecc9843 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,14 @@
2007-10-15 Alexandre Oliva <aoliva@redhat.com>
+ PR tree-optimization/33735
+ PR tree-optimization/33572
+ * tree-inline.c (update_ssa_across_abnormal_edges): Revert
+ 2007-10-09's change.
+ * except.c (duplicate_eh_regions): Don't look for prev_try
+ beyond ERT_ALLOWED_EXCEPTIONS with an empty list.
+
+2007-10-15 Alexandre Oliva <aoliva@redhat.com>
+
PR middle-end/33706
* tree-inline.c (copy_bb): Use bsi_replace to replace a
__builtin_va_arg_pack-containing call stmt.
diff --git a/gcc/except.c b/gcc/except.c
index fe98299450d..0fbda613961 100644
--- a/gcc/except.c
+++ b/gcc/except.c
@@ -1005,7 +1005,9 @@ duplicate_eh_regions (struct function *ifun, duplicate_eh_regions_map map,
for (prev_try = VEC_index (eh_region, cfun->eh->region_array, outer_region);
prev_try && prev_try->type != ERT_TRY;
prev_try = prev_try->outer)
- if (prev_try->type == ERT_MUST_NOT_THROW)
+ if (prev_try->type == ERT_MUST_NOT_THROW
+ || (prev_try->type == ERT_ALLOWED_EXCEPTIONS
+ && !prev_try->u.allowed.type_list))
{
prev_try = NULL;
break;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 7f09cddb89c..12b8cba6cb2 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2007-10-15 Alexandre Oliva <aoliva@redhat.com>
+ PR tree-optimization/33735
+ * g++.dg/torture/pr33735.C: New.
+
+2007-10-15 Alexandre Oliva <aoliva@redhat.com>
+
PR middle-end/33706
* gcc.dg/va-arg-pack-2.c: New.
diff --git a/gcc/testsuite/g++.dg/torture/pr33735.C b/gcc/testsuite/g++.dg/torture/pr33735.C
new file mode 100644
index 00000000000..0a90745b91e
--- /dev/null
+++ b/gcc/testsuite/g++.dg/torture/pr33735.C
@@ -0,0 +1,21 @@
+// { dg-do compile }
+#include <string>
+typedef struct _ts { } PyThreadState;
+PyThreadState * Py_NewInterpreter(void);
+void Py_EndInterpreter(PyThreadState *);
+class ApplicationError {
+public:
+ ApplicationError(std::string errormsg) : errormsg(errormsg) { }
+ std::string errormsg;
+};
+void run()
+{
+ PyThreadState *py_state=__null;
+ try {
+ if (!(py_state=Py_NewInterpreter()))
+ throw ApplicationError("error");
+ }
+ catch(ApplicationError e) {
+ Py_EndInterpreter(py_state);
+ }
+}
diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c
index 7ebfbcd4a6c..55aef3d5c6e 100644
--- a/gcc/tree-inline.c
+++ b/gcc/tree-inline.c
@@ -1064,8 +1064,7 @@ update_ssa_across_abnormal_edges (basic_block bb, basic_block ret_bb,
}
re = find_edge (ret_bb, e->dest);
- if (!re)
- continue;
+ gcc_assert (re);
gcc_assert ((re->flags & (EDGE_EH | EDGE_ABNORMAL))
== (e->flags & (EDGE_EH | EDGE_ABNORMAL)));