Commit 134c2de3 by Jakub Jelinek Committed by Jakub Jelinek

re PR middle-end/34934 (-O1 crash compile *** glibc detected ***…

re PR middle-end/34934 (-O1 crash compile *** glibc detected *** /usr/lib/gcc/i486-linux-gnu/4.2.3/cc1: double free or corruption (!prev))

	PR middle-end/34934
	* tree-stdarg.c (reachable_at_most_once): Use VEC vector instead of
	a fixed vector for stack.

	* gcc.c-torture/compile/20080124-1.c: New test.

From-SVN: r131780
parent 160b8b80
2008-01-24 Jakub Jakub Jelinek <jakub@redhat.com>
PR middle-end/34934
* tree-stdarg.c (reachable_at_most_once): Use VEC vector instead of
a fixed vector for stack.
2008-01-24 Ben Elliston <bje@au.ibm.com> 2008-01-24 Ben Elliston <bje@au.ibm.com>
PR c++/25701 PR c++/25701
......
2008-01-24 Jakub Jakub Jelinek <jakub@redhat.com>
PR middle-end/34934
* gcc.c-torture/compile/20080124-1.c: New test.
2008-01-24 Paul Thomas <pault@gcc.gnu.org> 2008-01-24 Paul Thomas <pault@gcc.gnu.org>
PR fortran/34872 PR fortran/34872
/* PR middle-end/34934 */
#include <stdarg.h>
typedef struct
{
int e[1024];
int f;
} S;
void foo (long *, va_list);
void
bar (long *x, S *y, int z, ...)
{
int i, j;
va_list ap;
va_start (ap, z);
for (j = y->e[i = 1]; i <= y->f; j = y->e[++i])
{
switch (z)
{
case 1:
if (!(*x & 0x00000020))
continue;
case 3:
if (!(*x & 0x00000080))
continue;
case 9:
if (!(*x & 0x04000000))
continue;
case 4:
if (!(*x & 0x00000200))
continue;
case 8:
if (!(*x & 0x00100000))
continue;
case 6:
if (!(*x & 0x00000100))
continue;
case 7:
if (!(*x & 0x00040000))
continue;
case 10:
if (!(*x & 0x00000020)
&& ((*x & 0x00008000) || (*x & 0x08000000)))
continue;
}
foo (x, ap);
}
va_end (ap);
}
/* Pass computing data for optimizing stdarg functions. /* Pass computing data for optimizing stdarg functions.
Copyright (C) 2004, 2005, 2007 Free Software Foundation, Inc. Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
Contributed by Jakub Jelinek <jakub@redhat.com> Contributed by Jakub Jelinek <jakub@redhat.com>
This file is part of GCC. This file is part of GCC.
...@@ -46,9 +46,9 @@ along with GCC; see the file COPYING3. If not see ...@@ -46,9 +46,9 @@ along with GCC; see the file COPYING3. If not see
static bool static bool
reachable_at_most_once (basic_block va_arg_bb, basic_block va_start_bb) reachable_at_most_once (basic_block va_arg_bb, basic_block va_start_bb)
{ {
edge *stack, e; VEC (edge, heap) *stack = NULL;
edge e;
edge_iterator ei; edge_iterator ei;
int sp;
sbitmap visited; sbitmap visited;
bool ret; bool ret;
...@@ -58,22 +58,18 @@ reachable_at_most_once (basic_block va_arg_bb, basic_block va_start_bb) ...@@ -58,22 +58,18 @@ reachable_at_most_once (basic_block va_arg_bb, basic_block va_start_bb)
if (! dominated_by_p (CDI_DOMINATORS, va_arg_bb, va_start_bb)) if (! dominated_by_p (CDI_DOMINATORS, va_arg_bb, va_start_bb))
return false; return false;
stack = XNEWVEC (edge, n_basic_blocks + 1);
sp = 0;
visited = sbitmap_alloc (last_basic_block); visited = sbitmap_alloc (last_basic_block);
sbitmap_zero (visited); sbitmap_zero (visited);
ret = true; ret = true;
FOR_EACH_EDGE (e, ei, va_arg_bb->preds) FOR_EACH_EDGE (e, ei, va_arg_bb->preds)
stack[sp++] = e; VEC_safe_push (edge, heap, stack, e);
while (sp) while (! VEC_empty (edge, stack))
{ {
basic_block src; basic_block src;
--sp; e = VEC_pop (edge, stack);
e = stack[sp];
src = e->src; src = e->src;
if (e->flags & EDGE_COMPLEX) if (e->flags & EDGE_COMPLEX)
...@@ -98,11 +94,11 @@ reachable_at_most_once (basic_block va_arg_bb, basic_block va_start_bb) ...@@ -98,11 +94,11 @@ reachable_at_most_once (basic_block va_arg_bb, basic_block va_start_bb)
{ {
SET_BIT (visited, src->index); SET_BIT (visited, src->index);
FOR_EACH_EDGE (e, ei, src->preds) FOR_EACH_EDGE (e, ei, src->preds)
stack[sp++] = e; VEC_safe_push (edge, heap, stack, e);
} }
} }
free (stack); VEC_free (edge, heap, stack);
sbitmap_free (visited); sbitmap_free (visited);
return ret; return ret;
} }
......
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