From f21bdd05bdbac16e29fbc663731f6dfacb74dbd8 Mon Sep 17 00:00:00 2001 From: Roman Zippel Date: Mon, 27 Aug 2001 22:43:37 +0000 Subject: expmed.c (store_bit_field): Ignore adjustment to bitpos and use bitnum to decide about register move. * expmed.c (store_bit_field): Ignore adjustment to bitpos and use bitnum to decide about register move. From-SVN: r45215 --- gcc/expmed.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'gcc/expmed.c') diff --git a/gcc/expmed.c b/gcc/expmed.c index 7cbc857..af5e56f 100644 --- a/gcc/expmed.c +++ b/gcc/expmed.c @@ -350,14 +350,14 @@ store_bit_field (str_rtx, bitsize, bitnum, fieldmode, value, align, total_size) done with a simple store. For targets that support fast unaligned memory, any naturally sized, unit aligned field can be done directly. */ - if (bitsize == GET_MODE_BITSIZE (fieldmode) + if (bitnum == 0 + && bitsize == GET_MODE_BITSIZE (fieldmode) && (GET_CODE (op0) != MEM ? (GET_MODE_SIZE (fieldmode) >= UNITS_PER_WORD || GET_MODE_SIZE (GET_MODE (op0)) == GET_MODE_SIZE (fieldmode)) : (! SLOW_UNALIGNED_ACCESS (fieldmode, align) || (offset * BITS_PER_UNIT % bitsize == 0 - && align % GET_MODE_BITSIZE (fieldmode) == 0))) - && (BYTES_BIG_ENDIAN ? bitpos + bitsize == unit : bitpos == 0)) + && align % GET_MODE_BITSIZE (fieldmode) == 0)))) { if (GET_MODE (op0) != fieldmode) { -- cgit v1.1