annotate gcc/testsuite/gcc.dg/fold-bopcond-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 /* { dg-do compile } */
kono
parents:
diff changeset
2 /* { dg-options "-O3 -fdump-tree-ifcvt" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 int foo1 (unsigned short a[], unsigned int x)
kono
parents:
diff changeset
5 {
kono
parents:
diff changeset
6 unsigned int i;
kono
parents:
diff changeset
7 for (i = 0; i < 1000; i++)
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 x = a[i];
kono
parents:
diff changeset
10 a[i] = (unsigned short)(x >= 32768 ? x - 32768 : 0);
kono
parents:
diff changeset
11 }
kono
parents:
diff changeset
12 return x;
kono
parents:
diff changeset
13 }
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 int foo2 (unsigned short a[], unsigned int x)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 unsigned int i;
kono
parents:
diff changeset
18 for (i = 0; i < 1000; i++)
kono
parents:
diff changeset
19 {
kono
parents:
diff changeset
20 x = a[i];
kono
parents:
diff changeset
21 a[i] = (unsigned short)(x > 32768 ? x - 32768 : 0);
kono
parents:
diff changeset
22 }
kono
parents:
diff changeset
23 return x;
kono
parents:
diff changeset
24 }
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 int foo3 (unsigned short a[], unsigned int x)
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 unsigned int i;
kono
parents:
diff changeset
29 for (i = 0; i < 1000; i++)
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 x = a[i];
kono
parents:
diff changeset
32 a[i] = (unsigned short)(x > 1000 ? x - 1000 : 0);
kono
parents:
diff changeset
33 }
kono
parents:
diff changeset
34 return x;
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 int foo4 (unsigned short a[], unsigned int x)
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 unsigned int i;
kono
parents:
diff changeset
40 for (i = 0; i < 1000; i++)
kono
parents:
diff changeset
41 {
kono
parents:
diff changeset
42 x = a[i];
kono
parents:
diff changeset
43 a[i] = (unsigned short)(x >= 2 ? x - 32768 : 32770);
kono
parents:
diff changeset
44 }
kono
parents:
diff changeset
45 return x;
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 /* { dg-final { scan-tree-dump-times "MAX_EXPR " 4 "ifcvt" } } */