re PR tree-optimization/54386 (Unaligned mem load wrongly generated for inlined inlin...
authorOleg Endo <olegendo@gcc.gnu.org>
Mon, 4 Feb 2013 22:41:44 +0000 (22:41 +0000)
committerOleg Endo <olegendo@gcc.gnu.org>
Mon, 4 Feb 2013 22:41:44 +0000 (22:41 +0000)
PR tree-optimization/54386
* gcc.target/sh/pr54386.c: New.

From-SVN: r195742

gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/sh/pr54386.c [new file with mode: 0644]

index 548ccc12e64271ddd6fc54e013803d637a22cafc..29f0281b47633fa7fe0f679e473b093b8b790392 100644 (file)
@@ -1,3 +1,8 @@
+2012-02-04  Oleg Endo  <olegendo@gcc.gnu.org>
+
+       PR tree-optimization/54386
+       * gcc.target/sh/pr54386.c: New.
+
 2013-02-04  Paul Thomas  <pault@gcc.gnu.org>
 
        PR fortran/56008
diff --git a/gcc/testsuite/gcc.target/sh/pr54386.c b/gcc/testsuite/gcc.target/sh/pr54386.c
new file mode 100644 (file)
index 0000000..4e17f37
--- /dev/null
@@ -0,0 +1,41 @@
+/* Check that the inlined mem load is not handled as unaligned load.  */
+/* { dg-do compile { target "sh*-*-*" } } */
+/* { dg-options "-O2" } */
+/* { dg-skip-if "" { "sh*-*-*" } { "-m5*"} { "" } }  */
+/* { dg-final { scan-assembler-not "shll|extu|or" } } */
+
+static inline int
+readint0 (int* x)
+{
+  return *x;
+}
+
+int
+test0 (int* x)
+{
+  return readint0 (x);
+}
+
+inline int
+readint1 (int* x)
+{
+  return *x;
+}
+
+int
+test1 (int* x)
+{
+  return readint1 (x);
+}
+
+static int
+readint2 (int* x)
+{
+  return *x;
+}
+
+int
+test2 (int* x)
+{
+  return readint2 (x);
+}