Mercurial > hg > CbC > CbC_gcc
diff gcc/testsuite/gcc.dg/store_merging_20.c @ 131:84e7813d76e9
gcc-8.2
author | mir3636 |
---|---|
date | Thu, 25 Oct 2018 07:37:49 +0900 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gcc/testsuite/gcc.dg/store_merging_20.c Thu Oct 25 07:37:49 2018 +0900 @@ -0,0 +1,68 @@ +/* { dg-do run } */ +/* { dg-require-effective-target store_merge } */ +/* { dg-options "-O2 -fdump-tree-store-merging" } */ + +extern void abort (void); + +struct S1 { + unsigned int flag : 1; + unsigned int size : 31; +}; + +__attribute__((noipa)) +void foo1 (struct S1 *s, unsigned int size) +{ + s->flag = 1; + s->size = size & 0x7FFFFFFF; +} + +struct S2 { + unsigned int flag : 1; + unsigned int size : 15; + unsigned short count; +}; + +__attribute__((noipa)) +void foo2 (struct S2 *s, unsigned short size) +{ + s->flag = 1; + s->size = size; + s->count = 0xABCD; +} + +struct S3 { + unsigned int n1 : 4; + unsigned int c : 8; + unsigned int n2 : 4; +}; + +__attribute__((noipa)) +void foo3 (struct S3 *s, unsigned char n1, unsigned char c, unsigned char n2) +{ + s->n1 = n1 & 0xF; + s->n2 = n2 & 0xF; + s->c = c; +} + +int main (void) +{ + struct S1 s1; + struct S2 s2; + struct S3 s3; + + foo1 (&s1, 0x12345678); + if (s1.flag != 1 || s1.size != 0x12345678) + abort (); + + foo2 (&s2, 0x1234); + if (s2.flag != 1 || s2.size != 0x1234 || s2.count != 0xABCD) + abort (); + + foo3 (&s3, 0x12, 0x34, 0x56); + if (s3.n1 != 0x2 || s3.c != 0x34 || s3.n2 != 0x6) + abort (); + + return 0; +} + +/* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" } } */