OSDN Git Service

* expmed.c (store_bit_field): Update to patch from 2001-08-27:
authorrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 31 Aug 2001 22:54:19 +0000 (22:54 +0000)
committerrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 31 Aug 2001 22:54:19 +0000 (22:54 +0000)
        move adjustment of bitpos instead.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@45338 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/expmed.c

index 77be0dc..e03aa81 100644 (file)
@@ -1,3 +1,8 @@
+2001-08-30  Roman Zippel  <zippel@linux-m68k.org>
+
+       * expmed.c (store_bit_field): Update to patch from 2001-08-27:
+       move adjustment of bitpos instead.
+
 2001-08-31  Zack Weinberg  <zack@codesourcery.com>
 
        * function.c: Remove all_functions.  Make outer_function_chain
index af5e56f..8bc66b2 100644 (file)
@@ -330,14 +330,6 @@ store_bit_field (str_rtx, bitsize, bitnum, fieldmode, value, align, total_size)
       op0 = SUBREG_REG (op0);
     }
 
-  /* If OP0 is a register, BITPOS must count within a word.
-     But as we have it, it counts within whatever size OP0 now has.
-     On a bigendian machine, these are not the same, so convert.  */
-  if (BYTES_BIG_ENDIAN
-      && GET_CODE (op0) != MEM
-      && unit > GET_MODE_BITSIZE (GET_MODE (op0)))
-    bitpos += unit - GET_MODE_BITSIZE (GET_MODE (op0));
-
   value = protect_from_queue (value, 0);
 
   if (flag_force_mem)
@@ -350,7 +342,7 @@ 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 (bitnum == 0
+  if (bitpos == 0
       && bitsize == GET_MODE_BITSIZE (fieldmode)
       && (GET_CODE (op0) != MEM
          ? (GET_MODE_SIZE (fieldmode) >= UNITS_PER_WORD
@@ -401,6 +393,14 @@ store_bit_field (str_rtx, bitsize, bitnum, fieldmode, value, align, total_size)
       }
   }
 
+  /* If OP0 is a register, BITPOS must count within a word.
+     But as we have it, it counts within whatever size OP0 now has.
+     On a bigendian machine, these are not the same, so convert.  */
+  if (BYTES_BIG_ENDIAN
+      && GET_CODE (op0) != MEM
+      && unit > GET_MODE_BITSIZE (GET_MODE (op0)))
+    bitpos += unit - GET_MODE_BITSIZE (GET_MODE (op0));
+
   /* Storing an lsb-aligned field in a register
      can be done with a movestrict instruction.  */