aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Kenner <kenner@vlsi1.ultra.nyu.edu>2001-06-28 10:16:03 +0000
committerRichard Kenner <kenner@gcc.gnu.org>2001-06-28 06:16:03 -0400
commiteeb35b4552717ded7a8e006854be6766bb6237c4 (patch)
tree77bfa163e04d00aa941a0bb95c24b4d8e77db81c /gcc
parentb9b2c339633c658046d481aa0db0d3c1008a4595 (diff)
downloadgcc-eeb35b4552717ded7a8e006854be6766bb6237c4.zip
gcc-eeb35b4552717ded7a8e006854be6766bb6237c4.tar.gz
gcc-eeb35b4552717ded7a8e006854be6766bb6237c4.tar.bz2
expr.c (expand_assignment): When have varying-length object, make MEM a BLKmode.
* expr.c (expand_assignment): When have varying-length object, make MEM a BLKmode. (expand_expr, case ADDR_EXPR): Use SAVE_EXPR_RTL after putting SAVE_EXPR stack in case we had a SUBREG. From-SVN: r43637
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/expr.c7
2 files changed, 12 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 2784e01..1d811e2 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+Thu Jun 28 06:16:45 2001 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
+
+ * expr.c (expand_assignment): When have varying-length object,
+ make MEM a BLKmode.
+ (expand_expr, case ADDR_EXPR): Use SAVE_EXPR_RTL after putting
+ SAVE_EXPR stack in case we had a SUBREG.
+
Thu Jun 28 10:31:06 CEST 2001 Jan Hubicka <jh@suse.cz>
* i386.md (cmp?i): Simplify; refuse immediate operand
diff --git a/gcc/expr.c b/gcc/expr.c
index 4031cab..c5276f2 100644
--- a/gcc/expr.c
+++ b/gcc/expr.c
@@ -3810,7 +3810,7 @@ expand_assignment (to, from, want_value, suggest_reg)
unsigned int from_align;
rtx from_rtx = expand_expr_unaligned (from, &from_align);
rtx inner_to_rtx
- = change_address (to_rtx, VOIDmode,
+ = change_address (to_rtx, BLKmode,
plus_constant (XEXP (to_rtx, 0),
bitpos / BITS_PER_UNIT));
@@ -7039,7 +7039,10 @@ expand_expr (exp, target, tmode, modifier)
/* If the operand is a SAVE_EXPR, we can deal with this by
forcing the SAVE_EXPR into memory. */
if (TREE_CODE (TREE_OPERAND (exp, 0)) == SAVE_EXPR)
- put_var_into_stack (TREE_OPERAND (exp, 0));
+ {
+ put_var_into_stack (TREE_OPERAND (exp, 0));
+ op0 = SAVE_EXPR_RTL (TREE_OPERAND (exp, 0));
+ }
else
{
tree nt