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/expr.c | |
| 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/expr.c')
| -rw-r--r-- | gcc/expr.c | 7 |
1 files changed, 5 insertions, 2 deletions
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 |

