diff options
author | Richard Kenner <kenner@vlsi1.ultra.nyu.edu> | 2002-02-16 18:44:14 +0000 |
---|---|---|
committer | Richard Kenner <kenner@gcc.gnu.org> | 2002-02-16 13:44:14 -0500 |
commit | 725e58b1b6b9e59bfb05d08572210ae1050fe232 (patch) | |
tree | c71c53ccc676e9349b0b92e81be55ef57bf72b72 | |
parent | 7f311f637fb7a5aaf375d78c7f585bc4c43665dc (diff) | |
download | gcc-725e58b1b6b9e59bfb05d08572210ae1050fe232.zip gcc-725e58b1b6b9e59bfb05d08572210ae1050fe232.tar.gz gcc-725e58b1b6b9e59bfb05d08572210ae1050fe232.tar.bz2 |
* expr.c (store_constructor): Handle target REG case for ARRAY_TYPE.
From-SVN: r49805
-rw-r--r-- | gcc/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/expr.c | 7 |
2 files changed, 10 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 73f2033..0481a6e 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +Sat Feb 16 13:39:09 2002 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * expr.c (store_constructor): Handle target REG case for ARRAY_TYPE. + 2002-02-16 Ulrich Weigand <uweigand@de.ibm.com> * config/s390/s390.c (pool_stop_uid, other_chunk, far_away, @@ -4617,7 +4617,12 @@ store_constructor (exp, target, cleared, size) if (need_to_clear && size > 0) { if (! cleared) - clear_storage (target, GEN_INT (size)); + { + if (REG_P (target)) + emit_move_insn (target, CONST0_RTX (GET_MODE (target))); + else + clear_storage (target, GEN_INT (size)); + } cleared = 1; } else if (REG_P (target)) |