diff options
author | Richard Henderson <rth@redhat.com> | 2001-01-06 15:13:58 -0800 |
---|---|---|
committer | Richard Henderson <rth@gcc.gnu.org> | 2001-01-06 15:13:58 -0800 |
commit | 587f56c2413efd99d7813316d01c9321289008dd (patch) | |
tree | db993f2880eb1910cbbfa2e33bf674fe8a9e0234 /gcc/loop.c | |
parent | cd5662732a9ce840e9276d18b080cd38ec1d66a5 (diff) | |
download | gcc-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.c | 14 |
1 files changed, 5 insertions, 9 deletions
@@ -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; |