[Bug bootstrap/14671] [3.3/3.4 regression] caller-save.c:491: int
John David Anglin
dave@hiauly1.hia.nrc.ca
Fri May 28 05:14:00 GMT 2004
> | This appears to be because alias_invariant was not GC allocated. I
> | think the patch that I posted earlier today will fix this. It's basically
> | the same as that applied to the trunk except that in 3.3 the arrays are
> | over allocated to allow for expansion during loop_optimize.
>
> Thanks for the additional information. Please could you give me a
> link to the patch that you proposed for 3.3.x? Thanks.
Here is the patch that I propose. It uses ggc_alloc_cleared because
the multiplication is already done in init_alias_analysis. I have
added the "rtx *" cast for K&R compatibility.
I have built the testcase provided with PR15660 and the current version
of the pooma-2.4.0 with -O2 -funroll-loops. However, the triggering
of collection probably depends on the amount of memory in the test
machine. So, Richard should test the patch and see if it resolves
his PR.
I've done a complete bootstrap with no regressions on hppa-unknown-linux-gnu.
A full build of all languages except treelang has just completed on
i686-pc-linux-gnu. I will start a check.
A similar fix is needed for 3.4.
Dave
--
J. David Anglin dave.anglin@nrc-cnrc.gc.ca
National Research Council of Canada (613) 990-0752 (FAX: 952-6602)
2004-05-27 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
PR bootstrap/14671
* alias.c (init_alias_analysis): Allocate alias_invariant array with
ggc_alloc_cleared instead of xrealloc.
(end_alias_analysis): Don't free alias_invariant.
Index: alias.c
===================================================================
RCS file: /cvs/gcc/gcc/gcc/alias.c,v
retrieving revision 1.181.2.5
diff -u -3 -p -r1.181.2.5 alias.c
--- alias.c 8 May 2004 21:52:42 -0000 1.181.2.5
+++ alias.c 27 May 2004 21:07:12 -0000
@@ -2786,10 +2786,8 @@ init_alias_analysis ()
reg_seen = (char *) xmalloc (reg_base_value_size);
if (! reload_completed && flag_unroll_loops)
{
- /* ??? Why are we realloc'ing if we're just going to zero it? */
- alias_invariant = (rtx *)xrealloc (alias_invariant,
- reg_base_value_size * sizeof (rtx));
- memset ((char *)alias_invariant, 0, reg_base_value_size * sizeof (rtx));
+ alias_invariant = (rtx *) ggc_alloc_cleared (reg_base_value_size
+ * sizeof (rtx));
alias_invariant_size = reg_base_value_size;
}
@@ -2985,7 +2983,6 @@ end_alias_analysis ()
reg_base_value_size = 0;
if (alias_invariant)
{
- free (alias_invariant);
alias_invariant = 0;
alias_invariant_size = 0;
}
More information about the Gcc-patches
mailing list