re PR target/67770 (i386: -fshrink-wrap can interact badly with trampolines)
authorJakub Jelinek <jakub@redhat.com>
Thu, 19 Nov 2015 08:30:19 +0000 (09:30 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Thu, 19 Nov 2015 08:30:19 +0000 (09:30 +0100)
PR target/67770
* config/i386/i386.md (simple_return): Disable if
ix86_static_chain_on_stack is true.

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

From-SVN: r230593

gcc/ChangeLog
gcc/config/i386/i386.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/pr67770.c [new file with mode: 0644]

index f37ad250cb4913dcdf8c6ee6565645786502b2a9..3ba93271b811797eaa83f829f979deff23b5fc77 100644 (file)
@@ -1,3 +1,9 @@
+2015-11-19  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/67770
+       * config/i386/i386.md (simple_return): Disable if
+       ix86_static_chain_on_stack is true.
+
 2015-11-19  Richard Sandiford  <richard.sandiford@arm.com>
 
        PR bootstrap/68393
index 39b058f82c742ab493ecde66f200e73fb29bcd94..4c5e22aa71981c7ef8f438ac645de73b5d0f1fef 100644 (file)
 ;; We need to disable this for TARGET_SEH, as otherwise
 ;; shrink-wrapped prologue gets enabled too.  This might exceed
 ;; the maximum size of prologue in unwind information.
+;; Also disallow shrink-wrapping if using stack slot to pass the
+;; static chain pointer - the first instruction has to be pushl %esi
+;; and it can't be moved around, as we use alternate entry points
+;; in that case.
 
 (define_expand "simple_return"
   [(simple_return)]
-  "!TARGET_SEH"
+  "!TARGET_SEH && !ix86_static_chain_on_stack"
 {
   if (crtl->args.pops_args)
     {
index 48f536fc61056acc7c9adfab0ee3cfa51e1c0bf9..8c7746ff72949ff6e761567f52bfb31adf59ad57 100644 (file)
@@ -1,3 +1,8 @@
+2015-11-19  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/67770
+       * gcc.target/i386/pr67770.c: New test.
+
 2015-11-18  Jeff Law  <law@redhat.com>
 
         PR tree-optimization/68198
diff --git a/gcc/testsuite/gcc.target/i386/pr67770.c b/gcc/testsuite/gcc.target/i386/pr67770.c
new file mode 100644 (file)
index 0000000..3826aff
--- /dev/null
@@ -0,0 +1,40 @@
+/* PR target/67770 */
+/* { dg-do run { target ia32 } } */
+/* { dg-require-effective-target trampolines } */
+/* { dg-options "-O2" } */
+
+#ifndef NO_TRAMPOLINES
+__attribute__ ((noinline)) void
+foo (int i, void (* __attribute__ ((regparm (3))) bar) (int))
+{
+  bar (i);
+}
+#endif
+
+int
+main ()
+{
+#ifndef NO_TRAMPOLINES
+  int p = 0;
+
+  __attribute__ ((regparm (3), noinline)) void
+  bar (int i)
+  {
+    if (__builtin_expect (i, 0))
+      ++p;
+  }
+
+  foo (0, bar);
+  bar (0);
+
+  if (p != 0)
+    __builtin_abort ();
+
+  foo (1, bar);
+  bar (1);
+
+  if (p != 2)
+    __builtin_abort ();
+#endif
+  return 0;
+}