annotate gcc/testsuite/gcc.dg/vect/slp-36.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 /* { dg-do compile } */
kono
parents:
diff changeset
2 /* { dg-require-effective-target vect_int } */
kono
parents:
diff changeset
3 /* { dg-require-effective-target vect_shift } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #define N 32
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 /* All the loops are vectorizable on platforms with vector shift argument. */
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 void
kono
parents:
diff changeset
10 test_1 (void)
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 static unsigned int bm[N];
kono
parents:
diff changeset
13 static unsigned int cm[N];
kono
parents:
diff changeset
14 int j;
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 /* Vectorizable on platforms with scalar shift argument. */
kono
parents:
diff changeset
17 for (j = 0; j < N/2; j++)
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 bm[2*j] <<= 8;
kono
parents:
diff changeset
20 bm[2*j+1] <<= 8;
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 /* Not vectorizable on platforms with scalar shift argument. */
kono
parents:
diff changeset
24 for (j = 0; j < N/2; j++)
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 cm[2*j] <<= 8;
kono
parents:
diff changeset
27 cm[2*j+1] <<= 7;
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 void
kono
parents:
diff changeset
32 test_2 (int a, int b)
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 static unsigned int bm[N];
kono
parents:
diff changeset
35 static unsigned int cm[N];
kono
parents:
diff changeset
36 int j;
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 /* Vectorizable on platforms with scalar shift argument. */
kono
parents:
diff changeset
39 for (j = 0; j < N/2; j++)
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 bm[2*j] <<= a;
kono
parents:
diff changeset
42 bm[2*j+1] <<= a;
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 /* Not vectorizable on platforms with scalar shift argument. */
kono
parents:
diff changeset
46 for (j = 0; j < N/2; j++)
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 cm[2*j] <<= a;
kono
parents:
diff changeset
49 cm[2*j+1] <<= b;
kono
parents:
diff changeset
50 }
kono
parents:
diff changeset
51 }
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 void
kono
parents:
diff changeset
54 test_3 (void)
kono
parents:
diff changeset
55 {
kono
parents:
diff changeset
56 static unsigned int bm[N];
kono
parents:
diff changeset
57 int am[N];
kono
parents:
diff changeset
58 int j;
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 /* Not vectorizable on platforms with scalar shift argument. */
kono
parents:
diff changeset
61 for (j = 0; j < N/2; j++)
kono
parents:
diff changeset
62 {
kono
parents:
diff changeset
63 bm[2*j] <<= am[j];
kono
parents:
diff changeset
64 bm[2*j+1] <<= am[j];
kono
parents:
diff changeset
65 }
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 /* Not vectorizable on platforms with scalar shift argument. */
kono
parents:
diff changeset
68 for (j = 0; j < N/2; j++)
kono
parents:
diff changeset
69 {
kono
parents:
diff changeset
70 bm[2*j] <<= am[2*j];
kono
parents:
diff changeset
71 bm[2*j+1] <<= am[2*j+1];
kono
parents:
diff changeset
72 }
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 }
kono
parents:
diff changeset
75