diff options
author | rguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-01-05 13:42:40 +0000 |
---|---|---|
committer | rguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-01-05 13:42:40 +0000 |
commit | a97efcbd10b1578882ebba981cfef61612c3a068 (patch) | |
tree | de35d790f8d69233802bd7770c31626901df9ae4 | |
parent | cc029bec00c7e130c9d46188e9b8c12809fb2a7b (diff) | |
download | gcc-a97efcbd10b1578882ebba981cfef61612c3a068.tar.gz |
2010-01-05 Richard Guenther <rguenther@suse.de>
PR tree-optimization/42614
* gcc.c-torture/execute/pr42614.c: New testcase.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@155647 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/execute/pr42614.c | 68 |
2 files changed, 73 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 42eb680f7ef..813e00583af 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-01-05 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/42614 + * gcc.c-torture/execute/pr42614.c: New testcase. + 2010-01-05 Eric Fisher <joefoxreal@gmail.com> * gcc.dg/pr12603.c: Remove -Wunreachable-code from dg-options. diff --git a/gcc/testsuite/gcc.c-torture/execute/pr42614.c b/gcc/testsuite/gcc.c-torture/execute/pr42614.c new file mode 100644 index 00000000000..d3680539bdc --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/pr42614.c @@ -0,0 +1,68 @@ +extern void *malloc(__SIZE_TYPE__); +extern void abort(void); +extern void free(void *); + +typedef struct SEntry +{ + unsigned char num; +} TEntry; + +typedef struct STable +{ + TEntry data[2]; +} TTable; + +TTable *init () +{ + return malloc(sizeof(TTable)); +} + +void +expect_func (int a, unsigned char *b) __attribute__ ((noinline)); + +static inline void +inlined_wrong (TEntry *entry_p, int flag); + +void +inlined_wrong (TEntry *entry_p, int flag) +{ + unsigned char index; + entry_p->num = 0; + + if (flag == 0) + abort(); + + for (index = 0; index < 1; index++) + entry_p->num++; + + if (!entry_p->num) + { + abort(); + } +} + +void +expect_func (int a, unsigned char *b) +{ + if (abs ((a == 0))) + abort (); + if (abs ((b == 0))) + abort (); +} + +int +main () +{ + unsigned char index = 0; + TTable *table_p = init(); + TEntry work; + + inlined_wrong (&(table_p->data[1]), 1); + expect_func (1, &index); + inlined_wrong (&work, 1); + + free (table_p); + + return 0; +} + |