Commit 1432b19f by Alexandre Oliva Committed by Alexandre Oliva

re PR tree-optimization/33735 (verify_stmts failed: missing PHI def)

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.

From-SVN: r129356
parent aa792834
2007-10-15 Alexandre Oliva <aoliva@redhat.com> 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 PR middle-end/33706
* tree-inline.c (copy_bb): Use bsi_replace to replace a * tree-inline.c (copy_bb): Use bsi_replace to replace a
__builtin_va_arg_pack-containing call stmt. __builtin_va_arg_pack-containing call stmt.
...@@ -1005,7 +1005,9 @@ duplicate_eh_regions (struct function *ifun, duplicate_eh_regions_map map, ...@@ -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); for (prev_try = VEC_index (eh_region, cfun->eh->region_array, outer_region);
prev_try && prev_try->type != ERT_TRY; prev_try && prev_try->type != ERT_TRY;
prev_try = prev_try->outer) 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; prev_try = NULL;
break; break;
......
2007-10-15 Alexandre Oliva <aoliva@redhat.com> 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 PR middle-end/33706
* gcc.dg/va-arg-pack-2.c: New. * gcc.dg/va-arg-pack-2.c: New.
// { 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);
}
}
...@@ -1064,8 +1064,7 @@ update_ssa_across_abnormal_edges (basic_block bb, basic_block ret_bb, ...@@ -1064,8 +1064,7 @@ update_ssa_across_abnormal_edges (basic_block bb, basic_block ret_bb,
} }
re = find_edge (ret_bb, e->dest); re = find_edge (ret_bb, e->dest);
if (!re) gcc_assert (re);
continue;
gcc_assert ((re->flags & (EDGE_EH | EDGE_ABNORMAL)) gcc_assert ((re->flags & (EDGE_EH | EDGE_ABNORMAL))
== (e->flags & (EDGE_EH | EDGE_ABNORMAL))); == (e->flags & (EDGE_EH | EDGE_ABNORMAL)));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment