annotate gcc/testsuite/c-c++-common/rotate-8.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* PR middle-end/62263 */
kono
parents:
diff changeset
2 /* PR middle-end/82498 */
kono
parents:
diff changeset
3 /* { dg-do compile } */
kono
parents:
diff changeset
4 /* { dg-options "-O2 -fno-ipa-icf -fdump-tree-optimized" } */
kono
parents:
diff changeset
5 /* { dg-final { scan-tree-dump-times "r\[<>]\[<>]" 23 "optimized" } } */
kono
parents:
diff changeset
6 /* { dg-final { scan-tree-dump-not "PHI <" "optimized" } } */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 unsigned int
kono
parents:
diff changeset
9 f1 (unsigned int x, unsigned char y)
kono
parents:
diff changeset
10 {
kono
parents:
diff changeset
11 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
12 return (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y));
kono
parents:
diff changeset
13 }
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 unsigned int
kono
parents:
diff changeset
16 f2 (unsigned int x, signed char y)
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 y &= __CHAR_BIT__ * __SIZEOF_INT__ - 1;
kono
parents:
diff changeset
19 return (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y));
kono
parents:
diff changeset
20 }
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 unsigned int
kono
parents:
diff changeset
23 f3 (unsigned int x, unsigned char y)
kono
parents:
diff changeset
24 {
kono
parents:
diff changeset
25 return (x << (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))));
kono
parents:
diff changeset
26 }
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 unsigned int
kono
parents:
diff changeset
29 f4 (unsigned int x, unsigned char y)
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 y = y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1);
kono
parents:
diff changeset
32 return y ? (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y)) : x;
kono
parents:
diff changeset
33 }
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 unsigned int
kono
parents:
diff changeset
36 f5 (unsigned int x, unsigned char y)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 y = y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1);
kono
parents:
diff changeset
39 return (x << y) | (x >> ((__CHAR_BIT__ * __SIZEOF_INT__ - y) & (__CHAR_BIT__ * __SIZEOF_INT__ - 1)));
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 unsigned int
kono
parents:
diff changeset
43 f6 (unsigned int x, unsigned char y)
kono
parents:
diff changeset
44 {
kono
parents:
diff changeset
45 return (x << (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) | (x >> ((__CHAR_BIT__ * __SIZEOF_INT__ - (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) & (__CHAR_BIT__ * __SIZEOF_INT__ - 1)));
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 unsigned int
kono
parents:
diff changeset
49 f7 (unsigned int x, unsigned char y)
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 return (x << (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) | (x >> ((__CHAR_BIT__ * __SIZEOF_INT__ - y) & (__CHAR_BIT__ * __SIZEOF_INT__ - 1)));
kono
parents:
diff changeset
52 }
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 unsigned int
kono
parents:
diff changeset
55 f8 (unsigned int x, unsigned char y)
kono
parents:
diff changeset
56 {
kono
parents:
diff changeset
57 return (x << (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) | (x >> ((-y) & (__CHAR_BIT__ * __SIZEOF_INT__ - 1)));
kono
parents:
diff changeset
58 }
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 unsigned int
kono
parents:
diff changeset
61 f9 (unsigned int x, int y)
kono
parents:
diff changeset
62 {
kono
parents:
diff changeset
63 return (0x12345678U << (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) | (0x12345678U >> (-y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1)));
kono
parents:
diff changeset
64 }
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 unsigned int
kono
parents:
diff changeset
67 f10 (unsigned int x, int y)
kono
parents:
diff changeset
68 {
kono
parents:
diff changeset
69 return (0x12345678U >> (-y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) | (0x12345678U << (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1)));
kono
parents:
diff changeset
70 }
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 unsigned int
kono
parents:
diff changeset
73 f11 (unsigned int x, int y)
kono
parents:
diff changeset
74 {
kono
parents:
diff changeset
75 return (0x12345678U >> (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) | (0x12345678U << (-y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1)));
kono
parents:
diff changeset
76 }
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 unsigned int
kono
parents:
diff changeset
79 f12 (unsigned int x, int y)
kono
parents:
diff changeset
80 {
kono
parents:
diff changeset
81 return (0x12345678U << (-y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1))) | (0x12345678U >> (y & (__CHAR_BIT__ * __SIZEOF_INT__ - 1)));
kono
parents:
diff changeset
82 }
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 unsigned
kono
parents:
diff changeset
85 f13 (unsigned x, unsigned char y)
kono
parents:
diff changeset
86 {
kono
parents:
diff changeset
87 if (y == 0)
kono
parents:
diff changeset
88 return x;
kono
parents:
diff changeset
89 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
90 return (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y));
kono
parents:
diff changeset
91 }
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 unsigned
kono
parents:
diff changeset
94 f14 (unsigned x, unsigned y)
kono
parents:
diff changeset
95 {
kono
parents:
diff changeset
96 if (y == 0)
kono
parents:
diff changeset
97 return x;
kono
parents:
diff changeset
98 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
99 return (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y));
kono
parents:
diff changeset
100 }
kono
parents:
diff changeset
101
kono
parents:
diff changeset
102 unsigned
kono
parents:
diff changeset
103 f15 (unsigned x, unsigned short y)
kono
parents:
diff changeset
104 {
kono
parents:
diff changeset
105 if (y == 0)
kono
parents:
diff changeset
106 return x;
kono
parents:
diff changeset
107 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
108 return (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y));
kono
parents:
diff changeset
109 }
kono
parents:
diff changeset
110
kono
parents:
diff changeset
111 unsigned
kono
parents:
diff changeset
112 f16 (unsigned x, unsigned char y)
kono
parents:
diff changeset
113 {
kono
parents:
diff changeset
114 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
115 if (y == 0)
kono
parents:
diff changeset
116 return x;
kono
parents:
diff changeset
117 return (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y));
kono
parents:
diff changeset
118 }
kono
parents:
diff changeset
119
kono
parents:
diff changeset
120 unsigned
kono
parents:
diff changeset
121 f17 (unsigned x, unsigned y)
kono
parents:
diff changeset
122 {
kono
parents:
diff changeset
123 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
124 if (y == 0)
kono
parents:
diff changeset
125 return x;
kono
parents:
diff changeset
126 return (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y));
kono
parents:
diff changeset
127 }
kono
parents:
diff changeset
128
kono
parents:
diff changeset
129 unsigned
kono
parents:
diff changeset
130 f18 (unsigned x, unsigned short y)
kono
parents:
diff changeset
131 {
kono
parents:
diff changeset
132 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
133 if (y == 0)
kono
parents:
diff changeset
134 return x;
kono
parents:
diff changeset
135 return (x << y) | (x >> (__CHAR_BIT__ * __SIZEOF_INT__ - y));
kono
parents:
diff changeset
136 }
kono
parents:
diff changeset
137
kono
parents:
diff changeset
138 unsigned
kono
parents:
diff changeset
139 f19 (unsigned x, unsigned char y)
kono
parents:
diff changeset
140 {
kono
parents:
diff changeset
141 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
142 return (x << y) | (x >> (((unsigned char) -y) % (__CHAR_BIT__ * __SIZEOF_INT__)));
kono
parents:
diff changeset
143 }
kono
parents:
diff changeset
144
kono
parents:
diff changeset
145 unsigned
kono
parents:
diff changeset
146 f20 (unsigned x, unsigned int y)
kono
parents:
diff changeset
147 {
kono
parents:
diff changeset
148 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
149 return (x << y) | (x >> (-y % (__CHAR_BIT__ * __SIZEOF_INT__)));
kono
parents:
diff changeset
150 }
kono
parents:
diff changeset
151
kono
parents:
diff changeset
152 unsigned
kono
parents:
diff changeset
153 f21 (unsigned x, unsigned short y)
kono
parents:
diff changeset
154 {
kono
parents:
diff changeset
155 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
156 return (x << y) | (x >> (((unsigned short) -y) % (__CHAR_BIT__ * __SIZEOF_INT__)));
kono
parents:
diff changeset
157 }
kono
parents:
diff changeset
158
kono
parents:
diff changeset
159 unsigned
kono
parents:
diff changeset
160 f22 (unsigned x, unsigned char y)
kono
parents:
diff changeset
161 {
kono
parents:
diff changeset
162 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
163 return (x << y) | (x >> (-y & ((__CHAR_BIT__ * __SIZEOF_INT__) - 1)));
kono
parents:
diff changeset
164 }
kono
parents:
diff changeset
165
kono
parents:
diff changeset
166 unsigned
kono
parents:
diff changeset
167 f23 (unsigned x, unsigned short y)
kono
parents:
diff changeset
168 {
kono
parents:
diff changeset
169 y %= __CHAR_BIT__ * __SIZEOF_INT__;
kono
parents:
diff changeset
170 return (x << y) | (x >> (-y & ((__CHAR_BIT__ * __SIZEOF_INT__) - 1)));
kono
parents:
diff changeset
171 }