aboutsummaryrefslogtreecommitdiff
path: root/gcc/loop.c
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2001-01-06 15:13:58 -0800
committerRichard Henderson <rth@gcc.gnu.org>2001-01-06 15:13:58 -0800
commit587f56c2413efd99d7813316d01c9321289008dd (patch)
treedb993f2880eb1910cbbfa2e33bf674fe8a9e0234 /gcc/loop.c
parentcd5662732a9ce840e9276d18b080cd38ec1d66a5 (diff)
downloadgcc-587f56c2413efd99d7813316d01c9321289008dd.zip
gcc-587f56c2413efd99d7813316d01c9321289008dd.tar.gz
gcc-587f56c2413efd99d7813316d01c9321289008dd.tar.bz2
loop.c (scan_loop): Use xcalloc for the regs array.
* loop.c (scan_loop): Use xcalloc for the regs array. (load_mems_and_recount_loop_regs_set): Zero the new memory received from xrealloc. From-SVN: r38752
Diffstat (limited to 'gcc/loop.c')
-rw-r--r--gcc/loop.c14
1 files changed, 5 insertions, 9 deletions
diff --git a/gcc/loop.c b/gcc/loop.c
index 347f3c9..e4ef90a3 100644
--- a/gcc/loop.c
+++ b/gcc/loop.c
@@ -627,14 +627,7 @@ scan_loop (loop, flags)
the arrays, if necessary, in load_mems_recount_loop_regs_set. */
regs->size = regs->num + loop_info->mems_idx + 16;
regs->array = (struct loop_reg *)
- xmalloc (regs->size * sizeof (*regs->array));
-
- for (i = 0; i < regs->num; i++)
- {
- regs->array[i].set_in_loop = 0;
- regs->array[i].may_not_optimize = 0;
- regs->array[i].single_usage = NULL_RTX;
- }
+ xcalloc (regs->size, sizeof (*regs->array));
count_loop_regs_set (loop, &insn_count);
@@ -8724,9 +8717,12 @@ load_mems_and_recount_loop_regs_set (loop, insn_count)
/* Grow the array. */
regs->array = (struct loop_reg *)
xrealloc (regs->array, regs->size * sizeof (*regs->array));
+
+ memset (regs->array + old_nregs, 0,
+ (regs->size - old_nregs) * sizeof (*regs->array));
}
- for (i = 0; i < regs->num; i++)
+ for (i = 0; i < old_nregs; i++)
{
regs->array[i].set_in_loop = 0;
regs->array[i].may_not_optimize = 0;