diff options
author | H.J. Lu <hongjiu.lu@intel.com> | 2014-03-31 15:24:56 +0000 |
---|---|---|
committer | H.J. Lu <hjl@gcc.gnu.org> | 2014-03-31 08:24:56 -0700 |
commit | a283136a5870513f1ec4d7d9a0b3b2cc1771baf4 (patch) | |
tree | 14d97bc30b10045d1eec672eb7a8f3fa6985598d | |
parent | 80dc1f0c88d68e39ed9be6baae040c1048ab64f0 (diff) | |
download | gcc-a283136a5870513f1ec4d7d9a0b3b2cc1771baf4.zip gcc-a283136a5870513f1ec4d7d9a0b3b2cc1771baf4.tar.gz gcc-a283136a5870513f1ec4d7d9a0b3b2cc1771baf4.tar.bz2 |
Add a testcase for PR rtl-optimization/60700
PR rtl-optimization/60700
* gcc.target/i386/pr60700.c: New test.
From-SVN: r208962
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/i386/pr60700.c | 59 |
2 files changed, 64 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 532bba6..ccffd49 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2014-03-31 H.J. Lu <hongjiu.lu@intel.com> + + PR rtl-optimization/60700 + * gcc.target/i386/pr60700.c: New test. + 2014-03-31 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> PR target/60650 diff --git a/gcc/testsuite/gcc.target/i386/pr60700.c b/gcc/testsuite/gcc.target/i386/pr60700.c new file mode 100644 index 0000000..5428f36 --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/pr60700.c @@ -0,0 +1,59 @@ +/* PR rtl-optimization/60700 */ +/* { dg-do run { target ia32 } } */ +/* { dg-options "-O3 -march=i686" } */ + +int +__attribute__((noinline)) +foo (void) +{ + return 0; +} + +void *g = (void *)1; + +struct st { + char data[36]; /* must be greater than 32. */ +}; + +int +__attribute__((noinline)) +repro(struct st **out) +{ + int status = 0; + + *out = 0; + + status = foo(); + if (status != 0) { + return status; + } + + if (0 == g) { + status = 999; + return status; + } + + *out = (struct st *)__builtin_malloc(sizeof(struct st)); + if (0 == *out) { + status = 42; + return status; + } + + __builtin_memset(*out, 0, sizeof(struct st)); + + return status; +} + +int +main () +{ + struct st *p; + int ret = repro (&p); + unsigned int i; + + for (i = 0; i < sizeof (p->data)/sizeof (p->data[0]); i++) + if (p->data[i] != 0) + __builtin_abort (); + + return ret; +} |