OSDN Git Service

PR tree-optimization/45903
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 8 Oct 2010 20:49:44 +0000 (20:49 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 8 Oct 2010 20:49:44 +0000 (20:49 +0000)
* simplify-rtx.c (simplify_subreg): Optimize lowpart SUBREG
of *SHIFTRT of MEM.

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

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

gcc/testsuite/gcc.target/i386/pr45903.c [new file with mode: 0644]

diff --git a/gcc/testsuite/gcc.target/i386/pr45903.c b/gcc/testsuite/gcc.target/i386/pr45903.c
new file mode 100644 (file)
index 0000000..5cb642a
--- /dev/null
@@ -0,0 +1,44 @@
+/* PR tree-optimization/45903 */
+/* { dg-do compile } */
+/* { dg-options "-O2" } */
+
+unsigned long long a, b;
+unsigned char c;
+
+void
+f1 (void)
+{
+  c = (a >> 8) + (b >> 8);
+}
+
+void
+f2 (void)
+{
+  c = (a >> 8) | (b >> 8);
+}
+
+void
+f3 (void)
+{
+  c = (a >> 16) ^ (b >> 56);
+}
+
+unsigned char
+f4 (void)
+{
+  return (a >> 48) + (b >> 40);
+}
+
+unsigned char
+f5 (void)
+{
+  return (a >> 32) | (b >> 16);
+}
+
+unsigned char
+f6 (void)
+{
+  return (a >> 24) ^ (b >> 32);
+}
+
+/* { dg-final { scan-assembler-not "shr\[qdl\]" } } */