annotate gcc/testsuite/gcc.dg/pr56837.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Limit this test to selected targets with IEEE double, 8-byte long long,
kono
parents:
diff changeset
2 supported 4x int vectors, 4-byte int. */
kono
parents:
diff changeset
3 /* { dg-do compile { target { i?86-*-* x86_64-*-* powerpc*-*-* } } } */
kono
parents:
diff changeset
4 /* { dg-options "-O3 -fdump-tree-optimized" } */
kono
parents:
diff changeset
5 /* { dg-additional-options "-msse2" { target ia32 } } */
kono
parents:
diff changeset
6 /* { dg-additional-options "-mvsx -maltivec" { target powerpc*-*-* } } */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 typedef int V __attribute__((__vector_size__ (16)));
kono
parents:
diff changeset
9 #define N 1024
kono
parents:
diff changeset
10 double d[N];
kono
parents:
diff changeset
11 long long int l[N];
kono
parents:
diff changeset
12 _Bool b[N];
kono
parents:
diff changeset
13 _Complex double c[N];
kono
parents:
diff changeset
14 V v[N];
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 void
kono
parents:
diff changeset
17 fd (void)
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 int i;
kono
parents:
diff changeset
20 for (i = 0; i < N; i++)
kono
parents:
diff changeset
21 d[i] = 747708026454360457216.0;
kono
parents:
diff changeset
22 }
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 void
kono
parents:
diff changeset
25 fl (void)
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 int i;
kono
parents:
diff changeset
28 for (i = 0; i < N; i++)
kono
parents:
diff changeset
29 l[i] = 0x7c7c7c7c7c7c7c7cULL;
kono
parents:
diff changeset
30 }
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 void
kono
parents:
diff changeset
33 fb (void)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 int i;
kono
parents:
diff changeset
36 for (i = 0; i < N; i++)
kono
parents:
diff changeset
37 b[i] = 1;
kono
parents:
diff changeset
38 }
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 void
kono
parents:
diff changeset
41 fc (void)
kono
parents:
diff changeset
42 {
kono
parents:
diff changeset
43 int i;
kono
parents:
diff changeset
44 for (i = 0; i < N; i++)
kono
parents:
diff changeset
45 c[i] = 747708026454360457216.0 + 747708026454360457216.0i;
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 void
kono
parents:
diff changeset
49 fv (void)
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 int i;
kono
parents:
diff changeset
52 for (i = 0; i < N; i++)
kono
parents:
diff changeset
53 v[i] = (V) { 0x12121212, 0x12121212, 0x12121212, 0x12121212 };
kono
parents:
diff changeset
54 }
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 /* Look for
kono
parents:
diff changeset
57 __builtin_memset (&d, 68, 8192);
kono
parents:
diff changeset
58 __builtin_memset (&l, 124, 8192);
kono
parents:
diff changeset
59 __builtin_memset (&b, 1, 1024);
kono
parents:
diff changeset
60 __builtin_memset (&c, 68, 16384);
kono
parents:
diff changeset
61 __builtin_memset (&v, 18, 16384); */
kono
parents:
diff changeset
62 /* { dg-final { scan-tree-dump-times "memset ..d, 68, 8192.;" 1 "optimized" } } */
kono
parents:
diff changeset
63 /* { dg-final { scan-tree-dump-times "memset ..l, 124, 8192.;" 1 "optimized" } } */
kono
parents:
diff changeset
64 /* { dg-final { scan-tree-dump-times "memset ..b, 1, 1024.;" 1 "optimized" } } */
kono
parents:
diff changeset
65 /* { dg-final { scan-tree-dump-times "memset ..c, 68, 16384.;" 1 "optimized" } } */
kono
parents:
diff changeset
66 /* { dg-final { scan-tree-dump-times "memset ..v, 18, 16384.;" 1 "optimized" } } */