From: Michael Hayes Date: Wed, 19 Jan 2000 20:10:00 +0000 (+0000) Subject: loop.c (loop_optimize): Allocate loop_info structure for each loop prior to calling... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=78458962965e06a91c20511ab02f88195d3b6a91;p=gcc.git loop.c (loop_optimize): Allocate loop_info structure for each loop prior to calling scan_loop. * loop.c (loop_optimize): Allocate loop_info structure for each loop prior to calling scan_loop. From-SVN: r31508 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3ccbe76d42a..fff7083ba95 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2000-01-20 Michael Hayes + + * loop.c (loop_optimize): Allocate loop_info structure for each loop + prior to calling scan_loop. + Wed Jan 19 19:54:38 2000 J"orn Rennecke * sh.c (prepare_scc_operands): Abort if no compare insn is available. diff --git a/gcc/loop.c b/gcc/loop.c index d69094f5db8..b52b33a55e5 100644 --- a/gcc/loop.c +++ b/gcc/loop.c @@ -510,15 +510,21 @@ loop_optimize (f, dumpfile, unroll_p, bct_p) this prevents low overhead loop instructions from being used. */ indirect_jump_in_function = indirect_jump_in_function_p (f); - /* Now scan the loops, last ones first, since this means inner ones are done - before outer ones. */ + /* Allocate and initialize auxiliary loop information. */ for (i = max_loop_num - 1; i >= 0; i--) { struct loop *loop = &loops->array[i]; loop->info = (struct loop_info *) alloca (sizeof (struct loop_info)); memset (loop->info, 0, sizeof (struct loop_info)); - + } + + /* Now scan the loops, last ones first, since this means inner ones are done + before outer ones. */ + for (i = max_loop_num - 1; i >= 0; i--) + { + struct loop *loop = &loops->array[i]; + if (! loop->invalid && loop->end) scan_loop (loop, unroll_p, bct_p); }