]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
builtins.c (expand_builtin_expect_jump): Save pending_stack_adjust and restore it...
authorJakub Jelinek <jakub@redhat.com>
Wed, 27 Aug 2003 10:52:09 +0000 (12:52 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Wed, 27 Aug 2003 10:52:09 +0000 (12:52 +0200)
* builtins.c (expand_builtin_expect_jump): Save pending_stack_adjust
and restore it if returning NULL.

* gcc.dg/20030826-2.c: New test.

From-SVN: r70844

gcc/ChangeLog
gcc/builtins.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/20030826-2.c [new file with mode: 0644]

index ef8624fef175415892af989b9fd0c7d6506db07f..0300d78069f841d826283f9e80ecc59e053222ff 100644 (file)
@@ -1,3 +1,8 @@
+2003-08-27  Jakub Jelinek  <jakub@redhat.com>
+
+       * builtins.c (expand_builtin_expect_jump): Save pending_stack_adjust
+       and restore it if returning NULL.
+
 2003-08-27  Richard Sandiford  <rsandifo@redhat.com>
 
        * calls.c (initialize_argument_information): If an argument has no
index 227bb49c32efc310dc57eee2dc60bdc63a86c9c8..37dc4e5eaa2c850962ddb53ad17499b7da031346 100644 (file)
@@ -4330,6 +4330,7 @@ expand_builtin_expect_jump (tree exp, rtx if_false_label, rtx if_true_label)
       && (integer_zerop (arg1) || integer_onep (arg1)))
     {
       int num_jumps = 0;
+      int save_pending_stack_adjust = pending_stack_adjust;
       rtx insn;
 
       /* If we fail to locate an appropriate conditional jump, we'll
@@ -4421,7 +4422,10 @@ expand_builtin_expect_jump (tree exp, rtx if_false_label, rtx if_true_label)
       /* If no jumps were modified, fail and do __builtin_expect the normal
         way.  */
       if (num_jumps == 0)
-       ret = NULL_RTX;
+       {
+         ret = NULL_RTX;
+         pending_stack_adjust = save_pending_stack_adjust;
+       }
     }
 
   return ret;
index 2cabf3401661dd8dd2698e8cdb2d85f11344280c..2e96a627549e766f554ae5591fdc9eab4c443475 100644 (file)
@@ -1,3 +1,7 @@
+2003-08-27  Jakub Jelinek  <jakub@redhat.com>
+
+       * gcc.dg/20030826-2.c: New test.
+
 2003-08-26  Roger Sayle  <roger@eyesopen.com>
 
        PR middle-end/12002
diff --git a/gcc/testsuite/gcc.dg/20030826-2.c b/gcc/testsuite/gcc.dg/20030826-2.c
new file mode 100644 (file)
index 0000000..f25887d
--- /dev/null
@@ -0,0 +1,64 @@
+/* { dg-do run } */
+/* { dg-options "-O2 -fomit-frame-pointer" } */
+/* { dg-options "-O2 -fomit-frame-pointer -march=i386" { target i?86-*-* } } */
+
+extern void abort (void);
+extern void exit (int);
+
+struct S
+{
+  int *a;
+  unsigned char *b, c;
+};
+
+int u, v, w;
+
+void
+foo (unsigned short x)
+{
+  u += x;
+}
+
+int
+bar (struct S **x, int *y)
+{
+  w += *y;
+  *y = w + 25;
+  return 0;
+}
+
+int
+baz (struct S **x)
+{
+  struct S *y = *x;
+  unsigned char *a = y->b;
+
+  foo (*a);
+
+  if (__builtin_expect (y->c != 0 || y->a == &v, 0))
+    return 1;
+
+  if (__builtin_expect (*a == 1, 0))
+    {
+      int a, b = bar (x, &a);
+
+      if (a)
+       return b;
+    }
+
+  return 0;
+}
+
+int
+main (void)
+{
+  struct S a, *b = &a;
+  unsigned char c;
+
+  __builtin_memset (b, 0, sizeof (a));
+  a.a = &v;
+  a.b = &c;
+  if (baz (&b) != 1)
+    abort ();
+  exit (0);
+}