From: Richard Guenther Date: Sat, 5 Apr 2008 18:04:07 +0000 (+0000) Subject: re PR tree-optimization/35833 (Wrong code generated with -ftree-vrp) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3d3e20df3616f7999bd607306b378a4861cd8b77;p=gcc.git re PR tree-optimization/35833 (Wrong code generated with -ftree-vrp) 2008-04-05 Richard Guenther PR tree-optimization/35833 * gcc.dg/torture/pr35833.c: New testcase. From-SVN: r133941 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 08e354548bb..720118a170e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2008-04-05 Richard Guenther + + PR tree-optimization/35833 + * gcc.dg/torture/pr35833.c: New testcase. + 2008-04-04 Naveen.H.S * gcc.target/sh/sh2a-band.c: New test. diff --git a/gcc/testsuite/gcc.dg/torture/pr35833.c b/gcc/testsuite/gcc.dg/torture/pr35833.c new file mode 100644 index 00000000000..2e740f29f84 --- /dev/null +++ b/gcc/testsuite/gcc.dg/torture/pr35833.c @@ -0,0 +1,22 @@ +/* { dg-do run } */ +/* { dg-options "-ftree-vrp" } */ + +struct S {struct S *field;}; +struct S True, False, Z; +static inline int f(void) {return 1;} +static inline int g(struct S **obj) { + return f() && *obj == &Z; +} +struct S **h(struct S **x) { + if (x) + return g(x) ? &True.field : &False.field; + else + return &True.field; +} +extern void abort (void); +int main() +{ + if (h(&False.field) != &False.field) + abort (); + return 0; +}