diff options
| author | kenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-06-28 10:16:03 +0000 |
|---|---|---|
| committer | kenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-06-28 10:16:03 +0000 |
| commit | 1ec36ac90e362c372d7ab3d5ebff29a8d4d99c00 (patch) | |
| tree | 77bfa163e04d00aa941a0bb95c24b4d8e77db81c /gcc | |
| parent | d62d9931f242931a9afbf85b7ef4a1350cb8fd6a (diff) | |
| download | ppe42-gcc-1ec36ac90e362c372d7ab3d5ebff29a8d4d99c00.tar.gz ppe42-gcc-1ec36ac90e362c372d7ab3d5ebff29a8d4d99c00.zip | |
* 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.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@43637 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
| -rw-r--r-- | gcc/ChangeLog | 7 | ||||
| -rw-r--r-- | gcc/expr.c | 7 |
2 files changed, 12 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2784e01aa6a..1d811e23fb2 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 4031cab1635..c5276f2556e 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 |

