Add -Wdisabled-optimization to loop prefetching pass (PR tree-optimization/79803).
authorMartin Liska <mliska@suse.cz>
Fri, 3 Mar 2017 11:53:56 +0000 (12:53 +0100)
committerMartin Liska <marxin@gcc.gnu.org>
Fri, 3 Mar 2017 11:53:56 +0000 (11:53 +0000)
2017-03-03  Martin Liska  <mliska@suse.cz>

PR tree-optimization/79803
* tree-ssa-loop-prefetch.c (tree_ssa_prefetch_arrays): Remove
assert.
(pass_loop_prefetch::execute): Disabled optimization if an
assumption about L1 cache size is not met.
2017-03-03  Martin Liska  <mliska@suse.cz>

PR tree-optimization/79803
* gcc.dg/tree-ssa/pr79803.c: New test.

From-SVN: r245869

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/tree-ssa/pr79803.c [new file with mode: 0644]
gcc/tree-ssa-loop-prefetch.c

index 1617bc1a1541708aeeb9cf59c6206bfa6aede4b6..68a03df81c9d8be3482cdb9262f7e506af172e11 100644 (file)
@@ -1,3 +1,11 @@
+2017-03-03  Martin Liska  <mliska@suse.cz>
+
+       PR tree-optimization/79803
+       * tree-ssa-loop-prefetch.c (tree_ssa_prefetch_arrays): Remove
+       assert.
+       (pass_loop_prefetch::execute): Disabled optimization if an
+       assumption about L1 cache size is not met.
+
 2017-03-03  Martin Liska  <mliska@suse.cz>
 
        PR rtl-optimization/79574
index 6f59a450b1d8e123eb962d8fdde5874bec1b3ac9..a1586282379f2db8aa3a41871c022a7b59ce0272 100644 (file)
@@ -1,3 +1,8 @@
+2017-03-03  Martin Liska  <mliska@suse.cz>
+
+       PR tree-optimization/79803
+       * gcc.dg/tree-ssa/pr79803.c: New test.
+
 2017-03-03  Martin Liska  <mliska@suse.cz>
 
        PR rtl-optimization/79574
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr79803.c b/gcc/testsuite/gcc.dg/tree-ssa/pr79803.c
new file mode 100644 (file)
index 0000000..51b245d
--- /dev/null
@@ -0,0 +1,60 @@
+/* { dg-do compile { target { x86_64-*-* } } } */
+/* { dg-options "-march=opteron-sse3 -Ofast --param l1-cache-line-size=3 -Wdisabled-optimization" } */
+/* { dg-require-effective-target indirect_jumps } */
+
+#include <setjmp.h>
+
+extern void abort (void);
+
+jmp_buf buf;
+
+void raise0(void)
+{
+  __builtin_longjmp (buf, 1);
+}
+
+int execute(int cmd) /* { dg-warning "'l1-cache-size' parameter is not a power of two 3" } */
+{
+  int last = 0;
+
+  if (__builtin_setjmp (buf) == 0)
+    while (1)
+      {
+       last = 1;
+       raise0 ();
+      }
+
+  if (last == 0)
+    return 0;
+  else
+    return cmd;
+}
+
+int execute2(int cmd, int cmd2)
+{
+  int last = 0;
+
+  if (__builtin_setjmp (buf) == 0)
+    while (1)
+      {
+       last = 1;
+       raise0 ();
+      }
+
+  if (last == 0)
+    return 0;
+  else
+    return cmd;
+}
+
+
+int main(void)
+{
+  if (execute (1) == 0)
+    abort ();
+
+  if (execute2 (1, 2) == 0)
+    abort ();
+
+  return 0;
+}
index 54cd942199871b1756808bd9bad22a797d15059f..a1372074e9f3562270fe260463b30545604e4f8d 100644 (file)
@@ -47,6 +47,7 @@ along with GCC; see the file COPYING3.  If not see
 #include "langhooks.h"
 #include "tree-inline.h"
 #include "tree-data-ref.h"
+#include "diagnostic-core.h"
 
 /* This pass inserts prefetch instructions to optimize cache usage during
    accesses to arrays in loops.  It processes loops sequentially and:
@@ -1977,10 +1978,6 @@ tree_ssa_prefetch_arrays (void)
       set_builtin_decl (BUILT_IN_PREFETCH, decl, false);
     }
 
-  /* We assume that size of cache line is a power of two, so verify this
-     here.  */
-  gcc_assert ((PREFETCH_BLOCK & (PREFETCH_BLOCK - 1)) == 0);
-
   FOR_EACH_LOOP (loop, LI_FROM_INNERMOST)
     {
       if (dump_file && (dump_flags & TDF_DETAILS))
@@ -2038,6 +2035,21 @@ pass_loop_prefetch::execute (function *fun)
   if (number_of_loops (fun) <= 1)
     return 0;
 
+  bool warned_p = false;
+  if ((PREFETCH_BLOCK & (PREFETCH_BLOCK - 1)) != 0)
+    {
+      static bool warned = false;
+
+      if (!warned)
+       {
+         warning (OPT_Wdisabled_optimization,
+                  "%<l1-cache-size%> parameter is not a power of two %d",
+                  PREFETCH_BLOCK);
+         warned = true;
+       }
+      return 0;
+    }
+
   return tree_ssa_prefetch_arrays ();
 }