diff options
author | Martin Jambor <mjambor@suse.cz> | 2021-01-22 18:09:38 +0100 |
---|---|---|
committer | Martin Jambor <mjambor@suse.cz> | 2021-01-22 18:09:38 +0100 |
commit | d7e681fc3afff24a6279058cbb0b0dc4cd96be8c (patch) | |
tree | 5000bc40c4d65fc170fa2dbdb5f36fa3da8152ed | |
parent | 9d33785f57daf29dc0c106c919da319fe1906bc6 (diff) | |
download | gcc-d7e681fc3afff24a6279058cbb0b0dc4cd96be8c.zip gcc-d7e681fc3afff24a6279058cbb0b0dc4cd96be8c.tar.gz gcc-d7e681fc3afff24a6279058cbb0b0dc4cd96be8c.tar.bz2 |
Testcase for old PR 47059
I stumbled across PR 47059 from 2010 which has been addressed by
store-merging. I am going to close it but would like to add its
testcase too.
gcc/testsuite/ChangeLog:
2021-01-08 Martin Jambor <mjambor@suse.cz>
PR tree-optimization/47059
* gcc.dg/tree-ssa/pr47059.c: New test.
-rw-r--r-- | gcc/testsuite/gcc.dg/tree-ssa/pr47059.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c new file mode 100644 index 0000000..9f9c61a --- /dev/null +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c @@ -0,0 +1,45 @@ +/* { dg-do compile } */ +/* { dg-options "-Os -fdump-tree-optimized" } */ + + +struct struct1 +{ + void *data; + unsigned short f1; + unsigned short f2; +}; +typedef struct struct1 S1; + +struct struct2 +{ + int f3; + S1 f4; +}; +typedef struct struct2 S2; + + +extern void foo (S1 *ptr); +extern S2 gstruct2_var; +extern S1 gstruct1_var; + +static inline S1 bar (const S1 *ptr) __attribute__ ((always_inline)); + +static inline S1 +bar (const S1 *ptr) +{ + S1 ls_var = *ptr; + foo (&ls_var); + return ls_var; +} + +int +main () +{ + S2 *ps_var; + + ps_var = &gstruct2_var; + ps_var->f4 = bar (&gstruct1_var); + + return 0; +} +/* { dg-final { scan-tree-dump-times "short unsigned int\[^*\]*;" 0 "optimized"} } */ |