]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
backport: re PR target/68701 ("gcc -m32 -finstrument-functions -ffixed-ebp" produces...
authorUros Bizjak <ubizjak@gmail.com>
Thu, 10 Dec 2015 16:43:49 +0000 (17:43 +0100)
committerUros Bizjak <uros@gcc.gnu.org>
Thu, 10 Dec 2015 16:43:49 +0000 (17:43 +0100)
Backport from mainline
2015-12-08  Uros Bizjak  <ubizjak@gmail.com>

PR target/68701
* config/i386/i386.c (ix86_option_override_internal): Enable
-maccumulate-outgoing-args when %ebp is fixed due to stack
realignment requirements.

testsuite/ChangeLog:

Backport from mainline
2015-12-08  Uros Bizjak  <ubizjak@gmail.com>

PR target/68701
* gcc.target/i386/pr68701-1.c: New test.
* gcc.target/i386/pr68701-2.c: Ditto.

From-SVN: r231529

gcc/ChangeLog
gcc/config/i386/i386.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/pr68701-1.c [new file with mode: 0644]
gcc/testsuite/gcc.target/i386/pr68701-2.c [new file with mode: 0644]

index bd387b0019ef9ba72d8c26d06fb3497077bb26e5..38477faf1b95b54f86b5c257fff86525ddc14bb4 100644 (file)
@@ -1,3 +1,13 @@
+2015-12-10  Uros Bizjak  <ubizjak@gmail.com>
+
+       Backport from mainline
+       2015-12-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/68701
+       * config/i386/i386.c (ix86_option_override_internal): Enable
+       -maccumulate-outgoing-args when %ebp is fixed due to stack
+       realignment requirements.
+
 2015-12-09  John David Anglin  <danglin@gcc.gnu.org>
 
        PR target/68729
index 9b7b58a52c9db74e99254bd5d279291e9f31baba..c6d0102ae1cde49d5a22dd0a667c61442f5fa9c9 100644 (file)
@@ -4029,6 +4029,17 @@ ix86_option_override_internal (bool main_args_p,
       opts->x_target_flags |= MASK_ACCUMULATE_OUTGOING_ARGS;
     }
 
+  /* Stack realignment without -maccumulate-outgoing-args requires %ebp,
+     so enable -maccumulate-outgoing-args when %ebp is fixed.  */
+  if (fixed_regs[BP_REG]
+      && !(opts->x_target_flags & MASK_ACCUMULATE_OUTGOING_ARGS))
+    {
+      if (opts_set->x_target_flags & MASK_ACCUMULATE_OUTGOING_ARGS)
+       warning (0, "fixed ebp register requires %saccumulate-outgoing-args%s",
+                prefix, suffix);
+      opts->x_target_flags |= MASK_ACCUMULATE_OUTGOING_ARGS;
+    }
+
   /* Figure out what ASM_GENERATE_INTERNAL_LABEL builds as a prefix.  */
   {
     char *p;
index 6663cb16e58a2e275451b62f5e3d659cbafd2c96..0d506ec5b37770cf856b5b97835ed69d34c4a555 100644 (file)
@@ -1,3 +1,12 @@
+2015-12-10  Uros Bizjak  <ubizjak@gmail.com>
+
+       Backport from mainline
+       2015-12-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/68701
+       * gcc.target/i386/pr68701-1.c: New test.
+       * gcc.target/i386/pr68701-2.c: Ditto.
+
 2015-12-09  Uros Bizjak  <ubizjak@gmail.com>
 
        * gcc.target/i386/sse4_1-roundps-1.c: Remove ASM_SUFFIX define.
diff --git a/gcc/testsuite/gcc.target/i386/pr68701-1.c b/gcc/testsuite/gcc.target/i386/pr68701-1.c
new file mode 100644 (file)
index 0000000..008eb6b
--- /dev/null
@@ -0,0 +1,13 @@
+/* { dg-do compile } */
+/* { dg-options "-O -ffixed-ebp -mno-accumulate-outgoing-args" } */
+
+/* { dg-warning "fixed ebp register requires" "" { target *-*-* } 0 } */
+
+void foo (void);
+
+int
+main (int argc, char *argv[])
+{
+  foo ();
+  return argc - 1;
+}
diff --git a/gcc/testsuite/gcc.target/i386/pr68701-2.c b/gcc/testsuite/gcc.target/i386/pr68701-2.c
new file mode 100644 (file)
index 0000000..bfe592e
--- /dev/null
@@ -0,0 +1,11 @@
+/* { dg-do compile } */
+/* { dg-options "-O -ffixed-ebp -mno-accumulate-outgoing-args -mstackrealign -msse" } */
+
+/* { dg-warning "fixed ebp register requires" "" { target *-*-* } 0 } */
+
+typedef float V __attribute__((vector_size(16)));
+
+void bar (V a)
+{
+  volatile V b = a;
+}