]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR rtl-optimization/45903 (unnecessary load of 32/64bit variable when only 8 bits...
authorJakub Jelinek <jakub@redhat.com>
Fri, 8 Oct 2010 20:49:19 +0000 (22:49 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Fri, 8 Oct 2010 20:49:19 +0000 (22:49 +0200)
PR tree-optimization/45903
* simplify-rtx.c (simplify_subreg): Optimize lowpart SUBREG
of *SHIFTRT of MEM.

* gcc.target/i386/pr45903.c: New test.

From-SVN: r165200

gcc/ChangeLog
gcc/simplify-rtx.c
gcc/testsuite/ChangeLog

index be4f9f795cf6ccf02abb6c66078edb3fb3cf1b98..182337f101b31e0e0e05136b34f8045faa9ecf18 100644 (file)
@@ -1,3 +1,9 @@
+2010-10-08  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/45903
+       * simplify-rtx.c (simplify_subreg): Optimize lowpart SUBREG
+       of *SHIFTRT of MEM.
+
 2010-10-08  Richard Guenther  <rguenther@suse.de>
 
        * lto-streamer-in.c (lto_input_ts_decl_minimal_tree_pointers):
index 122c45fdf647417d5802b134f1b60e367f8d2519..ff1437be41bdc4265252aa70bff2de7c20b51a49 100644 (file)
@@ -5482,6 +5482,31 @@ simplify_subreg (enum machine_mode outermode, rtx op,
                                   : byte + shifted_bytes));
     }
 
+  /* If we have a lowpart SUBREG of a right shift of MEM, make a new MEM
+     and try replacing the SUBREG and shift with it.  Don't do this if
+     the MEM has a mode-dependent address or if we would be widening it.  */
+
+  if ((GET_CODE (op) == LSHIFTRT
+       || GET_CODE (op) == ASHIFTRT)
+      && MEM_P (XEXP (op, 0))
+      && CONST_INT_P (XEXP (op, 1))
+      && GET_MODE_SIZE (outermode) < GET_MODE_SIZE (GET_MODE (op))
+      && (INTVAL (XEXP (op, 1)) % GET_MODE_BITSIZE (outermode)) == 0
+      && INTVAL (XEXP (op, 1)) > 0
+      && INTVAL (XEXP (op, 1)) < GET_MODE_BITSIZE (innermode)
+      && ! mode_dependent_address_p (XEXP (XEXP (op, 0), 0))
+      && ! MEM_VOLATILE_P (XEXP (op, 0))
+      && byte == subreg_lowpart_offset (outermode, innermode)
+      && (GET_MODE_SIZE (outermode) >= UNITS_PER_WORD
+         || WORDS_BIG_ENDIAN == BYTES_BIG_ENDIAN))
+    {
+      int shifted_bytes = INTVAL (XEXP (op, 1)) / BITS_PER_UNIT;
+      return adjust_address_nv (XEXP (op, 0), outermode,
+                               (WORDS_BIG_ENDIAN
+                                ? byte - shifted_bytes
+                                : byte + shifted_bytes));
+    }
+
   return NULL_RTX;
 }
 
index 0c4fb410ea8507804ee56d19b96d05c48292486e..dd23413753da756fce1bbf2c701737e326e6cea4 100644 (file)
@@ -1,3 +1,8 @@
+2010-10-08  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/45903
+       * gcc.target/i386/pr45903.c: New test.
+
 2010-10-08  Arnaud Charlet  <charlet@adacore.com>
 
        * gnat.dg/interface5.adb: Compile with warnings disabled.