aboutsummaryrefslogtreecommitdiff
path: root/gcc/expmed.c
diff options
context:
space:
mode:
authorRoman Zippel <zippel@linux-m68k.org>2001-08-27 22:43:37 +0000
committerRichard Henderson <rth@gcc.gnu.org>2001-08-27 15:43:37 -0700
commitf21bdd05bdbac16e29fbc663731f6dfacb74dbd8 (patch)
tree4e1f4a225bb3680339d4e0a49ce1ce791bf90dc2 /gcc/expmed.c
parenta224278b115a7a5324313185817f27ca21ee11f4 (diff)
downloadgcc-f21bdd05bdbac16e29fbc663731f6dfacb74dbd8.zip
gcc-f21bdd05bdbac16e29fbc663731f6dfacb74dbd8.tar.gz
gcc-f21bdd05bdbac16e29fbc663731f6dfacb74dbd8.tar.bz2
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
Diffstat (limited to 'gcc/expmed.c')
-rw-r--r--gcc/expmed.c6
1 files changed, 3 insertions, 3 deletions
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)
{