annotate gcc/testsuite/gcc.c-torture/compile/pr53410-2.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 /* PR tree-optimization/53410 */
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 typedef int V __attribute__((vector_size (4 * sizeof (int))));
kono
parents:
diff changeset
4 typedef unsigned int W __attribute__((vector_size (4 * sizeof (int))));
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 void
kono
parents:
diff changeset
7 f1 (V *p)
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 *p = (*p & ((V) { 1, 1, 1, 1 })) ^ ((V) { 1, 1, 1, 1});
kono
parents:
diff changeset
10 }
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 void
kono
parents:
diff changeset
13 f2 (V *p)
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 *p = (*p ^ ((V) { 1, 1, 1, 1 })) & ((V) { 1, 1, 1, 1});
kono
parents:
diff changeset
16 }
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 void
kono
parents:
diff changeset
19 f3 (V *p)
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 *p = (~*p) & ((V) { 1, 1, 1, 1 });
kono
parents:
diff changeset
22 }
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 void
kono
parents:
diff changeset
25 f4 (V *p, V *q)
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 *p = (*p ^ *q) == *q;
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 void
kono
parents:
diff changeset
31 f5 (V *p, V *q)
kono
parents:
diff changeset
32 {
kono
parents:
diff changeset
33 *p = (*p ^ *q) == *p;
kono
parents:
diff changeset
34 }
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 void
kono
parents:
diff changeset
37 f6 (V *p, V *q, V *r)
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 *p = (*p & *r) == (*q & *r);
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 void
kono
parents:
diff changeset
43 f7 (V *p, V *q, V *r)
kono
parents:
diff changeset
44 {
kono
parents:
diff changeset
45 *p = (*p & *r) == (*r & *q);
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 void
kono
parents:
diff changeset
49 f8 (V *p, V *q, V *r)
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 *p = (*r & *p) == (*q & *r);
kono
parents:
diff changeset
52 }
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 void
kono
parents:
diff changeset
55 f9 (V *p, V *q, V *r)
kono
parents:
diff changeset
56 {
kono
parents:
diff changeset
57 *p = (*r & *p) == (*r & *q);
kono
parents:
diff changeset
58 }
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 void
kono
parents:
diff changeset
61 f10 (W *p, W *q)
kono
parents:
diff changeset
62 {
kono
parents:
diff changeset
63 *p = *p < (((const W) { 1U, 1U, 1U, 1U }) << *q);
kono
parents:
diff changeset
64 }