diff --git a/gcc/ChangeLog b/gcc/ChangeLog index beae01eba75..86b451e1eba 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,8 @@ Mon Nov 29 16:56:42 1999 Richard Kenner + * expr.c (store_constructor_field): If bit position is not multiple + of alignment of TARGET's mode, use BLKmode. + * expr.c (expand_expr_unaligned): Add more code from full case that is needed when OP0 is in a register. diff --git a/gcc/expr.c b/gcc/expr.c index bc6c93fb2bb..91a78e388cf 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -4040,9 +4040,14 @@ store_constructor_field (target, bitsize, bitpos, && (bitpos == 0 || GET_CODE (target) == MEM)) { if (bitpos != 0) - target = change_address (target, VOIDmode, - plus_constant (XEXP (target, 0), - bitpos / BITS_PER_UNIT)); + target + = change_address (target, + GET_MODE (target) == BLKmode + || 0 != (bitpos + % GET_MODE_ALIGNMENT (GET_MODE (target))) + ? BLKmode : VOIDmode, + plus_constant (XEXP (target, 0), + bitpos / BITS_PER_UNIT)); store_constructor (exp, target, align, cleared); } else