Branch data Line data Source code
1 : : /* Generated automatically by the program `genmatch' from
2 : : a IL pattern matching and simplification description. */
3 : : #pragma GCC diagnostic push
4 : : #pragma GCC diagnostic ignored "-Wunused-variable"
5 : : #pragma GCC diagnostic ignored "-Wunused-function"
6 : :
7 : : #include "gimple-match-auto.h"
8 : :
9 : : bool
10 : 55989149 : gimple_negate_expr_p (tree t, tree (*valueize)(tree) ATTRIBUTE_UNUSED)
11 : : {
12 : 55989149 : const tree type = TREE_TYPE (t);
13 : 55989149 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
14 : 55989149 : switch (TREE_CODE (t))
15 : : {
16 : 53353967 : case SSA_NAME:
17 : 53353967 : if (gimple *_d1 = get_def (valueize, t))
18 : : {
19 : 29506974 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
20 : 28177806 : switch (gimple_assign_rhs_code (_a1))
21 : : {
22 : 55650 : case NEGATE_EXPR:
23 : 55650 : {
24 : 55650 : tree _p0 = gimple_assign_rhs1 (_a1);
25 : 55650 : _p0 = do_valueize (valueize, _p0);
26 : 55650 : {
27 : 55650 : tree captures[1] ATTRIBUTE_UNUSED = { _p0 };
28 : 55650 : if (!TYPE_OVERFLOW_SANITIZED (type)
29 : : )
30 : : {
31 : 55650 : {
32 : 55650 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 15, __FILE__, __LINE__, false);
33 : 55650 : return true;
34 : : }
35 : : }
36 : : }
37 : : break;
38 : : }
39 : 616204 : case MINUS_EXPR:
40 : 616204 : {
41 : 616204 : tree _p0 = gimple_assign_rhs1 (_a1);
42 : 616204 : _p0 = do_valueize (valueize, _p0);
43 : 616204 : tree _p1 = gimple_assign_rhs2 (_a1);
44 : 616204 : _p1 = do_valueize (valueize, _p1);
45 : 616204 : {
46 : 616204 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
47 : 616204 : if ((ANY_INTEGRAL_TYPE_P (type) && TYPE_OVERFLOW_WRAPS (type))
48 : 1064931 : || (FLOAT_TYPE_P (type)
49 : 123115 : && !HONOR_SIGN_DEPENDENT_ROUNDING (type)
50 : 123090 : && !HONOR_SIGNED_ZEROS (type))
51 : : )
52 : : {
53 : 171277 : {
54 : 171277 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 16, __FILE__, __LINE__, false);
55 : 171277 : return true;
56 : : }
57 : : }
58 : : }
59 : 444927 : break;
60 : : }
61 : : default:;
62 : : }
63 : : }
64 : : break;
65 : 1426982 : case INTEGER_CST:
66 : 1426982 : {
67 : 1426982 : {
68 : 1426982 : if ((INTEGRAL_TYPE_P (type)
69 : 1426982 : && TYPE_UNSIGNED (type))
70 : 1938311 : || (!TYPE_OVERFLOW_SANITIZED (type)
71 : 510207 : && may_negate_without_overflow_p (t))
72 : : )
73 : : {
74 : 1424142 : {
75 : 1424142 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 17, __FILE__, __LINE__, false);
76 : 1424142 : return true;
77 : : }
78 : : }
79 : : }
80 : : break;
81 : : }
82 : 0 : case FIXED_CST:
83 : 0 : {
84 : 0 : {
85 : 0 : {
86 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 18, __FILE__, __LINE__, false);
87 : : return true;
88 : : }
89 : : }
90 : 483519 : break;
91 : : }
92 : 483519 : case REAL_CST:
93 : 483519 : {
94 : 483519 : {
95 : 483519 : if (REAL_VALUE_NEGATIVE (TREE_REAL_CST (t))
96 : : )
97 : : {
98 : 4011 : {
99 : 4011 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 19, __FILE__, __LINE__, false);
100 : 4011 : return true;
101 : : }
102 : : }
103 : : }
104 : : break;
105 : : }
106 : 24942 : case VECTOR_CST:
107 : 24942 : {
108 : 24942 : {
109 : 24942 : if (FLOAT_TYPE_P (TREE_TYPE (type)) || TYPE_OVERFLOW_WRAPS (type)
110 : : )
111 : : {
112 : 15174 : {
113 : 15174 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 20, __FILE__, __LINE__, false);
114 : 15174 : return true;
115 : : }
116 : : }
117 : : }
118 : : break;
119 : : }
120 : : default:;
121 : : }
122 : : return false;
123 : : }
124 : :
125 : : bool
126 : 22317700 : gimple_signed_integer_sat_add (tree t, tree *res_ops, tree (*valueize)(tree) ATTRIBUTE_UNUSED)
127 : : {
128 : 22317700 : const tree type = TREE_TYPE (t);
129 : 22317700 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
130 : 22317700 : switch (TREE_CODE (t))
131 : : {
132 : 18321139 : case SSA_NAME:
133 : 18321139 : if (gimple *_d1 = get_def (valueize, t))
134 : : {
135 : 18321139 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
136 : 17405684 : switch (gimple_assign_rhs_code (_a1))
137 : : {
138 : 144472 : case COND_EXPR:
139 : 144472 : {
140 : 144472 : tree _p0 = gimple_assign_rhs1 (_a1);
141 : 144472 : _p0 = do_valueize (valueize, _p0);
142 : 144472 : tree _p1 = gimple_assign_rhs2 (_a1);
143 : 144472 : _p1 = do_valueize (valueize, _p1);
144 : 144472 : tree _p2 = gimple_assign_rhs3 (_a1);
145 : 144472 : _p2 = do_valueize (valueize, _p2);
146 : 144472 : switch (TREE_CODE (_p0))
147 : : {
148 : 144472 : case SSA_NAME:
149 : 144472 : if (gimple *_d2 = get_def (valueize, _p0))
150 : : {
151 : 144472 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
152 : 145542 : switch (gimple_assign_rhs_code (_a2))
153 : : {
154 : 68069 : case LT_EXPR:
155 : 68069 : {
156 : 68069 : tree _q20 = gimple_assign_rhs1 (_a2);
157 : 68069 : _q20 = do_valueize (valueize, _q20);
158 : 68069 : tree _q21 = gimple_assign_rhs2 (_a2);
159 : 68069 : _q21 = do_valueize (valueize, _q21);
160 : 68069 : switch (TREE_CODE (_q20))
161 : : {
162 : 68069 : case SSA_NAME:
163 : 68069 : if (gimple *_d3 = get_def (valueize, _q20))
164 : : {
165 : 68069 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
166 : 72957 : switch (gimple_assign_rhs_code (_a3))
167 : : {
168 : 33 : case BIT_AND_EXPR:
169 : 33 : {
170 : 33 : tree _q30 = gimple_assign_rhs1 (_a3);
171 : 33 : _q30 = do_valueize (valueize, _q30);
172 : 33 : tree _q31 = gimple_assign_rhs2 (_a3);
173 : 33 : _q31 = do_valueize (valueize, _q31);
174 : 33 : if (tree_swap_operands_p (_q30, _q31))
175 : 0 : std::swap (_q30, _q31);
176 : 33 : switch (TREE_CODE (_q30))
177 : : {
178 : 33 : case SSA_NAME:
179 : 33 : if (gimple *_d4 = get_def (valueize, _q30))
180 : : {
181 : 33 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
182 : 0 : switch (gimple_assign_rhs_code (_a4))
183 : : {
184 : 0 : case BIT_XOR_EXPR:
185 : 0 : {
186 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
187 : 0 : _q40 = do_valueize (valueize, _q40);
188 : 0 : tree _q41 = gimple_assign_rhs2 (_a4);
189 : 0 : _q41 = do_valueize (valueize, _q41);
190 : 0 : if (tree_swap_operands_p (_q40, _q41))
191 : 0 : std::swap (_q40, _q41);
192 : 0 : {
193 : 0 : tree _q41_pops[1];
194 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
195 : : {
196 : 0 : tree _q60 = _q41_pops[0];
197 : 0 : switch (TREE_CODE (_q60))
198 : : {
199 : 0 : case SSA_NAME:
200 : 0 : if (gimple *_d5 = get_def (valueize, _q60))
201 : : {
202 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
203 : 0 : switch (gimple_assign_rhs_code (_a5))
204 : : {
205 : 0 : case PLUS_EXPR:
206 : 0 : {
207 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
208 : 0 : _q70 = do_valueize (valueize, _q70);
209 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
210 : 0 : _q71 = do_valueize (valueize, _q71);
211 : 0 : if (tree_swap_operands_p (_q70, _q71))
212 : 0 : std::swap (_q70, _q71);
213 : 0 : {
214 : 0 : tree _q70_pops[1];
215 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
216 : : {
217 : 0 : tree _q80 = _q70_pops[0];
218 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
219 : : {
220 : 0 : {
221 : 0 : tree _q71_pops[1];
222 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
223 : : {
224 : 0 : tree _q100 = _q71_pops[0];
225 : 0 : switch (TREE_CODE (_q31))
226 : : {
227 : 0 : case SSA_NAME:
228 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
229 : : {
230 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
231 : 0 : switch (gimple_assign_rhs_code (_a6))
232 : : {
233 : 0 : case BIT_NOT_EXPR:
234 : 0 : {
235 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
236 : 0 : _q120 = do_valueize (valueize, _q120);
237 : 0 : switch (TREE_CODE (_q120))
238 : : {
239 : 0 : case SSA_NAME:
240 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
241 : : {
242 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
243 : 0 : switch (gimple_assign_rhs_code (_a7))
244 : : {
245 : 0 : case BIT_XOR_EXPR:
246 : 0 : {
247 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
248 : 0 : _q130 = do_valueize (valueize, _q130);
249 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
250 : 0 : _q131 = do_valueize (valueize, _q131);
251 : 0 : if (tree_swap_operands_p (_q130, _q131))
252 : 0 : std::swap (_q130, _q131);
253 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
254 : : {
255 : 0 : if ((_q131 == _q100 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q100, 0) && types_match (_q131, _q100)))
256 : : {
257 : 0 : if (integer_zerop (_q21))
258 : : {
259 : 0 : {
260 : 0 : tree _p1_pops[1];
261 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
262 : : {
263 : 0 : tree _q170 = _p1_pops[0];
264 : 0 : if ((_q170 == _q40 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q40, 0) && types_match (_q170, _q40)))
265 : : {
266 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
267 : : {
268 : 0 : {
269 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
270 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
271 : : )
272 : : {
273 : 0 : {
274 : 0 : res_ops[0] = captures[0];
275 : 0 : res_ops[1] = captures[1];
276 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
277 : 0 : return true;
278 : : }
279 : : }
280 : : }
281 : : }
282 : : }
283 : : }
284 : : }
285 : : }
286 : : }
287 : : }
288 : 0 : if ((_q130 == _q100 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q100, 0) && types_match (_q130, _q100)))
289 : : {
290 : 0 : if ((_q131 == _q40 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q40, 0) && types_match (_q131, _q40)))
291 : : {
292 : 0 : if (integer_zerop (_q21))
293 : : {
294 : 0 : {
295 : 0 : tree _p1_pops[1];
296 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
297 : : {
298 : 0 : tree _q170 = _p1_pops[0];
299 : 0 : if ((_q170 == _q40 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q40, 0) && types_match (_q170, _q40)))
300 : : {
301 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
302 : : {
303 : 0 : {
304 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
305 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
306 : : )
307 : : {
308 : 0 : {
309 : 0 : res_ops[0] = captures[0];
310 : 0 : res_ops[1] = captures[1];
311 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
312 : 0 : return true;
313 : : }
314 : : }
315 : : }
316 : : }
317 : : }
318 : : }
319 : : }
320 : : }
321 : : }
322 : : }
323 : 0 : break;
324 : : }
325 : : default:;
326 : : }
327 : : }
328 : : break;
329 : : default:;
330 : : }
331 : : break;
332 : : }
333 : : default:;
334 : : }
335 : : }
336 : : break;
337 : : default:;
338 : : }
339 : : }
340 : : }
341 : : }
342 : : }
343 : : }
344 : 0 : break;
345 : : }
346 : : default:;
347 : : }
348 : : }
349 : : break;
350 : : default:;
351 : : }
352 : : }
353 : : }
354 : 0 : {
355 : 0 : tree _q40_pops[1];
356 : 0 : if (gimple_nop_convert (_q40, _q40_pops, valueize))
357 : : {
358 : 0 : tree _q50 = _q40_pops[0];
359 : 0 : switch (TREE_CODE (_q50))
360 : : {
361 : 0 : case SSA_NAME:
362 : 0 : if (gimple *_d5 = get_def (valueize, _q50))
363 : : {
364 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
365 : 0 : switch (gimple_assign_rhs_code (_a5))
366 : : {
367 : 0 : case PLUS_EXPR:
368 : 0 : {
369 : 0 : tree _q60 = gimple_assign_rhs1 (_a5);
370 : 0 : _q60 = do_valueize (valueize, _q60);
371 : 0 : tree _q61 = gimple_assign_rhs2 (_a5);
372 : 0 : _q61 = do_valueize (valueize, _q61);
373 : 0 : if (tree_swap_operands_p (_q60, _q61))
374 : 0 : std::swap (_q60, _q61);
375 : 0 : {
376 : 0 : tree _q60_pops[1];
377 : 0 : if (gimple_nop_convert (_q60, _q60_pops, valueize))
378 : : {
379 : 0 : tree _q70 = _q60_pops[0];
380 : 0 : switch (TREE_CODE (_q61))
381 : : {
382 : 0 : case INTEGER_CST:
383 : 0 : {
384 : 0 : if ((_q41 == _q70 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q70, 0) && types_match (_q41, _q70)))
385 : : {
386 : 0 : switch (TREE_CODE (_q31))
387 : : {
388 : 0 : case SSA_NAME:
389 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
390 : : {
391 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
392 : 0 : switch (gimple_assign_rhs_code (_a6))
393 : : {
394 : 0 : case BIT_XOR_EXPR:
395 : 0 : {
396 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
397 : 0 : _q110 = do_valueize (valueize, _q110);
398 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
399 : 0 : _q111 = do_valueize (valueize, _q111);
400 : 0 : if (tree_swap_operands_p (_q110, _q111))
401 : 0 : std::swap (_q110, _q111);
402 : 0 : if ((_q110 == _q70 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q70, 0) && types_match (_q110, _q70)))
403 : : {
404 : 0 : switch (TREE_CODE (_q111))
405 : : {
406 : 0 : case INTEGER_CST:
407 : 0 : {
408 : 0 : if (integer_zerop (_q21))
409 : : {
410 : 0 : {
411 : 0 : tree _p1_pops[1];
412 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
413 : : {
414 : 0 : tree _q150 = _p1_pops[0];
415 : 0 : if ((_q150 == _q70 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q70, 0) && types_match (_q150, _q70)))
416 : : {
417 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
418 : : {
419 : 0 : {
420 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q70, _q61, _q40, _q111 };
421 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
422 : : )
423 : : {
424 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
425 : : )
426 : : {
427 : 0 : {
428 : 0 : res_ops[0] = captures[0];
429 : 0 : res_ops[1] = captures[1];
430 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
431 : 0 : return true;
432 : : }
433 : : }
434 : : }
435 : : }
436 : : }
437 : : }
438 : : }
439 : : }
440 : : }
441 : : break;
442 : : }
443 : : default:;
444 : : }
445 : : }
446 : 0 : switch (TREE_CODE (_q110))
447 : : {
448 : 0 : case INTEGER_CST:
449 : 0 : {
450 : 0 : if ((_q111 == _q70 && ! TREE_SIDE_EFFECTS (_q111)) || (operand_equal_p (_q111, _q70, 0) && types_match (_q111, _q70)))
451 : : {
452 : 0 : if (integer_zerop (_q21))
453 : : {
454 : 0 : {
455 : 0 : tree _p1_pops[1];
456 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
457 : : {
458 : 0 : tree _q150 = _p1_pops[0];
459 : 0 : if ((_q150 == _q70 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q70, 0) && types_match (_q150, _q70)))
460 : : {
461 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
462 : : {
463 : 0 : {
464 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q70, _q61, _q40, _q110 };
465 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
466 : : )
467 : : {
468 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
469 : : )
470 : : {
471 : 0 : {
472 : 0 : res_ops[0] = captures[0];
473 : 0 : res_ops[1] = captures[1];
474 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
475 : 0 : return true;
476 : : }
477 : : }
478 : : }
479 : : }
480 : : }
481 : : }
482 : : }
483 : : }
484 : : }
485 : : }
486 : : break;
487 : : }
488 : : default:;
489 : : }
490 : 0 : break;
491 : : }
492 : : default:;
493 : : }
494 : : }
495 : : break;
496 : : default:;
497 : : }
498 : : }
499 : : break;
500 : : }
501 : 0 : default:;
502 : : }
503 : 0 : {
504 : 0 : tree _q61_pops[1];
505 : 0 : if (gimple_nop_convert (_q61, _q61_pops, valueize))
506 : : {
507 : 0 : tree _q90 = _q61_pops[0];
508 : 0 : if ((_q41 == _q70 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q70, 0) && types_match (_q41, _q70)))
509 : : {
510 : 0 : switch (TREE_CODE (_q31))
511 : : {
512 : 0 : case SSA_NAME:
513 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
514 : : {
515 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
516 : 0 : switch (gimple_assign_rhs_code (_a6))
517 : : {
518 : 0 : case BIT_NOT_EXPR:
519 : 0 : {
520 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
521 : 0 : _q120 = do_valueize (valueize, _q120);
522 : 0 : switch (TREE_CODE (_q120))
523 : : {
524 : 0 : case SSA_NAME:
525 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
526 : : {
527 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
528 : 0 : switch (gimple_assign_rhs_code (_a7))
529 : : {
530 : 0 : case BIT_XOR_EXPR:
531 : 0 : {
532 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
533 : 0 : _q130 = do_valueize (valueize, _q130);
534 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
535 : 0 : _q131 = do_valueize (valueize, _q131);
536 : 0 : if (tree_swap_operands_p (_q130, _q131))
537 : 0 : std::swap (_q130, _q131);
538 : 0 : if ((_q130 == _q70 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q70, 0) && types_match (_q130, _q70)))
539 : : {
540 : 0 : if ((_q131 == _q90 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q90, 0) && types_match (_q131, _q90)))
541 : : {
542 : 0 : if (integer_zerop (_q21))
543 : : {
544 : 0 : {
545 : 0 : tree _p1_pops[1];
546 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
547 : : {
548 : 0 : tree _q170 = _p1_pops[0];
549 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
550 : : {
551 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
552 : : {
553 : 0 : {
554 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q70, _q90, _q40 };
555 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
556 : : )
557 : : {
558 : 0 : {
559 : 0 : res_ops[0] = captures[0];
560 : 0 : res_ops[1] = captures[1];
561 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
562 : 0 : return true;
563 : : }
564 : : }
565 : : }
566 : : }
567 : : }
568 : : }
569 : : }
570 : : }
571 : : }
572 : : }
573 : 0 : if ((_q130 == _q90 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q90, 0) && types_match (_q130, _q90)))
574 : : {
575 : 0 : if ((_q131 == _q70 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q70, 0) && types_match (_q131, _q70)))
576 : : {
577 : 0 : if (integer_zerop (_q21))
578 : : {
579 : 0 : {
580 : 0 : tree _p1_pops[1];
581 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
582 : : {
583 : 0 : tree _q170 = _p1_pops[0];
584 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
585 : : {
586 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
587 : : {
588 : 0 : {
589 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q70, _q90, _q40 };
590 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
591 : : )
592 : : {
593 : 0 : {
594 : 0 : res_ops[0] = captures[0];
595 : 0 : res_ops[1] = captures[1];
596 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
597 : 0 : return true;
598 : : }
599 : : }
600 : : }
601 : : }
602 : : }
603 : : }
604 : : }
605 : : }
606 : : }
607 : : }
608 : 0 : break;
609 : : }
610 : : default:;
611 : : }
612 : : }
613 : : break;
614 : : default:;
615 : : }
616 : : break;
617 : : }
618 : : default:;
619 : : }
620 : : }
621 : : break;
622 : : default:;
623 : : }
624 : : }
625 : : }
626 : : }
627 : : }
628 : : }
629 : 0 : break;
630 : : }
631 : : default:;
632 : : }
633 : : }
634 : : break;
635 : : default:;
636 : : }
637 : : }
638 : : }
639 : 0 : switch (TREE_CODE (_q41))
640 : : {
641 : 0 : case INTEGER_CST:
642 : 0 : {
643 : 0 : switch (TREE_CODE (_q31))
644 : : {
645 : 0 : case SSA_NAME:
646 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
647 : : {
648 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
649 : 0 : switch (gimple_assign_rhs_code (_a5))
650 : : {
651 : 0 : case BIT_XOR_EXPR:
652 : 0 : {
653 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
654 : 0 : _q70 = do_valueize (valueize, _q70);
655 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
656 : 0 : _q71 = do_valueize (valueize, _q71);
657 : 0 : if (tree_swap_operands_p (_q70, _q71))
658 : 0 : std::swap (_q70, _q71);
659 : 0 : if ((_q70 == _q40 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q40, 0) && types_match (_q70, _q40)))
660 : : {
661 : 0 : {
662 : 0 : tree _q71_pops[1];
663 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
664 : : {
665 : 0 : tree _q90 = _q71_pops[0];
666 : 0 : switch (TREE_CODE (_q90))
667 : : {
668 : 0 : case SSA_NAME:
669 : 0 : if (gimple *_d6 = get_def (valueize, _q90))
670 : : {
671 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
672 : 0 : switch (gimple_assign_rhs_code (_a6))
673 : : {
674 : 0 : case PLUS_EXPR:
675 : 0 : {
676 : 0 : tree _q100 = gimple_assign_rhs1 (_a6);
677 : 0 : _q100 = do_valueize (valueize, _q100);
678 : 0 : tree _q101 = gimple_assign_rhs2 (_a6);
679 : 0 : _q101 = do_valueize (valueize, _q101);
680 : 0 : if (tree_swap_operands_p (_q100, _q101))
681 : 0 : std::swap (_q100, _q101);
682 : 0 : {
683 : 0 : tree _q100_pops[1];
684 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
685 : : {
686 : 0 : tree _q110 = _q100_pops[0];
687 : 0 : if ((_q110 == _q40 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q40, 0) && types_match (_q110, _q40)))
688 : : {
689 : 0 : switch (TREE_CODE (_q101))
690 : : {
691 : 0 : case INTEGER_CST:
692 : 0 : {
693 : 0 : if (integer_zerop (_q21))
694 : : {
695 : 0 : {
696 : 0 : tree _p1_pops[1];
697 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
698 : : {
699 : 0 : tree _q150 = _p1_pops[0];
700 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
701 : : {
702 : 0 : if ((_p2 == _q71 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q71, 0) && types_match (_p2, _q71)))
703 : : {
704 : 0 : {
705 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q101, _q71, _q41 };
706 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
707 : : )
708 : : {
709 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
710 : : )
711 : : {
712 : 0 : {
713 : 0 : res_ops[0] = captures[0];
714 : 0 : res_ops[1] = captures[1];
715 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
716 : 0 : return true;
717 : : }
718 : : }
719 : : }
720 : : }
721 : : }
722 : : }
723 : : }
724 : : }
725 : : }
726 : : break;
727 : : }
728 : : default:;
729 : : }
730 : : }
731 : : }
732 : : }
733 : 0 : break;
734 : : }
735 : : default:;
736 : : }
737 : : }
738 : : break;
739 : : default:;
740 : : }
741 : : }
742 : : }
743 : : }
744 : 0 : break;
745 : : }
746 : : default:;
747 : : }
748 : : }
749 : : break;
750 : : default:;
751 : : }
752 : : break;
753 : : }
754 : 0 : default:;
755 : : }
756 : 0 : {
757 : 0 : tree _q41_pops[1];
758 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
759 : : {
760 : 0 : tree _q60 = _q41_pops[0];
761 : 0 : switch (TREE_CODE (_q60))
762 : : {
763 : 0 : case SSA_NAME:
764 : 0 : if (gimple *_d5 = get_def (valueize, _q60))
765 : : {
766 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
767 : 0 : switch (gimple_assign_rhs_code (_a5))
768 : : {
769 : 0 : case PLUS_EXPR:
770 : 0 : {
771 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
772 : 0 : _q70 = do_valueize (valueize, _q70);
773 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
774 : 0 : _q71 = do_valueize (valueize, _q71);
775 : 0 : if (tree_swap_operands_p (_q70, _q71))
776 : 0 : std::swap (_q70, _q71);
777 : 0 : {
778 : 0 : tree _q70_pops[1];
779 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
780 : : {
781 : 0 : tree _q80 = _q70_pops[0];
782 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
783 : : {
784 : 0 : switch (TREE_CODE (_q71))
785 : : {
786 : 0 : case INTEGER_CST:
787 : 0 : {
788 : 0 : switch (TREE_CODE (_q31))
789 : : {
790 : 0 : case SSA_NAME:
791 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
792 : : {
793 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
794 : 0 : switch (gimple_assign_rhs_code (_a6))
795 : : {
796 : 0 : case BIT_XOR_EXPR:
797 : 0 : {
798 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
799 : 0 : _q110 = do_valueize (valueize, _q110);
800 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
801 : 0 : _q111 = do_valueize (valueize, _q111);
802 : 0 : if (tree_swap_operands_p (_q110, _q111))
803 : 0 : std::swap (_q110, _q111);
804 : 0 : if ((_q110 == _q40 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q40, 0) && types_match (_q110, _q40)))
805 : : {
806 : 0 : switch (TREE_CODE (_q111))
807 : : {
808 : 0 : case INTEGER_CST:
809 : 0 : {
810 : 0 : if (integer_zerop (_q21))
811 : : {
812 : 0 : {
813 : 0 : tree _p1_pops[1];
814 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
815 : : {
816 : 0 : tree _q150 = _p1_pops[0];
817 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
818 : : {
819 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
820 : : {
821 : 0 : {
822 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q71, _q41, _q111 };
823 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
824 : : )
825 : : {
826 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
827 : : )
828 : : {
829 : 0 : {
830 : 0 : res_ops[0] = captures[0];
831 : 0 : res_ops[1] = captures[1];
832 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
833 : 0 : return true;
834 : : }
835 : : }
836 : : }
837 : : }
838 : : }
839 : : }
840 : : }
841 : : }
842 : : }
843 : : break;
844 : : }
845 : : default:;
846 : : }
847 : : }
848 : 0 : switch (TREE_CODE (_q110))
849 : : {
850 : 0 : case INTEGER_CST:
851 : 0 : {
852 : 0 : if ((_q111 == _q40 && ! TREE_SIDE_EFFECTS (_q111)) || (operand_equal_p (_q111, _q40, 0) && types_match (_q111, _q40)))
853 : : {
854 : 0 : if (integer_zerop (_q21))
855 : : {
856 : 0 : {
857 : 0 : tree _p1_pops[1];
858 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
859 : : {
860 : 0 : tree _q150 = _p1_pops[0];
861 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
862 : : {
863 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
864 : : {
865 : 0 : {
866 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q71, _q41, _q110 };
867 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
868 : : )
869 : : {
870 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
871 : : )
872 : : {
873 : 0 : {
874 : 0 : res_ops[0] = captures[0];
875 : 0 : res_ops[1] = captures[1];
876 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
877 : 0 : return true;
878 : : }
879 : : }
880 : : }
881 : : }
882 : : }
883 : : }
884 : : }
885 : : }
886 : : }
887 : : }
888 : : break;
889 : : }
890 : : default:;
891 : : }
892 : 0 : break;
893 : : }
894 : : default:;
895 : : }
896 : : }
897 : : break;
898 : : default:;
899 : : }
900 : : break;
901 : : }
902 : : default:;
903 : : }
904 : : }
905 : : }
906 : : }
907 : 0 : break;
908 : : }
909 : : default:;
910 : : }
911 : : }
912 : : break;
913 : : default:;
914 : : }
915 : : }
916 : : }
917 : 0 : switch (TREE_CODE (_q40))
918 : : {
919 : 0 : case INTEGER_CST:
920 : 0 : {
921 : 0 : switch (TREE_CODE (_q31))
922 : : {
923 : 0 : case SSA_NAME:
924 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
925 : : {
926 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
927 : 0 : switch (gimple_assign_rhs_code (_a5))
928 : : {
929 : 0 : case BIT_XOR_EXPR:
930 : 0 : {
931 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
932 : 0 : _q70 = do_valueize (valueize, _q70);
933 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
934 : 0 : _q71 = do_valueize (valueize, _q71);
935 : 0 : if (tree_swap_operands_p (_q70, _q71))
936 : 0 : std::swap (_q70, _q71);
937 : 0 : if ((_q70 == _q41 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q41, 0) && types_match (_q70, _q41)))
938 : : {
939 : 0 : {
940 : 0 : tree _q71_pops[1];
941 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
942 : : {
943 : 0 : tree _q90 = _q71_pops[0];
944 : 0 : switch (TREE_CODE (_q90))
945 : : {
946 : 0 : case SSA_NAME:
947 : 0 : if (gimple *_d6 = get_def (valueize, _q90))
948 : : {
949 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
950 : 0 : switch (gimple_assign_rhs_code (_a6))
951 : : {
952 : 0 : case PLUS_EXPR:
953 : 0 : {
954 : 0 : tree _q100 = gimple_assign_rhs1 (_a6);
955 : 0 : _q100 = do_valueize (valueize, _q100);
956 : 0 : tree _q101 = gimple_assign_rhs2 (_a6);
957 : 0 : _q101 = do_valueize (valueize, _q101);
958 : 0 : if (tree_swap_operands_p (_q100, _q101))
959 : 0 : std::swap (_q100, _q101);
960 : 0 : {
961 : 0 : tree _q100_pops[1];
962 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
963 : : {
964 : 0 : tree _q110 = _q100_pops[0];
965 : 0 : if ((_q110 == _q41 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q41, 0) && types_match (_q110, _q41)))
966 : : {
967 : 0 : switch (TREE_CODE (_q101))
968 : : {
969 : 0 : case INTEGER_CST:
970 : 0 : {
971 : 0 : if (integer_zerop (_q21))
972 : : {
973 : 0 : {
974 : 0 : tree _p1_pops[1];
975 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
976 : : {
977 : 0 : tree _q150 = _p1_pops[0];
978 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
979 : : {
980 : 0 : if ((_p2 == _q71 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q71, 0) && types_match (_p2, _q71)))
981 : : {
982 : 0 : {
983 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q41, _q101, _q71, _q40 };
984 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
985 : : )
986 : : {
987 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
988 : : )
989 : : {
990 : 0 : {
991 : 0 : res_ops[0] = captures[0];
992 : 0 : res_ops[1] = captures[1];
993 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
994 : 0 : return true;
995 : : }
996 : : }
997 : : }
998 : : }
999 : : }
1000 : : }
1001 : : }
1002 : : }
1003 : : }
1004 : : break;
1005 : : }
1006 : : default:;
1007 : : }
1008 : : }
1009 : : }
1010 : : }
1011 : 0 : break;
1012 : : }
1013 : : default:;
1014 : : }
1015 : : }
1016 : : break;
1017 : : default:;
1018 : : }
1019 : : }
1020 : : }
1021 : : }
1022 : 0 : {
1023 : 0 : tree _q70_pops[1];
1024 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
1025 : : {
1026 : 0 : tree _q80 = _q70_pops[0];
1027 : 0 : switch (TREE_CODE (_q80))
1028 : : {
1029 : 0 : case SSA_NAME:
1030 : 0 : if (gimple *_d6 = get_def (valueize, _q80))
1031 : : {
1032 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
1033 : 0 : switch (gimple_assign_rhs_code (_a6))
1034 : : {
1035 : 0 : case PLUS_EXPR:
1036 : 0 : {
1037 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
1038 : 0 : _q90 = do_valueize (valueize, _q90);
1039 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
1040 : 0 : _q91 = do_valueize (valueize, _q91);
1041 : 0 : if (tree_swap_operands_p (_q90, _q91))
1042 : 0 : std::swap (_q90, _q91);
1043 : 0 : {
1044 : 0 : tree _q90_pops[1];
1045 : 0 : if (gimple_nop_convert (_q90, _q90_pops, valueize))
1046 : : {
1047 : 0 : tree _q100 = _q90_pops[0];
1048 : 0 : if ((_q100 == _q41 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q41, 0) && types_match (_q100, _q41)))
1049 : : {
1050 : 0 : switch (TREE_CODE (_q91))
1051 : : {
1052 : 0 : case INTEGER_CST:
1053 : 0 : {
1054 : 0 : if ((_q71 == _q41 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q41, 0) && types_match (_q71, _q41)))
1055 : : {
1056 : 0 : if (integer_zerop (_q21))
1057 : : {
1058 : 0 : {
1059 : 0 : tree _p1_pops[1];
1060 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
1061 : : {
1062 : 0 : tree _q150 = _p1_pops[0];
1063 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
1064 : : {
1065 : 0 : if ((_p2 == _q70 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q70, 0) && types_match (_p2, _q70)))
1066 : : {
1067 : 0 : {
1068 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q41, _q91, _q70, _q40 };
1069 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1070 : : )
1071 : : {
1072 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
1073 : : )
1074 : : {
1075 : 0 : {
1076 : 0 : res_ops[0] = captures[0];
1077 : 0 : res_ops[1] = captures[1];
1078 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
1079 : 0 : return true;
1080 : : }
1081 : : }
1082 : : }
1083 : : }
1084 : : }
1085 : : }
1086 : : }
1087 : : }
1088 : : }
1089 : : }
1090 : : break;
1091 : : }
1092 : : default:;
1093 : : }
1094 : : }
1095 : : }
1096 : : }
1097 : 0 : break;
1098 : : }
1099 : : default:;
1100 : : }
1101 : : }
1102 : : break;
1103 : : default:;
1104 : : }
1105 : : }
1106 : : }
1107 : 0 : break;
1108 : : }
1109 : : default:;
1110 : : }
1111 : : }
1112 : : break;
1113 : : default:;
1114 : : }
1115 : : break;
1116 : : }
1117 : 0 : default:;
1118 : : }
1119 : 0 : switch (TREE_CODE (_q41))
1120 : : {
1121 : 0 : case INTEGER_CST:
1122 : 0 : {
1123 : 0 : switch (TREE_CODE (_q31))
1124 : : {
1125 : 0 : case SSA_NAME:
1126 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
1127 : : {
1128 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
1129 : 0 : switch (gimple_assign_rhs_code (_a5))
1130 : : {
1131 : 0 : case BIT_XOR_EXPR:
1132 : 0 : {
1133 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
1134 : 0 : _q70 = do_valueize (valueize, _q70);
1135 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
1136 : 0 : _q71 = do_valueize (valueize, _q71);
1137 : 0 : if (tree_swap_operands_p (_q70, _q71))
1138 : 0 : std::swap (_q70, _q71);
1139 : 0 : {
1140 : 0 : tree _q70_pops[1];
1141 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
1142 : : {
1143 : 0 : tree _q80 = _q70_pops[0];
1144 : 0 : switch (TREE_CODE (_q80))
1145 : : {
1146 : 0 : case SSA_NAME:
1147 : 0 : if (gimple *_d6 = get_def (valueize, _q80))
1148 : : {
1149 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
1150 : 0 : switch (gimple_assign_rhs_code (_a6))
1151 : : {
1152 : 0 : case PLUS_EXPR:
1153 : 0 : {
1154 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
1155 : 0 : _q90 = do_valueize (valueize, _q90);
1156 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
1157 : 0 : _q91 = do_valueize (valueize, _q91);
1158 : 0 : if (tree_swap_operands_p (_q90, _q91))
1159 : 0 : std::swap (_q90, _q91);
1160 : 0 : {
1161 : 0 : tree _q90_pops[1];
1162 : 0 : if (gimple_nop_convert (_q90, _q90_pops, valueize))
1163 : : {
1164 : 0 : tree _q100 = _q90_pops[0];
1165 : 0 : if ((_q100 == _q40 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q40, 0) && types_match (_q100, _q40)))
1166 : : {
1167 : 0 : switch (TREE_CODE (_q91))
1168 : : {
1169 : 0 : case INTEGER_CST:
1170 : 0 : {
1171 : 0 : if ((_q71 == _q40 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q40, 0) && types_match (_q71, _q40)))
1172 : : {
1173 : 0 : if (integer_zerop (_q21))
1174 : : {
1175 : 0 : {
1176 : 0 : tree _p1_pops[1];
1177 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
1178 : : {
1179 : 0 : tree _q150 = _p1_pops[0];
1180 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
1181 : : {
1182 : 0 : if ((_p2 == _q70 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q70, 0) && types_match (_p2, _q70)))
1183 : : {
1184 : 0 : {
1185 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q91, _q70, _q41 };
1186 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1187 : : )
1188 : : {
1189 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
1190 : : )
1191 : : {
1192 : 0 : {
1193 : 0 : res_ops[0] = captures[0];
1194 : 0 : res_ops[1] = captures[1];
1195 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
1196 : 0 : return true;
1197 : : }
1198 : : }
1199 : : }
1200 : : }
1201 : : }
1202 : : }
1203 : : }
1204 : : }
1205 : : }
1206 : : }
1207 : : break;
1208 : : }
1209 : : default:;
1210 : : }
1211 : : }
1212 : : }
1213 : : }
1214 : 0 : break;
1215 : : }
1216 : : default:;
1217 : : }
1218 : : }
1219 : : break;
1220 : : default:;
1221 : : }
1222 : : }
1223 : : }
1224 : 0 : break;
1225 : : }
1226 : : default:;
1227 : : }
1228 : : }
1229 : : break;
1230 : : default:;
1231 : : }
1232 : : break;
1233 : : }
1234 : : default:;
1235 : : }
1236 : 22317700 : break;
1237 : : }
1238 : 0 : case BIT_NOT_EXPR:
1239 : 0 : {
1240 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
1241 : 0 : _q40 = do_valueize (valueize, _q40);
1242 : 0 : switch (TREE_CODE (_q40))
1243 : : {
1244 : 0 : case SSA_NAME:
1245 : 0 : if (gimple *_d5 = get_def (valueize, _q40))
1246 : : {
1247 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
1248 : 0 : switch (gimple_assign_rhs_code (_a5))
1249 : : {
1250 : 0 : case BIT_XOR_EXPR:
1251 : 0 : {
1252 : 0 : tree _q50 = gimple_assign_rhs1 (_a5);
1253 : 0 : _q50 = do_valueize (valueize, _q50);
1254 : 0 : tree _q51 = gimple_assign_rhs2 (_a5);
1255 : 0 : _q51 = do_valueize (valueize, _q51);
1256 : 0 : if (tree_swap_operands_p (_q50, _q51))
1257 : 0 : std::swap (_q50, _q51);
1258 : 0 : switch (TREE_CODE (_q31))
1259 : : {
1260 : 0 : case SSA_NAME:
1261 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
1262 : : {
1263 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
1264 : 0 : switch (gimple_assign_rhs_code (_a6))
1265 : : {
1266 : 0 : case BIT_XOR_EXPR:
1267 : 0 : {
1268 : 0 : tree _q80 = gimple_assign_rhs1 (_a6);
1269 : 0 : _q80 = do_valueize (valueize, _q80);
1270 : 0 : tree _q81 = gimple_assign_rhs2 (_a6);
1271 : 0 : _q81 = do_valueize (valueize, _q81);
1272 : 0 : if (tree_swap_operands_p (_q80, _q81))
1273 : 0 : std::swap (_q80, _q81);
1274 : 0 : if ((_q80 == _q50 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q50, 0) && types_match (_q80, _q50)))
1275 : : {
1276 : 0 : {
1277 : 0 : tree _q81_pops[1];
1278 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
1279 : : {
1280 : 0 : tree _q100 = _q81_pops[0];
1281 : 0 : switch (TREE_CODE (_q100))
1282 : : {
1283 : 0 : case SSA_NAME:
1284 : 0 : if (gimple *_d7 = get_def (valueize, _q100))
1285 : : {
1286 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
1287 : 0 : switch (gimple_assign_rhs_code (_a7))
1288 : : {
1289 : 0 : case PLUS_EXPR:
1290 : 0 : {
1291 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
1292 : 0 : _q110 = do_valueize (valueize, _q110);
1293 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
1294 : 0 : _q111 = do_valueize (valueize, _q111);
1295 : 0 : if (tree_swap_operands_p (_q110, _q111))
1296 : 0 : std::swap (_q110, _q111);
1297 : 0 : {
1298 : 0 : tree _q110_pops[1];
1299 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
1300 : : {
1301 : 0 : tree _q120 = _q110_pops[0];
1302 : 0 : if ((_q120 == _q50 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q50, 0) && types_match (_q120, _q50)))
1303 : : {
1304 : 0 : {
1305 : 0 : tree _q111_pops[1];
1306 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
1307 : : {
1308 : 0 : tree _q140 = _q111_pops[0];
1309 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
1310 : : {
1311 : 0 : if (integer_zerop (_q21))
1312 : : {
1313 : 0 : {
1314 : 0 : tree _p1_pops[1];
1315 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
1316 : : {
1317 : 0 : tree _q170 = _p1_pops[0];
1318 : 0 : if ((_q170 == _q50 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q50, 0) && types_match (_q170, _q50)))
1319 : : {
1320 : 0 : if ((_p2 == _q81 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q81, 0) && types_match (_p2, _q81)))
1321 : : {
1322 : 0 : {
1323 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
1324 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1325 : : )
1326 : : {
1327 : 0 : {
1328 : 0 : res_ops[0] = captures[0];
1329 : 0 : res_ops[1] = captures[1];
1330 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
1331 : 0 : return true;
1332 : : }
1333 : : }
1334 : : }
1335 : : }
1336 : : }
1337 : : }
1338 : : }
1339 : : }
1340 : : }
1341 : : }
1342 : : }
1343 : : }
1344 : : }
1345 : : }
1346 : 0 : break;
1347 : : }
1348 : : default:;
1349 : : }
1350 : : }
1351 : : break;
1352 : : default:;
1353 : : }
1354 : : }
1355 : : }
1356 : : }
1357 : 0 : if ((_q80 == _q51 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q51, 0) && types_match (_q80, _q51)))
1358 : : {
1359 : 0 : {
1360 : 0 : tree _q81_pops[1];
1361 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
1362 : : {
1363 : 0 : tree _q100 = _q81_pops[0];
1364 : 0 : switch (TREE_CODE (_q100))
1365 : : {
1366 : 0 : case SSA_NAME:
1367 : 0 : if (gimple *_d7 = get_def (valueize, _q100))
1368 : : {
1369 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
1370 : 0 : switch (gimple_assign_rhs_code (_a7))
1371 : : {
1372 : 0 : case PLUS_EXPR:
1373 : 0 : {
1374 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
1375 : 0 : _q110 = do_valueize (valueize, _q110);
1376 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
1377 : 0 : _q111 = do_valueize (valueize, _q111);
1378 : 0 : if (tree_swap_operands_p (_q110, _q111))
1379 : 0 : std::swap (_q110, _q111);
1380 : 0 : {
1381 : 0 : tree _q110_pops[1];
1382 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
1383 : : {
1384 : 0 : tree _q120 = _q110_pops[0];
1385 : 0 : if ((_q120 == _q51 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q51, 0) && types_match (_q120, _q51)))
1386 : : {
1387 : 0 : {
1388 : 0 : tree _q111_pops[1];
1389 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
1390 : : {
1391 : 0 : tree _q140 = _q111_pops[0];
1392 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
1393 : : {
1394 : 0 : if (integer_zerop (_q21))
1395 : : {
1396 : 0 : {
1397 : 0 : tree _p1_pops[1];
1398 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
1399 : : {
1400 : 0 : tree _q170 = _p1_pops[0];
1401 : 0 : if ((_q170 == _q51 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q51, 0) && types_match (_q170, _q51)))
1402 : : {
1403 : 0 : if ((_p2 == _q81 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q81, 0) && types_match (_p2, _q81)))
1404 : : {
1405 : 0 : {
1406 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
1407 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1408 : : )
1409 : : {
1410 : 0 : {
1411 : 0 : res_ops[0] = captures[0];
1412 : 0 : res_ops[1] = captures[1];
1413 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
1414 : 0 : return true;
1415 : : }
1416 : : }
1417 : : }
1418 : : }
1419 : : }
1420 : : }
1421 : : }
1422 : : }
1423 : : }
1424 : : }
1425 : : }
1426 : : }
1427 : : }
1428 : : }
1429 : 0 : break;
1430 : : }
1431 : : default:;
1432 : : }
1433 : : }
1434 : : break;
1435 : : default:;
1436 : : }
1437 : : }
1438 : : }
1439 : : }
1440 : 0 : {
1441 : 0 : tree _q80_pops[1];
1442 : 0 : if (gimple_nop_convert (_q80, _q80_pops, valueize))
1443 : : {
1444 : 0 : tree _q90 = _q80_pops[0];
1445 : 0 : switch (TREE_CODE (_q90))
1446 : : {
1447 : 0 : case SSA_NAME:
1448 : 0 : if (gimple *_d7 = get_def (valueize, _q90))
1449 : : {
1450 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
1451 : 0 : switch (gimple_assign_rhs_code (_a7))
1452 : : {
1453 : 0 : case PLUS_EXPR:
1454 : 0 : {
1455 : 0 : tree _q100 = gimple_assign_rhs1 (_a7);
1456 : 0 : _q100 = do_valueize (valueize, _q100);
1457 : 0 : tree _q101 = gimple_assign_rhs2 (_a7);
1458 : 0 : _q101 = do_valueize (valueize, _q101);
1459 : 0 : if (tree_swap_operands_p (_q100, _q101))
1460 : 0 : std::swap (_q100, _q101);
1461 : 0 : {
1462 : 0 : tree _q100_pops[1];
1463 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
1464 : : {
1465 : 0 : tree _q110 = _q100_pops[0];
1466 : 0 : if ((_q110 == _q50 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q50, 0) && types_match (_q110, _q50)))
1467 : : {
1468 : 0 : {
1469 : 0 : tree _q101_pops[1];
1470 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
1471 : : {
1472 : 0 : tree _q130 = _q101_pops[0];
1473 : 0 : if ((_q130 == _q51 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q51, 0) && types_match (_q130, _q51)))
1474 : : {
1475 : 0 : if ((_q81 == _q50 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q50, 0) && types_match (_q81, _q50)))
1476 : : {
1477 : 0 : if (integer_zerop (_q21))
1478 : : {
1479 : 0 : {
1480 : 0 : tree _p1_pops[1];
1481 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
1482 : : {
1483 : 0 : tree _q170 = _p1_pops[0];
1484 : 0 : if ((_q170 == _q50 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q50, 0) && types_match (_q170, _q50)))
1485 : : {
1486 : 0 : if ((_p2 == _q80 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q80, 0) && types_match (_p2, _q80)))
1487 : : {
1488 : 0 : {
1489 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q80 };
1490 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1491 : : )
1492 : : {
1493 : 0 : {
1494 : 0 : res_ops[0] = captures[0];
1495 : 0 : res_ops[1] = captures[1];
1496 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
1497 : 0 : return true;
1498 : : }
1499 : : }
1500 : : }
1501 : : }
1502 : : }
1503 : : }
1504 : : }
1505 : : }
1506 : : }
1507 : : }
1508 : : }
1509 : : }
1510 : : }
1511 : 0 : if ((_q110 == _q51 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q51, 0) && types_match (_q110, _q51)))
1512 : : {
1513 : 0 : {
1514 : 0 : tree _q101_pops[1];
1515 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
1516 : : {
1517 : 0 : tree _q130 = _q101_pops[0];
1518 : 0 : if ((_q130 == _q50 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q50, 0) && types_match (_q130, _q50)))
1519 : : {
1520 : 0 : if ((_q81 == _q51 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q51, 0) && types_match (_q81, _q51)))
1521 : : {
1522 : 0 : if (integer_zerop (_q21))
1523 : : {
1524 : 0 : {
1525 : 0 : tree _p1_pops[1];
1526 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
1527 : : {
1528 : 0 : tree _q170 = _p1_pops[0];
1529 : 0 : if ((_q170 == _q51 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q51, 0) && types_match (_q170, _q51)))
1530 : : {
1531 : 0 : if ((_p2 == _q80 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q80, 0) && types_match (_p2, _q80)))
1532 : : {
1533 : 0 : {
1534 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q80 };
1535 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1536 : : )
1537 : : {
1538 : 0 : {
1539 : 0 : res_ops[0] = captures[0];
1540 : 0 : res_ops[1] = captures[1];
1541 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
1542 : 0 : return true;
1543 : : }
1544 : : }
1545 : : }
1546 : : }
1547 : : }
1548 : : }
1549 : : }
1550 : : }
1551 : : }
1552 : : }
1553 : : }
1554 : : }
1555 : : }
1556 : : }
1557 : : }
1558 : 0 : break;
1559 : : }
1560 : : default:;
1561 : : }
1562 : : }
1563 : : break;
1564 : : default:;
1565 : : }
1566 : : }
1567 : : }
1568 : 0 : break;
1569 : : }
1570 : : default:;
1571 : : }
1572 : : }
1573 : : break;
1574 : : default:;
1575 : : }
1576 : 22317700 : break;
1577 : : }
1578 : : default:;
1579 : : }
1580 : : }
1581 : : break;
1582 : : default:;
1583 : : }
1584 : : break;
1585 : : }
1586 : : default:;
1587 : : }
1588 : : }
1589 : : break;
1590 : : default:;
1591 : : }
1592 : 22317700 : break;
1593 : : }
1594 : : default:;
1595 : : }
1596 : : }
1597 : : break;
1598 : : default:;
1599 : : }
1600 : : break;
1601 : : }
1602 : 4469 : case GE_EXPR:
1603 : 4469 : {
1604 : 4469 : tree _q20 = gimple_assign_rhs1 (_a2);
1605 : 4469 : _q20 = do_valueize (valueize, _q20);
1606 : 4469 : tree _q21 = gimple_assign_rhs2 (_a2);
1607 : 4469 : _q21 = do_valueize (valueize, _q21);
1608 : 4469 : switch (TREE_CODE (_q20))
1609 : : {
1610 : 4469 : case SSA_NAME:
1611 : 4469 : if (gimple *_d3 = get_def (valueize, _q20))
1612 : : {
1613 : 4469 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
1614 : 5484 : switch (gimple_assign_rhs_code (_a3))
1615 : : {
1616 : 6 : case BIT_AND_EXPR:
1617 : 6 : {
1618 : 6 : tree _q30 = gimple_assign_rhs1 (_a3);
1619 : 6 : _q30 = do_valueize (valueize, _q30);
1620 : 6 : tree _q31 = gimple_assign_rhs2 (_a3);
1621 : 6 : _q31 = do_valueize (valueize, _q31);
1622 : 6 : if (tree_swap_operands_p (_q30, _q31))
1623 : 0 : std::swap (_q30, _q31);
1624 : 6 : switch (TREE_CODE (_q30))
1625 : : {
1626 : 6 : case SSA_NAME:
1627 : 6 : if (gimple *_d4 = get_def (valueize, _q30))
1628 : : {
1629 : 6 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
1630 : 6 : switch (gimple_assign_rhs_code (_a4))
1631 : : {
1632 : 0 : case BIT_XOR_EXPR:
1633 : 0 : {
1634 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
1635 : 0 : _q40 = do_valueize (valueize, _q40);
1636 : 0 : tree _q41 = gimple_assign_rhs2 (_a4);
1637 : 0 : _q41 = do_valueize (valueize, _q41);
1638 : 0 : if (tree_swap_operands_p (_q40, _q41))
1639 : 0 : std::swap (_q40, _q41);
1640 : 0 : {
1641 : 0 : tree _q41_pops[1];
1642 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
1643 : : {
1644 : 0 : tree _q60 = _q41_pops[0];
1645 : 0 : switch (TREE_CODE (_q60))
1646 : : {
1647 : 0 : case SSA_NAME:
1648 : 0 : if (gimple *_d5 = get_def (valueize, _q60))
1649 : : {
1650 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
1651 : 0 : switch (gimple_assign_rhs_code (_a5))
1652 : : {
1653 : 0 : case PLUS_EXPR:
1654 : 0 : {
1655 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
1656 : 0 : _q70 = do_valueize (valueize, _q70);
1657 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
1658 : 0 : _q71 = do_valueize (valueize, _q71);
1659 : 0 : if (tree_swap_operands_p (_q70, _q71))
1660 : 0 : std::swap (_q70, _q71);
1661 : 0 : {
1662 : 0 : tree _q70_pops[1];
1663 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
1664 : : {
1665 : 0 : tree _q80 = _q70_pops[0];
1666 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
1667 : : {
1668 : 0 : {
1669 : 0 : tree _q71_pops[1];
1670 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
1671 : : {
1672 : 0 : tree _q100 = _q71_pops[0];
1673 : 0 : switch (TREE_CODE (_q31))
1674 : : {
1675 : 0 : case SSA_NAME:
1676 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
1677 : : {
1678 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
1679 : 0 : switch (gimple_assign_rhs_code (_a6))
1680 : : {
1681 : 0 : case BIT_NOT_EXPR:
1682 : 0 : {
1683 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
1684 : 0 : _q120 = do_valueize (valueize, _q120);
1685 : 0 : switch (TREE_CODE (_q120))
1686 : : {
1687 : 0 : case SSA_NAME:
1688 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
1689 : : {
1690 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
1691 : 0 : switch (gimple_assign_rhs_code (_a7))
1692 : : {
1693 : 0 : case BIT_XOR_EXPR:
1694 : 0 : {
1695 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
1696 : 0 : _q130 = do_valueize (valueize, _q130);
1697 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
1698 : 0 : _q131 = do_valueize (valueize, _q131);
1699 : 0 : if (tree_swap_operands_p (_q130, _q131))
1700 : 0 : std::swap (_q130, _q131);
1701 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
1702 : : {
1703 : 0 : if ((_q131 == _q100 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q100, 0) && types_match (_q131, _q100)))
1704 : : {
1705 : 0 : if (integer_zerop (_q21))
1706 : : {
1707 : 0 : if ((_p1 == _q41 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q41, 0) && types_match (_p1, _q41)))
1708 : : {
1709 : 0 : switch (TREE_CODE (_p2))
1710 : : {
1711 : 0 : case SSA_NAME:
1712 : 0 : if (gimple *_d8 = get_def (valueize, _p2))
1713 : : {
1714 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
1715 : 0 : switch (gimple_assign_rhs_code (_a8))
1716 : : {
1717 : 0 : case BIT_XOR_EXPR:
1718 : 0 : {
1719 : 0 : tree _q180 = gimple_assign_rhs1 (_a8);
1720 : 0 : _q180 = do_valueize (valueize, _q180);
1721 : 0 : tree _q181 = gimple_assign_rhs2 (_a8);
1722 : 0 : _q181 = do_valueize (valueize, _q181);
1723 : 0 : if (tree_swap_operands_p (_q180, _q181))
1724 : 0 : std::swap (_q180, _q181);
1725 : 0 : switch (TREE_CODE (_q180))
1726 : : {
1727 : 0 : case SSA_NAME:
1728 : 0 : if (gimple *_d9 = get_def (valueize, _q180))
1729 : : {
1730 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
1731 : 0 : switch (gimple_assign_rhs_code (_a9))
1732 : : {
1733 : 0 : case NEGATE_EXPR:
1734 : 0 : {
1735 : 0 : tree _q190 = gimple_assign_rhs1 (_a9);
1736 : 0 : _q190 = do_valueize (valueize, _q190);
1737 : 0 : switch (TREE_CODE (_q190))
1738 : : {
1739 : 0 : case SSA_NAME:
1740 : 0 : if (gimple *_d10 = get_def (valueize, _q190))
1741 : : {
1742 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
1743 : 0 : switch (gimple_assign_rhs_code (_a10))
1744 : : {
1745 : 0 : CASE_CONVERT:
1746 : 0 : {
1747 : 0 : tree _q200 = gimple_assign_rhs1 (_a10);
1748 : 0 : _q200 = do_valueize (valueize, _q200);
1749 : 0 : switch (TREE_CODE (_q200))
1750 : : {
1751 : 0 : case SSA_NAME:
1752 : 0 : if (gimple *_d11 = get_def (valueize, _q200))
1753 : : {
1754 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
1755 : 0 : switch (gimple_assign_rhs_code (_a11))
1756 : : {
1757 : 0 : case LT_EXPR:
1758 : 0 : {
1759 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
1760 : 0 : _q210 = do_valueize (valueize, _q210);
1761 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
1762 : 0 : _q211 = do_valueize (valueize, _q211);
1763 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
1764 : : {
1765 : 0 : if (integer_zerop (_q211))
1766 : : {
1767 : 0 : if (gimple_max_value (_q181, valueize))
1768 : : {
1769 : 0 : {
1770 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
1771 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1772 : : )
1773 : : {
1774 : 0 : {
1775 : 0 : res_ops[0] = captures[0];
1776 : 0 : res_ops[1] = captures[1];
1777 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
1778 : 0 : return true;
1779 : : }
1780 : : }
1781 : : }
1782 : : }
1783 : : }
1784 : : }
1785 : : break;
1786 : : }
1787 : : default:;
1788 : : }
1789 : : }
1790 : : break;
1791 : : default:;
1792 : : }
1793 : : break;
1794 : : }
1795 : : default:;
1796 : : }
1797 : : }
1798 : : break;
1799 : : default:;
1800 : : }
1801 : : break;
1802 : : }
1803 : : default:;
1804 : : }
1805 : : }
1806 : : break;
1807 : 0 : default:;
1808 : : }
1809 : 0 : if (gimple_max_value (_q180, valueize))
1810 : : {
1811 : 0 : switch (TREE_CODE (_q181))
1812 : : {
1813 : 0 : case SSA_NAME:
1814 : 0 : if (gimple *_d9 = get_def (valueize, _q181))
1815 : : {
1816 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
1817 : 0 : switch (gimple_assign_rhs_code (_a9))
1818 : : {
1819 : 0 : case NEGATE_EXPR:
1820 : 0 : {
1821 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
1822 : 0 : _q200 = do_valueize (valueize, _q200);
1823 : 0 : switch (TREE_CODE (_q200))
1824 : : {
1825 : 0 : case SSA_NAME:
1826 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
1827 : : {
1828 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
1829 : 0 : switch (gimple_assign_rhs_code (_a10))
1830 : : {
1831 : 0 : CASE_CONVERT:
1832 : 0 : {
1833 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
1834 : 0 : _q210 = do_valueize (valueize, _q210);
1835 : 0 : switch (TREE_CODE (_q210))
1836 : : {
1837 : 0 : case SSA_NAME:
1838 : 0 : if (gimple *_d11 = get_def (valueize, _q210))
1839 : : {
1840 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
1841 : 0 : switch (gimple_assign_rhs_code (_a11))
1842 : : {
1843 : 0 : case LT_EXPR:
1844 : 0 : {
1845 : 0 : tree _q220 = gimple_assign_rhs1 (_a11);
1846 : 0 : _q220 = do_valueize (valueize, _q220);
1847 : 0 : tree _q221 = gimple_assign_rhs2 (_a11);
1848 : 0 : _q221 = do_valueize (valueize, _q221);
1849 : 0 : if ((_q220 == _q40 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q40, 0) && types_match (_q220, _q40)))
1850 : : {
1851 : 0 : if (integer_zerop (_q221))
1852 : : {
1853 : 0 : {
1854 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
1855 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1856 : : )
1857 : : {
1858 : 0 : {
1859 : 0 : res_ops[0] = captures[0];
1860 : 0 : res_ops[1] = captures[1];
1861 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
1862 : 0 : return true;
1863 : : }
1864 : : }
1865 : : }
1866 : : }
1867 : : }
1868 : : break;
1869 : : }
1870 : : default:;
1871 : : }
1872 : : }
1873 : : break;
1874 : : default:;
1875 : : }
1876 : : break;
1877 : : }
1878 : : default:;
1879 : : }
1880 : : }
1881 : : break;
1882 : : default:;
1883 : : }
1884 : : break;
1885 : : }
1886 : : default:;
1887 : : }
1888 : : }
1889 : : break;
1890 : : default:;
1891 : : }
1892 : : }
1893 : 0 : break;
1894 : : }
1895 : : default:;
1896 : : }
1897 : : }
1898 : : break;
1899 : : default:;
1900 : : }
1901 : : }
1902 : : }
1903 : : }
1904 : : }
1905 : 0 : if ((_q130 == _q100 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q100, 0) && types_match (_q130, _q100)))
1906 : : {
1907 : 0 : if ((_q131 == _q40 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q40, 0) && types_match (_q131, _q40)))
1908 : : {
1909 : 0 : if (integer_zerop (_q21))
1910 : : {
1911 : 0 : if ((_p1 == _q41 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q41, 0) && types_match (_p1, _q41)))
1912 : : {
1913 : 0 : switch (TREE_CODE (_p2))
1914 : : {
1915 : 0 : case SSA_NAME:
1916 : 0 : if (gimple *_d8 = get_def (valueize, _p2))
1917 : : {
1918 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
1919 : 0 : switch (gimple_assign_rhs_code (_a8))
1920 : : {
1921 : 0 : case BIT_XOR_EXPR:
1922 : 0 : {
1923 : 0 : tree _q180 = gimple_assign_rhs1 (_a8);
1924 : 0 : _q180 = do_valueize (valueize, _q180);
1925 : 0 : tree _q181 = gimple_assign_rhs2 (_a8);
1926 : 0 : _q181 = do_valueize (valueize, _q181);
1927 : 0 : if (tree_swap_operands_p (_q180, _q181))
1928 : 0 : std::swap (_q180, _q181);
1929 : 0 : switch (TREE_CODE (_q180))
1930 : : {
1931 : 0 : case SSA_NAME:
1932 : 0 : if (gimple *_d9 = get_def (valueize, _q180))
1933 : : {
1934 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
1935 : 0 : switch (gimple_assign_rhs_code (_a9))
1936 : : {
1937 : 0 : case NEGATE_EXPR:
1938 : 0 : {
1939 : 0 : tree _q190 = gimple_assign_rhs1 (_a9);
1940 : 0 : _q190 = do_valueize (valueize, _q190);
1941 : 0 : switch (TREE_CODE (_q190))
1942 : : {
1943 : 0 : case SSA_NAME:
1944 : 0 : if (gimple *_d10 = get_def (valueize, _q190))
1945 : : {
1946 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
1947 : 0 : switch (gimple_assign_rhs_code (_a10))
1948 : : {
1949 : 0 : CASE_CONVERT:
1950 : 0 : {
1951 : 0 : tree _q200 = gimple_assign_rhs1 (_a10);
1952 : 0 : _q200 = do_valueize (valueize, _q200);
1953 : 0 : switch (TREE_CODE (_q200))
1954 : : {
1955 : 0 : case SSA_NAME:
1956 : 0 : if (gimple *_d11 = get_def (valueize, _q200))
1957 : : {
1958 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
1959 : 0 : switch (gimple_assign_rhs_code (_a11))
1960 : : {
1961 : 0 : case LT_EXPR:
1962 : 0 : {
1963 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
1964 : 0 : _q210 = do_valueize (valueize, _q210);
1965 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
1966 : 0 : _q211 = do_valueize (valueize, _q211);
1967 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
1968 : : {
1969 : 0 : if (integer_zerop (_q211))
1970 : : {
1971 : 0 : if (gimple_max_value (_q181, valueize))
1972 : : {
1973 : 0 : {
1974 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
1975 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
1976 : : )
1977 : : {
1978 : 0 : {
1979 : 0 : res_ops[0] = captures[0];
1980 : 0 : res_ops[1] = captures[1];
1981 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
1982 : 0 : return true;
1983 : : }
1984 : : }
1985 : : }
1986 : : }
1987 : : }
1988 : : }
1989 : : break;
1990 : : }
1991 : : default:;
1992 : : }
1993 : : }
1994 : : break;
1995 : : default:;
1996 : : }
1997 : : break;
1998 : : }
1999 : : default:;
2000 : : }
2001 : : }
2002 : : break;
2003 : : default:;
2004 : : }
2005 : : break;
2006 : : }
2007 : : default:;
2008 : : }
2009 : : }
2010 : : break;
2011 : 0 : default:;
2012 : : }
2013 : 0 : if (gimple_max_value (_q180, valueize))
2014 : : {
2015 : 0 : switch (TREE_CODE (_q181))
2016 : : {
2017 : 0 : case SSA_NAME:
2018 : 0 : if (gimple *_d9 = get_def (valueize, _q181))
2019 : : {
2020 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
2021 : 0 : switch (gimple_assign_rhs_code (_a9))
2022 : : {
2023 : 0 : case NEGATE_EXPR:
2024 : 0 : {
2025 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
2026 : 0 : _q200 = do_valueize (valueize, _q200);
2027 : 0 : switch (TREE_CODE (_q200))
2028 : : {
2029 : 0 : case SSA_NAME:
2030 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
2031 : : {
2032 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
2033 : 0 : switch (gimple_assign_rhs_code (_a10))
2034 : : {
2035 : 0 : CASE_CONVERT:
2036 : 0 : {
2037 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
2038 : 0 : _q210 = do_valueize (valueize, _q210);
2039 : 0 : switch (TREE_CODE (_q210))
2040 : : {
2041 : 0 : case SSA_NAME:
2042 : 0 : if (gimple *_d11 = get_def (valueize, _q210))
2043 : : {
2044 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
2045 : 0 : switch (gimple_assign_rhs_code (_a11))
2046 : : {
2047 : 0 : case LT_EXPR:
2048 : 0 : {
2049 : 0 : tree _q220 = gimple_assign_rhs1 (_a11);
2050 : 0 : _q220 = do_valueize (valueize, _q220);
2051 : 0 : tree _q221 = gimple_assign_rhs2 (_a11);
2052 : 0 : _q221 = do_valueize (valueize, _q221);
2053 : 0 : if ((_q220 == _q40 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q40, 0) && types_match (_q220, _q40)))
2054 : : {
2055 : 0 : if (integer_zerop (_q221))
2056 : : {
2057 : 0 : {
2058 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
2059 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2060 : : )
2061 : : {
2062 : 0 : {
2063 : 0 : res_ops[0] = captures[0];
2064 : 0 : res_ops[1] = captures[1];
2065 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
2066 : 0 : return true;
2067 : : }
2068 : : }
2069 : : }
2070 : : }
2071 : : }
2072 : : break;
2073 : : }
2074 : : default:;
2075 : : }
2076 : : }
2077 : : break;
2078 : : default:;
2079 : : }
2080 : : break;
2081 : : }
2082 : : default:;
2083 : : }
2084 : : }
2085 : : break;
2086 : : default:;
2087 : : }
2088 : : break;
2089 : : }
2090 : : default:;
2091 : : }
2092 : : }
2093 : : break;
2094 : : default:;
2095 : : }
2096 : : }
2097 : 0 : break;
2098 : : }
2099 : : default:;
2100 : : }
2101 : : }
2102 : : break;
2103 : : default:;
2104 : : }
2105 : : }
2106 : : }
2107 : : }
2108 : : }
2109 : 0 : break;
2110 : : }
2111 : : default:;
2112 : : }
2113 : : }
2114 : : break;
2115 : : default:;
2116 : : }
2117 : : break;
2118 : : }
2119 : : default:;
2120 : : }
2121 : : }
2122 : : break;
2123 : : default:;
2124 : : }
2125 : : }
2126 : : }
2127 : : }
2128 : : }
2129 : : }
2130 : 0 : break;
2131 : : }
2132 : : default:;
2133 : : }
2134 : : }
2135 : : break;
2136 : : default:;
2137 : : }
2138 : : }
2139 : : }
2140 : 0 : break;
2141 : : }
2142 : 0 : case BIT_NOT_EXPR:
2143 : 0 : {
2144 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
2145 : 0 : _q40 = do_valueize (valueize, _q40);
2146 : 0 : switch (TREE_CODE (_q40))
2147 : : {
2148 : 0 : case SSA_NAME:
2149 : 0 : if (gimple *_d5 = get_def (valueize, _q40))
2150 : : {
2151 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
2152 : 0 : switch (gimple_assign_rhs_code (_a5))
2153 : : {
2154 : 0 : case BIT_XOR_EXPR:
2155 : 0 : {
2156 : 0 : tree _q50 = gimple_assign_rhs1 (_a5);
2157 : 0 : _q50 = do_valueize (valueize, _q50);
2158 : 0 : tree _q51 = gimple_assign_rhs2 (_a5);
2159 : 0 : _q51 = do_valueize (valueize, _q51);
2160 : 0 : if (tree_swap_operands_p (_q50, _q51))
2161 : 0 : std::swap (_q50, _q51);
2162 : 0 : switch (TREE_CODE (_q31))
2163 : : {
2164 : 0 : case SSA_NAME:
2165 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
2166 : : {
2167 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
2168 : 0 : switch (gimple_assign_rhs_code (_a6))
2169 : : {
2170 : 0 : case BIT_XOR_EXPR:
2171 : 0 : {
2172 : 0 : tree _q80 = gimple_assign_rhs1 (_a6);
2173 : 0 : _q80 = do_valueize (valueize, _q80);
2174 : 0 : tree _q81 = gimple_assign_rhs2 (_a6);
2175 : 0 : _q81 = do_valueize (valueize, _q81);
2176 : 0 : if (tree_swap_operands_p (_q80, _q81))
2177 : 0 : std::swap (_q80, _q81);
2178 : 0 : if ((_q80 == _q50 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q50, 0) && types_match (_q80, _q50)))
2179 : : {
2180 : 0 : {
2181 : 0 : tree _q81_pops[1];
2182 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
2183 : : {
2184 : 0 : tree _q100 = _q81_pops[0];
2185 : 0 : switch (TREE_CODE (_q100))
2186 : : {
2187 : 0 : case SSA_NAME:
2188 : 0 : if (gimple *_d7 = get_def (valueize, _q100))
2189 : : {
2190 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
2191 : 0 : switch (gimple_assign_rhs_code (_a7))
2192 : : {
2193 : 0 : case PLUS_EXPR:
2194 : 0 : {
2195 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
2196 : 0 : _q110 = do_valueize (valueize, _q110);
2197 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
2198 : 0 : _q111 = do_valueize (valueize, _q111);
2199 : 0 : if (tree_swap_operands_p (_q110, _q111))
2200 : 0 : std::swap (_q110, _q111);
2201 : 0 : {
2202 : 0 : tree _q110_pops[1];
2203 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
2204 : : {
2205 : 0 : tree _q120 = _q110_pops[0];
2206 : 0 : if ((_q120 == _q50 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q50, 0) && types_match (_q120, _q50)))
2207 : : {
2208 : 0 : {
2209 : 0 : tree _q111_pops[1];
2210 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
2211 : : {
2212 : 0 : tree _q140 = _q111_pops[0];
2213 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
2214 : : {
2215 : 0 : if (integer_zerop (_q21))
2216 : : {
2217 : 0 : if ((_p1 == _q81 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q81, 0) && types_match (_p1, _q81)))
2218 : : {
2219 : 0 : switch (TREE_CODE (_p2))
2220 : : {
2221 : 0 : case SSA_NAME:
2222 : 0 : if (gimple *_d8 = get_def (valueize, _p2))
2223 : : {
2224 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
2225 : 0 : switch (gimple_assign_rhs_code (_a8))
2226 : : {
2227 : 0 : case BIT_XOR_EXPR:
2228 : 0 : {
2229 : 0 : tree _q180 = gimple_assign_rhs1 (_a8);
2230 : 0 : _q180 = do_valueize (valueize, _q180);
2231 : 0 : tree _q181 = gimple_assign_rhs2 (_a8);
2232 : 0 : _q181 = do_valueize (valueize, _q181);
2233 : 0 : if (tree_swap_operands_p (_q180, _q181))
2234 : 0 : std::swap (_q180, _q181);
2235 : 0 : switch (TREE_CODE (_q180))
2236 : : {
2237 : 0 : case SSA_NAME:
2238 : 0 : if (gimple *_d9 = get_def (valueize, _q180))
2239 : : {
2240 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
2241 : 0 : switch (gimple_assign_rhs_code (_a9))
2242 : : {
2243 : 0 : case NEGATE_EXPR:
2244 : 0 : {
2245 : 0 : tree _q190 = gimple_assign_rhs1 (_a9);
2246 : 0 : _q190 = do_valueize (valueize, _q190);
2247 : 0 : switch (TREE_CODE (_q190))
2248 : : {
2249 : 0 : case SSA_NAME:
2250 : 0 : if (gimple *_d10 = get_def (valueize, _q190))
2251 : : {
2252 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
2253 : 0 : switch (gimple_assign_rhs_code (_a10))
2254 : : {
2255 : 0 : CASE_CONVERT:
2256 : 0 : {
2257 : 0 : tree _q200 = gimple_assign_rhs1 (_a10);
2258 : 0 : _q200 = do_valueize (valueize, _q200);
2259 : 0 : switch (TREE_CODE (_q200))
2260 : : {
2261 : 0 : case SSA_NAME:
2262 : 0 : if (gimple *_d11 = get_def (valueize, _q200))
2263 : : {
2264 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
2265 : 0 : switch (gimple_assign_rhs_code (_a11))
2266 : : {
2267 : 0 : case LT_EXPR:
2268 : 0 : {
2269 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
2270 : 0 : _q210 = do_valueize (valueize, _q210);
2271 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
2272 : 0 : _q211 = do_valueize (valueize, _q211);
2273 : 0 : if ((_q210 == _q50 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q50, 0) && types_match (_q210, _q50)))
2274 : : {
2275 : 0 : if (integer_zerop (_q211))
2276 : : {
2277 : 0 : if (gimple_max_value (_q181, valueize))
2278 : : {
2279 : 0 : {
2280 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
2281 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2282 : : )
2283 : : {
2284 : 0 : {
2285 : 0 : res_ops[0] = captures[0];
2286 : 0 : res_ops[1] = captures[1];
2287 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
2288 : 0 : return true;
2289 : : }
2290 : : }
2291 : : }
2292 : : }
2293 : : }
2294 : : }
2295 : : break;
2296 : : }
2297 : : default:;
2298 : : }
2299 : : }
2300 : : break;
2301 : : default:;
2302 : : }
2303 : : break;
2304 : : }
2305 : : default:;
2306 : : }
2307 : : }
2308 : : break;
2309 : : default:;
2310 : : }
2311 : : break;
2312 : : }
2313 : : default:;
2314 : : }
2315 : : }
2316 : : break;
2317 : 0 : default:;
2318 : : }
2319 : 0 : if (gimple_max_value (_q180, valueize))
2320 : : {
2321 : 0 : switch (TREE_CODE (_q181))
2322 : : {
2323 : 0 : case SSA_NAME:
2324 : 0 : if (gimple *_d9 = get_def (valueize, _q181))
2325 : : {
2326 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
2327 : 0 : switch (gimple_assign_rhs_code (_a9))
2328 : : {
2329 : 0 : case NEGATE_EXPR:
2330 : 0 : {
2331 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
2332 : 0 : _q200 = do_valueize (valueize, _q200);
2333 : 0 : switch (TREE_CODE (_q200))
2334 : : {
2335 : 0 : case SSA_NAME:
2336 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
2337 : : {
2338 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
2339 : 0 : switch (gimple_assign_rhs_code (_a10))
2340 : : {
2341 : 0 : CASE_CONVERT:
2342 : 0 : {
2343 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
2344 : 0 : _q210 = do_valueize (valueize, _q210);
2345 : 0 : switch (TREE_CODE (_q210))
2346 : : {
2347 : 0 : case SSA_NAME:
2348 : 0 : if (gimple *_d11 = get_def (valueize, _q210))
2349 : : {
2350 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
2351 : 0 : switch (gimple_assign_rhs_code (_a11))
2352 : : {
2353 : 0 : case LT_EXPR:
2354 : 0 : {
2355 : 0 : tree _q220 = gimple_assign_rhs1 (_a11);
2356 : 0 : _q220 = do_valueize (valueize, _q220);
2357 : 0 : tree _q221 = gimple_assign_rhs2 (_a11);
2358 : 0 : _q221 = do_valueize (valueize, _q221);
2359 : 0 : if ((_q220 == _q50 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q50, 0) && types_match (_q220, _q50)))
2360 : : {
2361 : 0 : if (integer_zerop (_q221))
2362 : : {
2363 : 0 : {
2364 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
2365 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2366 : : )
2367 : : {
2368 : 0 : {
2369 : 0 : res_ops[0] = captures[0];
2370 : 0 : res_ops[1] = captures[1];
2371 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
2372 : 0 : return true;
2373 : : }
2374 : : }
2375 : : }
2376 : : }
2377 : : }
2378 : : break;
2379 : : }
2380 : : default:;
2381 : : }
2382 : : }
2383 : : break;
2384 : : default:;
2385 : : }
2386 : : break;
2387 : : }
2388 : : default:;
2389 : : }
2390 : : }
2391 : : break;
2392 : : default:;
2393 : : }
2394 : : break;
2395 : : }
2396 : : default:;
2397 : : }
2398 : : }
2399 : : break;
2400 : : default:;
2401 : : }
2402 : : }
2403 : 0 : break;
2404 : : }
2405 : : default:;
2406 : : }
2407 : : }
2408 : : break;
2409 : : default:;
2410 : : }
2411 : : }
2412 : : }
2413 : : }
2414 : : }
2415 : : }
2416 : : }
2417 : : }
2418 : : }
2419 : 0 : break;
2420 : : }
2421 : : default:;
2422 : : }
2423 : : }
2424 : : break;
2425 : : default:;
2426 : : }
2427 : : }
2428 : : }
2429 : : }
2430 : 0 : if ((_q80 == _q51 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q51, 0) && types_match (_q80, _q51)))
2431 : : {
2432 : 0 : {
2433 : 0 : tree _q81_pops[1];
2434 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
2435 : : {
2436 : 0 : tree _q100 = _q81_pops[0];
2437 : 0 : switch (TREE_CODE (_q100))
2438 : : {
2439 : 0 : case SSA_NAME:
2440 : 0 : if (gimple *_d7 = get_def (valueize, _q100))
2441 : : {
2442 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
2443 : 0 : switch (gimple_assign_rhs_code (_a7))
2444 : : {
2445 : 0 : case PLUS_EXPR:
2446 : 0 : {
2447 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
2448 : 0 : _q110 = do_valueize (valueize, _q110);
2449 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
2450 : 0 : _q111 = do_valueize (valueize, _q111);
2451 : 0 : if (tree_swap_operands_p (_q110, _q111))
2452 : 0 : std::swap (_q110, _q111);
2453 : 0 : {
2454 : 0 : tree _q110_pops[1];
2455 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
2456 : : {
2457 : 0 : tree _q120 = _q110_pops[0];
2458 : 0 : if ((_q120 == _q51 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q51, 0) && types_match (_q120, _q51)))
2459 : : {
2460 : 0 : {
2461 : 0 : tree _q111_pops[1];
2462 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
2463 : : {
2464 : 0 : tree _q140 = _q111_pops[0];
2465 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
2466 : : {
2467 : 0 : if (integer_zerop (_q21))
2468 : : {
2469 : 0 : if ((_p1 == _q81 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q81, 0) && types_match (_p1, _q81)))
2470 : : {
2471 : 0 : switch (TREE_CODE (_p2))
2472 : : {
2473 : 0 : case SSA_NAME:
2474 : 0 : if (gimple *_d8 = get_def (valueize, _p2))
2475 : : {
2476 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
2477 : 0 : switch (gimple_assign_rhs_code (_a8))
2478 : : {
2479 : 0 : case BIT_XOR_EXPR:
2480 : 0 : {
2481 : 0 : tree _q180 = gimple_assign_rhs1 (_a8);
2482 : 0 : _q180 = do_valueize (valueize, _q180);
2483 : 0 : tree _q181 = gimple_assign_rhs2 (_a8);
2484 : 0 : _q181 = do_valueize (valueize, _q181);
2485 : 0 : if (tree_swap_operands_p (_q180, _q181))
2486 : 0 : std::swap (_q180, _q181);
2487 : 0 : switch (TREE_CODE (_q180))
2488 : : {
2489 : 0 : case SSA_NAME:
2490 : 0 : if (gimple *_d9 = get_def (valueize, _q180))
2491 : : {
2492 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
2493 : 0 : switch (gimple_assign_rhs_code (_a9))
2494 : : {
2495 : 0 : case NEGATE_EXPR:
2496 : 0 : {
2497 : 0 : tree _q190 = gimple_assign_rhs1 (_a9);
2498 : 0 : _q190 = do_valueize (valueize, _q190);
2499 : 0 : switch (TREE_CODE (_q190))
2500 : : {
2501 : 0 : case SSA_NAME:
2502 : 0 : if (gimple *_d10 = get_def (valueize, _q190))
2503 : : {
2504 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
2505 : 0 : switch (gimple_assign_rhs_code (_a10))
2506 : : {
2507 : 0 : CASE_CONVERT:
2508 : 0 : {
2509 : 0 : tree _q200 = gimple_assign_rhs1 (_a10);
2510 : 0 : _q200 = do_valueize (valueize, _q200);
2511 : 0 : switch (TREE_CODE (_q200))
2512 : : {
2513 : 0 : case SSA_NAME:
2514 : 0 : if (gimple *_d11 = get_def (valueize, _q200))
2515 : : {
2516 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
2517 : 0 : switch (gimple_assign_rhs_code (_a11))
2518 : : {
2519 : 0 : case LT_EXPR:
2520 : 0 : {
2521 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
2522 : 0 : _q210 = do_valueize (valueize, _q210);
2523 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
2524 : 0 : _q211 = do_valueize (valueize, _q211);
2525 : 0 : if ((_q210 == _q51 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q51, 0) && types_match (_q210, _q51)))
2526 : : {
2527 : 0 : if (integer_zerop (_q211))
2528 : : {
2529 : 0 : if (gimple_max_value (_q181, valueize))
2530 : : {
2531 : 0 : {
2532 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
2533 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2534 : : )
2535 : : {
2536 : 0 : {
2537 : 0 : res_ops[0] = captures[0];
2538 : 0 : res_ops[1] = captures[1];
2539 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
2540 : 0 : return true;
2541 : : }
2542 : : }
2543 : : }
2544 : : }
2545 : : }
2546 : : }
2547 : : break;
2548 : : }
2549 : : default:;
2550 : : }
2551 : : }
2552 : : break;
2553 : : default:;
2554 : : }
2555 : : break;
2556 : : }
2557 : : default:;
2558 : : }
2559 : : }
2560 : : break;
2561 : : default:;
2562 : : }
2563 : : break;
2564 : : }
2565 : : default:;
2566 : : }
2567 : : }
2568 : : break;
2569 : 0 : default:;
2570 : : }
2571 : 0 : if (gimple_max_value (_q180, valueize))
2572 : : {
2573 : 0 : switch (TREE_CODE (_q181))
2574 : : {
2575 : 0 : case SSA_NAME:
2576 : 0 : if (gimple *_d9 = get_def (valueize, _q181))
2577 : : {
2578 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
2579 : 0 : switch (gimple_assign_rhs_code (_a9))
2580 : : {
2581 : 0 : case NEGATE_EXPR:
2582 : 0 : {
2583 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
2584 : 0 : _q200 = do_valueize (valueize, _q200);
2585 : 0 : switch (TREE_CODE (_q200))
2586 : : {
2587 : 0 : case SSA_NAME:
2588 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
2589 : : {
2590 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
2591 : 0 : switch (gimple_assign_rhs_code (_a10))
2592 : : {
2593 : 0 : CASE_CONVERT:
2594 : 0 : {
2595 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
2596 : 0 : _q210 = do_valueize (valueize, _q210);
2597 : 0 : switch (TREE_CODE (_q210))
2598 : : {
2599 : 0 : case SSA_NAME:
2600 : 0 : if (gimple *_d11 = get_def (valueize, _q210))
2601 : : {
2602 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
2603 : 0 : switch (gimple_assign_rhs_code (_a11))
2604 : : {
2605 : 0 : case LT_EXPR:
2606 : 0 : {
2607 : 0 : tree _q220 = gimple_assign_rhs1 (_a11);
2608 : 0 : _q220 = do_valueize (valueize, _q220);
2609 : 0 : tree _q221 = gimple_assign_rhs2 (_a11);
2610 : 0 : _q221 = do_valueize (valueize, _q221);
2611 : 0 : if ((_q220 == _q51 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q51, 0) && types_match (_q220, _q51)))
2612 : : {
2613 : 0 : if (integer_zerop (_q221))
2614 : : {
2615 : 0 : {
2616 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
2617 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2618 : : )
2619 : : {
2620 : 0 : {
2621 : 0 : res_ops[0] = captures[0];
2622 : 0 : res_ops[1] = captures[1];
2623 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
2624 : 0 : return true;
2625 : : }
2626 : : }
2627 : : }
2628 : : }
2629 : : }
2630 : : break;
2631 : : }
2632 : : default:;
2633 : : }
2634 : : }
2635 : : break;
2636 : : default:;
2637 : : }
2638 : : break;
2639 : : }
2640 : : default:;
2641 : : }
2642 : : }
2643 : : break;
2644 : : default:;
2645 : : }
2646 : : break;
2647 : : }
2648 : : default:;
2649 : : }
2650 : : }
2651 : : break;
2652 : : default:;
2653 : : }
2654 : : }
2655 : 0 : break;
2656 : : }
2657 : : default:;
2658 : : }
2659 : : }
2660 : : break;
2661 : : default:;
2662 : : }
2663 : : }
2664 : : }
2665 : : }
2666 : : }
2667 : : }
2668 : : }
2669 : : }
2670 : : }
2671 : 0 : break;
2672 : : }
2673 : : default:;
2674 : : }
2675 : : }
2676 : : break;
2677 : : default:;
2678 : : }
2679 : : }
2680 : : }
2681 : : }
2682 : 22317700 : break;
2683 : : }
2684 : : default:;
2685 : : }
2686 : : }
2687 : : break;
2688 : : default:;
2689 : : }
2690 : 22317700 : break;
2691 : : }
2692 : : default:;
2693 : : }
2694 : : }
2695 : : break;
2696 : : default:;
2697 : : }
2698 : : break;
2699 : : }
2700 : : default:;
2701 : : }
2702 : : }
2703 : : break;
2704 : : default:;
2705 : : }
2706 : 22317700 : break;
2707 : : }
2708 : : default:;
2709 : : }
2710 : : }
2711 : : break;
2712 : : default:;
2713 : : }
2714 : : break;
2715 : : }
2716 : 14124 : case BIT_AND_EXPR:
2717 : 14124 : {
2718 : 14124 : tree _q20 = gimple_assign_rhs1 (_a2);
2719 : 14124 : _q20 = do_valueize (valueize, _q20);
2720 : 14124 : tree _q21 = gimple_assign_rhs2 (_a2);
2721 : 14124 : _q21 = do_valueize (valueize, _q21);
2722 : 14124 : if (tree_swap_operands_p (_q20, _q21))
2723 : 23 : std::swap (_q20, _q21);
2724 : 14124 : switch (TREE_CODE (_q20))
2725 : : {
2726 : 14124 : case SSA_NAME:
2727 : 14124 : if (gimple *_d3 = get_def (valueize, _q20))
2728 : : {
2729 : 14124 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
2730 : 14100 : switch (gimple_assign_rhs_code (_a3))
2731 : : {
2732 : 119 : case LT_EXPR:
2733 : 119 : {
2734 : 119 : tree _q30 = gimple_assign_rhs1 (_a3);
2735 : 119 : _q30 = do_valueize (valueize, _q30);
2736 : 119 : tree _q31 = gimple_assign_rhs2 (_a3);
2737 : 119 : _q31 = do_valueize (valueize, _q31);
2738 : 119 : switch (TREE_CODE (_q30))
2739 : : {
2740 : 119 : case SSA_NAME:
2741 : 119 : if (gimple *_d4 = get_def (valueize, _q30))
2742 : : {
2743 : 119 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
2744 : 123 : switch (gimple_assign_rhs_code (_a4))
2745 : : {
2746 : 12 : case BIT_XOR_EXPR:
2747 : 12 : {
2748 : 12 : tree _q40 = gimple_assign_rhs1 (_a4);
2749 : 12 : _q40 = do_valueize (valueize, _q40);
2750 : 12 : tree _q41 = gimple_assign_rhs2 (_a4);
2751 : 12 : _q41 = do_valueize (valueize, _q41);
2752 : 12 : if (tree_swap_operands_p (_q40, _q41))
2753 : 0 : std::swap (_q40, _q41);
2754 : 12 : {
2755 : 12 : tree _q41_pops[1];
2756 : 12 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
2757 : : {
2758 : 12 : tree _q60 = _q41_pops[0];
2759 : 12 : switch (TREE_CODE (_q60))
2760 : : {
2761 : 12 : case SSA_NAME:
2762 : 12 : if (gimple *_d5 = get_def (valueize, _q60))
2763 : : {
2764 : 12 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
2765 : 12 : switch (gimple_assign_rhs_code (_a5))
2766 : : {
2767 : 6 : case PLUS_EXPR:
2768 : 6 : {
2769 : 6 : tree _q70 = gimple_assign_rhs1 (_a5);
2770 : 6 : _q70 = do_valueize (valueize, _q70);
2771 : 6 : tree _q71 = gimple_assign_rhs2 (_a5);
2772 : 6 : _q71 = do_valueize (valueize, _q71);
2773 : 6 : if (tree_swap_operands_p (_q70, _q71))
2774 : 0 : std::swap (_q70, _q71);
2775 : 6 : {
2776 : 6 : tree _q70_pops[1];
2777 : 6 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
2778 : : {
2779 : 6 : tree _q80 = _q70_pops[0];
2780 : 6 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
2781 : : {
2782 : 6 : {
2783 : 6 : tree _q71_pops[1];
2784 : 6 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
2785 : : {
2786 : 6 : tree _q100 = _q71_pops[0];
2787 : 6 : if (integer_zerop (_q31))
2788 : : {
2789 : 6 : switch (TREE_CODE (_q21))
2790 : : {
2791 : 6 : case SSA_NAME:
2792 : 6 : if (gimple *_d6 = get_def (valueize, _q21))
2793 : : {
2794 : 6 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
2795 : 6 : switch (gimple_assign_rhs_code (_a6))
2796 : : {
2797 : 6 : case GE_EXPR:
2798 : 6 : {
2799 : 6 : tree _q130 = gimple_assign_rhs1 (_a6);
2800 : 6 : _q130 = do_valueize (valueize, _q130);
2801 : 6 : tree _q131 = gimple_assign_rhs2 (_a6);
2802 : 6 : _q131 = do_valueize (valueize, _q131);
2803 : 6 : switch (TREE_CODE (_q130))
2804 : : {
2805 : 6 : case SSA_NAME:
2806 : 6 : if (gimple *_d7 = get_def (valueize, _q130))
2807 : : {
2808 : 6 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
2809 : 6 : switch (gimple_assign_rhs_code (_a7))
2810 : : {
2811 : 6 : case BIT_XOR_EXPR:
2812 : 6 : {
2813 : 6 : tree _q140 = gimple_assign_rhs1 (_a7);
2814 : 6 : _q140 = do_valueize (valueize, _q140);
2815 : 6 : tree _q141 = gimple_assign_rhs2 (_a7);
2816 : 6 : _q141 = do_valueize (valueize, _q141);
2817 : 6 : if (tree_swap_operands_p (_q140, _q141))
2818 : 0 : std::swap (_q140, _q141);
2819 : 6 : if ((_q140 == _q40 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q40, 0) && types_match (_q140, _q40)))
2820 : : {
2821 : 6 : if ((_q141 == _q100 && ! TREE_SIDE_EFFECTS (_q141)) || (operand_equal_p (_q141, _q100, 0) && types_match (_q141, _q100)))
2822 : : {
2823 : 6 : if (integer_zerop (_q131))
2824 : : {
2825 : 6 : {
2826 : 6 : tree _p1_pops[1];
2827 : 6 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
2828 : : {
2829 : 6 : tree _q180 = _p1_pops[0];
2830 : 6 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
2831 : : {
2832 : 6 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
2833 : : {
2834 : 6 : {
2835 : 6 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
2836 : 6 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2837 : : )
2838 : : {
2839 : 6 : {
2840 : 6 : res_ops[0] = captures[0];
2841 : 6 : res_ops[1] = captures[1];
2842 : 6 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
2843 : 6 : return true;
2844 : : }
2845 : : }
2846 : : }
2847 : : }
2848 : : }
2849 : : }
2850 : : }
2851 : : }
2852 : : }
2853 : : }
2854 : 0 : if ((_q140 == _q100 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q100, 0) && types_match (_q140, _q100)))
2855 : : {
2856 : 0 : if ((_q141 == _q40 && ! TREE_SIDE_EFFECTS (_q141)) || (operand_equal_p (_q141, _q40, 0) && types_match (_q141, _q40)))
2857 : : {
2858 : 0 : if (integer_zerop (_q131))
2859 : : {
2860 : 0 : {
2861 : 0 : tree _p1_pops[1];
2862 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
2863 : : {
2864 : 0 : tree _q180 = _p1_pops[0];
2865 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
2866 : : {
2867 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
2868 : : {
2869 : 0 : {
2870 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
2871 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2872 : : )
2873 : : {
2874 : 0 : {
2875 : 0 : res_ops[0] = captures[0];
2876 : 0 : res_ops[1] = captures[1];
2877 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
2878 : 0 : return true;
2879 : : }
2880 : : }
2881 : : }
2882 : : }
2883 : : }
2884 : : }
2885 : : }
2886 : : }
2887 : : }
2888 : : }
2889 : 0 : break;
2890 : : }
2891 : : default:;
2892 : : }
2893 : : }
2894 : : break;
2895 : : default:;
2896 : : }
2897 : : break;
2898 : : }
2899 : 0 : case BIT_NOT_EXPR:
2900 : 0 : {
2901 : 0 : tree _q130 = gimple_assign_rhs1 (_a6);
2902 : 0 : _q130 = do_valueize (valueize, _q130);
2903 : 0 : switch (TREE_CODE (_q130))
2904 : : {
2905 : 0 : case SSA_NAME:
2906 : 0 : if (gimple *_d7 = get_def (valueize, _q130))
2907 : : {
2908 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
2909 : 0 : switch (gimple_assign_rhs_code (_a7))
2910 : : {
2911 : 0 : case LT_EXPR:
2912 : 0 : {
2913 : 0 : tree _q140 = gimple_assign_rhs1 (_a7);
2914 : 0 : _q140 = do_valueize (valueize, _q140);
2915 : 0 : tree _q141 = gimple_assign_rhs2 (_a7);
2916 : 0 : _q141 = do_valueize (valueize, _q141);
2917 : 0 : switch (TREE_CODE (_q140))
2918 : : {
2919 : 0 : case SSA_NAME:
2920 : 0 : if (gimple *_d8 = get_def (valueize, _q140))
2921 : : {
2922 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
2923 : 0 : switch (gimple_assign_rhs_code (_a8))
2924 : : {
2925 : 0 : case BIT_XOR_EXPR:
2926 : 0 : {
2927 : 0 : tree _q150 = gimple_assign_rhs1 (_a8);
2928 : 0 : _q150 = do_valueize (valueize, _q150);
2929 : 0 : tree _q151 = gimple_assign_rhs2 (_a8);
2930 : 0 : _q151 = do_valueize (valueize, _q151);
2931 : 0 : if (tree_swap_operands_p (_q150, _q151))
2932 : 0 : std::swap (_q150, _q151);
2933 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
2934 : : {
2935 : 0 : if ((_q151 == _q100 && ! TREE_SIDE_EFFECTS (_q151)) || (operand_equal_p (_q151, _q100, 0) && types_match (_q151, _q100)))
2936 : : {
2937 : 0 : if (integer_zerop (_q141))
2938 : : {
2939 : 0 : {
2940 : 0 : tree _p1_pops[1];
2941 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
2942 : : {
2943 : 0 : tree _q190 = _p1_pops[0];
2944 : 0 : if ((_q190 == _q40 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q40, 0) && types_match (_q190, _q40)))
2945 : : {
2946 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
2947 : : {
2948 : 0 : {
2949 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
2950 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2951 : : )
2952 : : {
2953 : 0 : {
2954 : 0 : res_ops[0] = captures[0];
2955 : 0 : res_ops[1] = captures[1];
2956 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
2957 : 0 : return true;
2958 : : }
2959 : : }
2960 : : }
2961 : : }
2962 : : }
2963 : : }
2964 : : }
2965 : : }
2966 : : }
2967 : : }
2968 : 0 : if ((_q150 == _q100 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q100, 0) && types_match (_q150, _q100)))
2969 : : {
2970 : 0 : if ((_q151 == _q40 && ! TREE_SIDE_EFFECTS (_q151)) || (operand_equal_p (_q151, _q40, 0) && types_match (_q151, _q40)))
2971 : : {
2972 : 0 : if (integer_zerop (_q141))
2973 : : {
2974 : 0 : {
2975 : 0 : tree _p1_pops[1];
2976 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
2977 : : {
2978 : 0 : tree _q190 = _p1_pops[0];
2979 : 0 : if ((_q190 == _q40 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q40, 0) && types_match (_q190, _q40)))
2980 : : {
2981 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
2982 : : {
2983 : 0 : {
2984 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
2985 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
2986 : : )
2987 : : {
2988 : 0 : {
2989 : 0 : res_ops[0] = captures[0];
2990 : 0 : res_ops[1] = captures[1];
2991 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
2992 : 0 : return true;
2993 : : }
2994 : : }
2995 : : }
2996 : : }
2997 : : }
2998 : : }
2999 : : }
3000 : : }
3001 : : }
3002 : : }
3003 : 0 : break;
3004 : : }
3005 : : default:;
3006 : : }
3007 : : }
3008 : : break;
3009 : : default:;
3010 : : }
3011 : : break;
3012 : : }
3013 : : default:;
3014 : : }
3015 : : }
3016 : : break;
3017 : : default:;
3018 : : }
3019 : : break;
3020 : : }
3021 : : default:;
3022 : : }
3023 : : }
3024 : : break;
3025 : : default:;
3026 : : }
3027 : : }
3028 : : }
3029 : : }
3030 : : }
3031 : : }
3032 : : }
3033 : 0 : break;
3034 : : }
3035 : : default:;
3036 : : }
3037 : : }
3038 : : break;
3039 : : default:;
3040 : : }
3041 : : }
3042 : : }
3043 : 6 : break;
3044 : : }
3045 : : default:;
3046 : : }
3047 : : }
3048 : : break;
3049 : : default:;
3050 : : }
3051 : : break;
3052 : : }
3053 : 886 : case GE_EXPR:
3054 : 886 : {
3055 : 886 : tree _q30 = gimple_assign_rhs1 (_a3);
3056 : 886 : _q30 = do_valueize (valueize, _q30);
3057 : 886 : tree _q31 = gimple_assign_rhs2 (_a3);
3058 : 886 : _q31 = do_valueize (valueize, _q31);
3059 : 886 : switch (TREE_CODE (_q30))
3060 : : {
3061 : 886 : case SSA_NAME:
3062 : 886 : if (gimple *_d4 = get_def (valueize, _q30))
3063 : : {
3064 : 886 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
3065 : 1402 : switch (gimple_assign_rhs_code (_a4))
3066 : : {
3067 : 0 : case BIT_XOR_EXPR:
3068 : 0 : {
3069 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
3070 : 0 : _q40 = do_valueize (valueize, _q40);
3071 : 0 : tree _q41 = gimple_assign_rhs2 (_a4);
3072 : 0 : _q41 = do_valueize (valueize, _q41);
3073 : 0 : if (tree_swap_operands_p (_q40, _q41))
3074 : 0 : std::swap (_q40, _q41);
3075 : 0 : if (integer_zerop (_q31))
3076 : : {
3077 : 0 : switch (TREE_CODE (_q21))
3078 : : {
3079 : 0 : case SSA_NAME:
3080 : 0 : if (gimple *_d5 = get_def (valueize, _q21))
3081 : : {
3082 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
3083 : 0 : switch (gimple_assign_rhs_code (_a5))
3084 : : {
3085 : 0 : case LT_EXPR:
3086 : 0 : {
3087 : 0 : tree _q80 = gimple_assign_rhs1 (_a5);
3088 : 0 : _q80 = do_valueize (valueize, _q80);
3089 : 0 : tree _q81 = gimple_assign_rhs2 (_a5);
3090 : 0 : _q81 = do_valueize (valueize, _q81);
3091 : 0 : switch (TREE_CODE (_q80))
3092 : : {
3093 : 0 : case SSA_NAME:
3094 : 0 : if (gimple *_d6 = get_def (valueize, _q80))
3095 : : {
3096 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
3097 : 0 : switch (gimple_assign_rhs_code (_a6))
3098 : : {
3099 : 0 : case BIT_XOR_EXPR:
3100 : 0 : {
3101 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
3102 : 0 : _q90 = do_valueize (valueize, _q90);
3103 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
3104 : 0 : _q91 = do_valueize (valueize, _q91);
3105 : 0 : if (tree_swap_operands_p (_q90, _q91))
3106 : 0 : std::swap (_q90, _q91);
3107 : 0 : if ((_q90 == _q40 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q40, 0) && types_match (_q90, _q40)))
3108 : : {
3109 : 0 : {
3110 : 0 : tree _q91_pops[1];
3111 : 0 : if (gimple_nop_convert (_q91, _q91_pops, valueize))
3112 : : {
3113 : 0 : tree _q110 = _q91_pops[0];
3114 : 0 : switch (TREE_CODE (_q110))
3115 : : {
3116 : 0 : case SSA_NAME:
3117 : 0 : if (gimple *_d7 = get_def (valueize, _q110))
3118 : : {
3119 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
3120 : 0 : switch (gimple_assign_rhs_code (_a7))
3121 : : {
3122 : 0 : case PLUS_EXPR:
3123 : 0 : {
3124 : 0 : tree _q120 = gimple_assign_rhs1 (_a7);
3125 : 0 : _q120 = do_valueize (valueize, _q120);
3126 : 0 : tree _q121 = gimple_assign_rhs2 (_a7);
3127 : 0 : _q121 = do_valueize (valueize, _q121);
3128 : 0 : if (tree_swap_operands_p (_q120, _q121))
3129 : 0 : std::swap (_q120, _q121);
3130 : 0 : {
3131 : 0 : tree _q120_pops[1];
3132 : 0 : if (gimple_nop_convert (_q120, _q120_pops, valueize))
3133 : : {
3134 : 0 : tree _q130 = _q120_pops[0];
3135 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
3136 : : {
3137 : 0 : {
3138 : 0 : tree _q121_pops[1];
3139 : 0 : if (gimple_nop_convert (_q121, _q121_pops, valueize))
3140 : : {
3141 : 0 : tree _q150 = _q121_pops[0];
3142 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
3143 : : {
3144 : 0 : if (integer_zerop (_q81))
3145 : : {
3146 : 0 : {
3147 : 0 : tree _p1_pops[1];
3148 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
3149 : : {
3150 : 0 : tree _q180 = _p1_pops[0];
3151 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
3152 : : {
3153 : 0 : if ((_p2 == _q91 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q91, 0) && types_match (_p2, _q91)))
3154 : : {
3155 : 0 : {
3156 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q41, _q91 };
3157 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
3158 : : )
3159 : : {
3160 : 0 : {
3161 : 0 : res_ops[0] = captures[0];
3162 : 0 : res_ops[1] = captures[1];
3163 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
3164 : 0 : return true;
3165 : : }
3166 : : }
3167 : : }
3168 : : }
3169 : : }
3170 : : }
3171 : : }
3172 : : }
3173 : : }
3174 : : }
3175 : : }
3176 : : }
3177 : : }
3178 : : }
3179 : 0 : break;
3180 : : }
3181 : : default:;
3182 : : }
3183 : : }
3184 : : break;
3185 : : default:;
3186 : : }
3187 : : }
3188 : : }
3189 : : }
3190 : 0 : if ((_q90 == _q41 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q41, 0) && types_match (_q90, _q41)))
3191 : : {
3192 : 0 : {
3193 : 0 : tree _q91_pops[1];
3194 : 0 : if (gimple_nop_convert (_q91, _q91_pops, valueize))
3195 : : {
3196 : 0 : tree _q110 = _q91_pops[0];
3197 : 0 : switch (TREE_CODE (_q110))
3198 : : {
3199 : 0 : case SSA_NAME:
3200 : 0 : if (gimple *_d7 = get_def (valueize, _q110))
3201 : : {
3202 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
3203 : 0 : switch (gimple_assign_rhs_code (_a7))
3204 : : {
3205 : 0 : case PLUS_EXPR:
3206 : 0 : {
3207 : 0 : tree _q120 = gimple_assign_rhs1 (_a7);
3208 : 0 : _q120 = do_valueize (valueize, _q120);
3209 : 0 : tree _q121 = gimple_assign_rhs2 (_a7);
3210 : 0 : _q121 = do_valueize (valueize, _q121);
3211 : 0 : if (tree_swap_operands_p (_q120, _q121))
3212 : 0 : std::swap (_q120, _q121);
3213 : 0 : {
3214 : 0 : tree _q120_pops[1];
3215 : 0 : if (gimple_nop_convert (_q120, _q120_pops, valueize))
3216 : : {
3217 : 0 : tree _q130 = _q120_pops[0];
3218 : 0 : if ((_q130 == _q41 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q41, 0) && types_match (_q130, _q41)))
3219 : : {
3220 : 0 : {
3221 : 0 : tree _q121_pops[1];
3222 : 0 : if (gimple_nop_convert (_q121, _q121_pops, valueize))
3223 : : {
3224 : 0 : tree _q150 = _q121_pops[0];
3225 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
3226 : : {
3227 : 0 : if (integer_zerop (_q81))
3228 : : {
3229 : 0 : {
3230 : 0 : tree _p1_pops[1];
3231 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
3232 : : {
3233 : 0 : tree _q180 = _p1_pops[0];
3234 : 0 : if ((_q180 == _q41 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q41, 0) && types_match (_q180, _q41)))
3235 : : {
3236 : 0 : if ((_p2 == _q91 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q91, 0) && types_match (_p2, _q91)))
3237 : : {
3238 : 0 : {
3239 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q41, _q40, _q91 };
3240 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
3241 : : )
3242 : : {
3243 : 0 : {
3244 : 0 : res_ops[0] = captures[0];
3245 : 0 : res_ops[1] = captures[1];
3246 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
3247 : 0 : return true;
3248 : : }
3249 : : }
3250 : : }
3251 : : }
3252 : : }
3253 : : }
3254 : : }
3255 : : }
3256 : : }
3257 : : }
3258 : : }
3259 : : }
3260 : : }
3261 : : }
3262 : 0 : break;
3263 : : }
3264 : : default:;
3265 : : }
3266 : : }
3267 : : break;
3268 : : default:;
3269 : : }
3270 : : }
3271 : : }
3272 : : }
3273 : 22317700 : break;
3274 : : }
3275 : : default:;
3276 : : }
3277 : : }
3278 : : break;
3279 : : default:;
3280 : : }
3281 : : break;
3282 : : }
3283 : : default:;
3284 : : }
3285 : : }
3286 : : break;
3287 : : default:;
3288 : : }
3289 : : }
3290 : 22317700 : break;
3291 : : }
3292 : : default:;
3293 : : }
3294 : : }
3295 : : break;
3296 : : default:;
3297 : : }
3298 : : break;
3299 : : }
3300 : 237 : case BIT_NOT_EXPR:
3301 : 237 : {
3302 : 237 : tree _q30 = gimple_assign_rhs1 (_a3);
3303 : 237 : _q30 = do_valueize (valueize, _q30);
3304 : 237 : switch (TREE_CODE (_q30))
3305 : : {
3306 : 237 : case SSA_NAME:
3307 : 237 : if (gimple *_d4 = get_def (valueize, _q30))
3308 : : {
3309 : 237 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
3310 : 237 : switch (gimple_assign_rhs_code (_a4))
3311 : : {
3312 : 3 : case LT_EXPR:
3313 : 3 : {
3314 : 3 : tree _q40 = gimple_assign_rhs1 (_a4);
3315 : 3 : _q40 = do_valueize (valueize, _q40);
3316 : 3 : tree _q41 = gimple_assign_rhs2 (_a4);
3317 : 3 : _q41 = do_valueize (valueize, _q41);
3318 : 3 : switch (TREE_CODE (_q40))
3319 : : {
3320 : 3 : case SSA_NAME:
3321 : 3 : if (gimple *_d5 = get_def (valueize, _q40))
3322 : : {
3323 : 3 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
3324 : 6 : switch (gimple_assign_rhs_code (_a5))
3325 : : {
3326 : 0 : case BIT_XOR_EXPR:
3327 : 0 : {
3328 : 0 : tree _q50 = gimple_assign_rhs1 (_a5);
3329 : 0 : _q50 = do_valueize (valueize, _q50);
3330 : 0 : tree _q51 = gimple_assign_rhs2 (_a5);
3331 : 0 : _q51 = do_valueize (valueize, _q51);
3332 : 0 : if (tree_swap_operands_p (_q50, _q51))
3333 : 0 : std::swap (_q50, _q51);
3334 : 0 : if (integer_zerop (_q41))
3335 : : {
3336 : 0 : switch (TREE_CODE (_q21))
3337 : : {
3338 : 0 : case SSA_NAME:
3339 : 0 : if (gimple *_d6 = get_def (valueize, _q21))
3340 : : {
3341 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
3342 : 0 : switch (gimple_assign_rhs_code (_a6))
3343 : : {
3344 : 0 : case LT_EXPR:
3345 : 0 : {
3346 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
3347 : 0 : _q90 = do_valueize (valueize, _q90);
3348 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
3349 : 0 : _q91 = do_valueize (valueize, _q91);
3350 : 0 : switch (TREE_CODE (_q90))
3351 : : {
3352 : 0 : case SSA_NAME:
3353 : 0 : if (gimple *_d7 = get_def (valueize, _q90))
3354 : : {
3355 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
3356 : 0 : switch (gimple_assign_rhs_code (_a7))
3357 : : {
3358 : 0 : case BIT_XOR_EXPR:
3359 : 0 : {
3360 : 0 : tree _q100 = gimple_assign_rhs1 (_a7);
3361 : 0 : _q100 = do_valueize (valueize, _q100);
3362 : 0 : tree _q101 = gimple_assign_rhs2 (_a7);
3363 : 0 : _q101 = do_valueize (valueize, _q101);
3364 : 0 : if (tree_swap_operands_p (_q100, _q101))
3365 : 0 : std::swap (_q100, _q101);
3366 : 0 : if ((_q100 == _q50 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q50, 0) && types_match (_q100, _q50)))
3367 : : {
3368 : 0 : {
3369 : 0 : tree _q101_pops[1];
3370 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
3371 : : {
3372 : 0 : tree _q120 = _q101_pops[0];
3373 : 0 : switch (TREE_CODE (_q120))
3374 : : {
3375 : 0 : case SSA_NAME:
3376 : 0 : if (gimple *_d8 = get_def (valueize, _q120))
3377 : : {
3378 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
3379 : 0 : switch (gimple_assign_rhs_code (_a8))
3380 : : {
3381 : 0 : case PLUS_EXPR:
3382 : 0 : {
3383 : 0 : tree _q130 = gimple_assign_rhs1 (_a8);
3384 : 0 : _q130 = do_valueize (valueize, _q130);
3385 : 0 : tree _q131 = gimple_assign_rhs2 (_a8);
3386 : 0 : _q131 = do_valueize (valueize, _q131);
3387 : 0 : if (tree_swap_operands_p (_q130, _q131))
3388 : 0 : std::swap (_q130, _q131);
3389 : 0 : {
3390 : 0 : tree _q130_pops[1];
3391 : 0 : if (gimple_nop_convert (_q130, _q130_pops, valueize))
3392 : : {
3393 : 0 : tree _q140 = _q130_pops[0];
3394 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
3395 : : {
3396 : 0 : {
3397 : 0 : tree _q131_pops[1];
3398 : 0 : if (gimple_nop_convert (_q131, _q131_pops, valueize))
3399 : : {
3400 : 0 : tree _q160 = _q131_pops[0];
3401 : 0 : if ((_q160 == _q51 && ! TREE_SIDE_EFFECTS (_q160)) || (operand_equal_p (_q160, _q51, 0) && types_match (_q160, _q51)))
3402 : : {
3403 : 0 : if (integer_zerop (_q91))
3404 : : {
3405 : 0 : {
3406 : 0 : tree _p1_pops[1];
3407 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
3408 : : {
3409 : 0 : tree _q190 = _p1_pops[0];
3410 : 0 : if ((_q190 == _q50 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q50, 0) && types_match (_q190, _q50)))
3411 : : {
3412 : 0 : if ((_p2 == _q101 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q101, 0) && types_match (_p2, _q101)))
3413 : : {
3414 : 0 : {
3415 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q101 };
3416 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
3417 : : )
3418 : : {
3419 : 0 : {
3420 : 0 : res_ops[0] = captures[0];
3421 : 0 : res_ops[1] = captures[1];
3422 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
3423 : 0 : return true;
3424 : : }
3425 : : }
3426 : : }
3427 : : }
3428 : : }
3429 : : }
3430 : : }
3431 : : }
3432 : : }
3433 : : }
3434 : : }
3435 : : }
3436 : : }
3437 : : }
3438 : 0 : break;
3439 : : }
3440 : : default:;
3441 : : }
3442 : : }
3443 : : break;
3444 : : default:;
3445 : : }
3446 : : }
3447 : : }
3448 : : }
3449 : 0 : if ((_q100 == _q51 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q51, 0) && types_match (_q100, _q51)))
3450 : : {
3451 : 0 : {
3452 : 0 : tree _q101_pops[1];
3453 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
3454 : : {
3455 : 0 : tree _q120 = _q101_pops[0];
3456 : 0 : switch (TREE_CODE (_q120))
3457 : : {
3458 : 0 : case SSA_NAME:
3459 : 0 : if (gimple *_d8 = get_def (valueize, _q120))
3460 : : {
3461 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
3462 : 0 : switch (gimple_assign_rhs_code (_a8))
3463 : : {
3464 : 0 : case PLUS_EXPR:
3465 : 0 : {
3466 : 0 : tree _q130 = gimple_assign_rhs1 (_a8);
3467 : 0 : _q130 = do_valueize (valueize, _q130);
3468 : 0 : tree _q131 = gimple_assign_rhs2 (_a8);
3469 : 0 : _q131 = do_valueize (valueize, _q131);
3470 : 0 : if (tree_swap_operands_p (_q130, _q131))
3471 : 0 : std::swap (_q130, _q131);
3472 : 0 : {
3473 : 0 : tree _q130_pops[1];
3474 : 0 : if (gimple_nop_convert (_q130, _q130_pops, valueize))
3475 : : {
3476 : 0 : tree _q140 = _q130_pops[0];
3477 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
3478 : : {
3479 : 0 : {
3480 : 0 : tree _q131_pops[1];
3481 : 0 : if (gimple_nop_convert (_q131, _q131_pops, valueize))
3482 : : {
3483 : 0 : tree _q160 = _q131_pops[0];
3484 : 0 : if ((_q160 == _q50 && ! TREE_SIDE_EFFECTS (_q160)) || (operand_equal_p (_q160, _q50, 0) && types_match (_q160, _q50)))
3485 : : {
3486 : 0 : if (integer_zerop (_q91))
3487 : : {
3488 : 0 : {
3489 : 0 : tree _p1_pops[1];
3490 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
3491 : : {
3492 : 0 : tree _q190 = _p1_pops[0];
3493 : 0 : if ((_q190 == _q51 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q51, 0) && types_match (_q190, _q51)))
3494 : : {
3495 : 0 : if ((_p2 == _q101 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q101, 0) && types_match (_p2, _q101)))
3496 : : {
3497 : 0 : {
3498 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q101 };
3499 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
3500 : : )
3501 : : {
3502 : 0 : {
3503 : 0 : res_ops[0] = captures[0];
3504 : 0 : res_ops[1] = captures[1];
3505 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
3506 : 0 : return true;
3507 : : }
3508 : : }
3509 : : }
3510 : : }
3511 : : }
3512 : : }
3513 : : }
3514 : : }
3515 : : }
3516 : : }
3517 : : }
3518 : : }
3519 : : }
3520 : : }
3521 : 0 : break;
3522 : : }
3523 : : default:;
3524 : : }
3525 : : }
3526 : : break;
3527 : : default:;
3528 : : }
3529 : : }
3530 : : }
3531 : : }
3532 : 22317700 : break;
3533 : : }
3534 : : default:;
3535 : : }
3536 : : }
3537 : : break;
3538 : : default:;
3539 : : }
3540 : : break;
3541 : : }
3542 : : default:;
3543 : : }
3544 : : }
3545 : : break;
3546 : : default:;
3547 : : }
3548 : : }
3549 : 22317700 : break;
3550 : : }
3551 : : default:;
3552 : : }
3553 : : }
3554 : : break;
3555 : : default:;
3556 : : }
3557 : : break;
3558 : : }
3559 : : default:;
3560 : : }
3561 : : }
3562 : : break;
3563 : : default:;
3564 : : }
3565 : : break;
3566 : : }
3567 : : default:;
3568 : : }
3569 : : }
3570 : : break;
3571 : : default:;
3572 : : }
3573 : 22317700 : break;
3574 : : }
3575 : 17908 : case NE_EXPR:
3576 : 17908 : {
3577 : 17908 : tree _q20 = gimple_assign_rhs1 (_a2);
3578 : 17908 : _q20 = do_valueize (valueize, _q20);
3579 : 17908 : tree _q21 = gimple_assign_rhs2 (_a2);
3580 : 17908 : _q21 = do_valueize (valueize, _q21);
3581 : 17908 : if (tree_swap_operands_p (_q20, _q21))
3582 : 0 : std::swap (_q20, _q21);
3583 : 17908 : switch (TREE_CODE (_q20))
3584 : : {
3585 : 17908 : case SSA_NAME:
3586 : 17908 : if (gimple *_d3 = get_def (valueize, _q20))
3587 : : {
3588 : 17908 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
3589 : 16283 : switch (gimple_assign_rhs_code (_a3))
3590 : : {
3591 : 6 : case IMAGPART_EXPR:
3592 : 6 : {
3593 : 6 : tree _q30 = TREE_OPERAND (gimple_assign_rhs1 (_a3), 0);
3594 : 6 : if ((TREE_CODE (_q30) == SSA_NAME
3595 : 6 : || is_gimple_min_invariant (_q30)))
3596 : : {
3597 : 6 : _q30 = do_valueize (valueize, _q30);
3598 : 6 : switch (TREE_CODE (_q30))
3599 : : {
3600 : 6 : case SSA_NAME:
3601 : 6 : if (gimple *_d4 = get_def (valueize, _q30))
3602 : : {
3603 : 6 : if (gcall *_c4 = dyn_cast <gcall *> (_d4))
3604 : 6 : switch (gimple_call_combined_fn (_c4))
3605 : : {
3606 : 0 : case CFN_ADD_OVERFLOW:
3607 : 0 : if (gimple_call_num_args (_c4) == 2)
3608 : : {
3609 : 0 : tree _q40 = gimple_call_arg (_c4, 0);
3610 : 0 : _q40 = do_valueize (valueize, _q40);
3611 : 0 : tree _q41 = gimple_call_arg (_c4, 1);
3612 : 0 : _q41 = do_valueize (valueize, _q41);
3613 : 0 : if (tree_swap_operands_p (_q40, _q41))
3614 : 0 : std::swap (_q40, _q41);
3615 : 0 : if (integer_zerop (_q21))
3616 : : {
3617 : 0 : {
3618 : 0 : tree _p1_pops[1];
3619 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
3620 : : {
3621 : 0 : tree _q80 = _p1_pops[0];
3622 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
3623 : : {
3624 : 0 : switch (TREE_CODE (_p2))
3625 : : {
3626 : 0 : case SSA_NAME:
3627 : 0 : if (gimple *_d5 = get_def (valueize, _p2))
3628 : : {
3629 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
3630 : 0 : switch (gimple_assign_rhs_code (_a5))
3631 : : {
3632 : 0 : case REALPART_EXPR:
3633 : 0 : {
3634 : 0 : tree _q100 = TREE_OPERAND (gimple_assign_rhs1 (_a5), 0);
3635 : 0 : if ((TREE_CODE (_q100) == SSA_NAME
3636 : 0 : || is_gimple_min_invariant (_q100)))
3637 : : {
3638 : 0 : _q100 = do_valueize (valueize, _q100);
3639 : 0 : if ((_q100 == _q30 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q30, 0) && types_match (_q100, _q30)))
3640 : : {
3641 : 0 : {
3642 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q41, _q30 };
3643 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
3644 : : )
3645 : : {
3646 : 0 : {
3647 : 0 : res_ops[0] = captures[0];
3648 : 0 : res_ops[1] = captures[1];
3649 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 76, __FILE__, __LINE__, false);
3650 : 0 : return true;
3651 : : }
3652 : : }
3653 : : }
3654 : : }
3655 : : }
3656 : : break;
3657 : : }
3658 : : default:;
3659 : : }
3660 : : }
3661 : : break;
3662 : : default:;
3663 : : }
3664 : : }
3665 : 0 : if ((_q80 == _q41 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q41, 0) && types_match (_q80, _q41)))
3666 : : {
3667 : 0 : switch (TREE_CODE (_p2))
3668 : : {
3669 : 0 : case SSA_NAME:
3670 : 0 : if (gimple *_d5 = get_def (valueize, _p2))
3671 : : {
3672 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
3673 : 0 : switch (gimple_assign_rhs_code (_a5))
3674 : : {
3675 : 0 : case REALPART_EXPR:
3676 : 0 : {
3677 : 0 : tree _q100 = TREE_OPERAND (gimple_assign_rhs1 (_a5), 0);
3678 : 0 : if ((TREE_CODE (_q100) == SSA_NAME
3679 : 0 : || is_gimple_min_invariant (_q100)))
3680 : : {
3681 : 0 : _q100 = do_valueize (valueize, _q100);
3682 : 0 : if ((_q100 == _q30 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q30, 0) && types_match (_q100, _q30)))
3683 : : {
3684 : 0 : {
3685 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q41, _q40, _q30 };
3686 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
3687 : : )
3688 : : {
3689 : 0 : {
3690 : 0 : res_ops[0] = captures[0];
3691 : 0 : res_ops[1] = captures[1];
3692 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 76, __FILE__, __LINE__, false);
3693 : 0 : return true;
3694 : : }
3695 : : }
3696 : : }
3697 : : }
3698 : : }
3699 : : break;
3700 : : }
3701 : : default:;
3702 : : }
3703 : : }
3704 : : break;
3705 : : default:;
3706 : : }
3707 : : }
3708 : : }
3709 : : }
3710 : : }
3711 : : }
3712 : : break;
3713 : : default:;
3714 : : }
3715 : : }
3716 : : break;
3717 : : default:;
3718 : : }
3719 : : }
3720 : : break;
3721 : : }
3722 : : default:;
3723 : : }
3724 : : }
3725 : : break;
3726 : : default:;
3727 : : }
3728 : 22317700 : break;
3729 : : }
3730 : : default:;
3731 : : }
3732 : : }
3733 : : break;
3734 : 0 : case LT_EXPR:
3735 : 0 : {
3736 : 0 : tree _q20 = TREE_OPERAND (_p0, 0);
3737 : 0 : if ((TREE_CODE (_q20) == SSA_NAME
3738 : 0 : || is_gimple_min_invariant (_q20)))
3739 : : {
3740 : 0 : _q20 = do_valueize (valueize, _q20);
3741 : 0 : tree _q21 = TREE_OPERAND (_p0, 1);
3742 : 0 : if ((TREE_CODE (_q21) == SSA_NAME
3743 : 0 : || is_gimple_min_invariant (_q21)))
3744 : : {
3745 : 0 : _q21 = do_valueize (valueize, _q21);
3746 : 0 : switch (TREE_CODE (_q20))
3747 : : {
3748 : 0 : case SSA_NAME:
3749 : 0 : if (gimple *_d2 = get_def (valueize, _q20))
3750 : : {
3751 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
3752 : 0 : switch (gimple_assign_rhs_code (_a2))
3753 : : {
3754 : 0 : case BIT_AND_EXPR:
3755 : 0 : {
3756 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
3757 : 0 : _q30 = do_valueize (valueize, _q30);
3758 : 0 : tree _q31 = gimple_assign_rhs2 (_a2);
3759 : 0 : _q31 = do_valueize (valueize, _q31);
3760 : 0 : if (tree_swap_operands_p (_q30, _q31))
3761 : 0 : std::swap (_q30, _q31);
3762 : 0 : switch (TREE_CODE (_q30))
3763 : : {
3764 : 0 : case SSA_NAME:
3765 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
3766 : : {
3767 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
3768 : 0 : switch (gimple_assign_rhs_code (_a3))
3769 : : {
3770 : 0 : case BIT_XOR_EXPR:
3771 : 0 : {
3772 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
3773 : 0 : _q40 = do_valueize (valueize, _q40);
3774 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
3775 : 0 : _q41 = do_valueize (valueize, _q41);
3776 : 0 : if (tree_swap_operands_p (_q40, _q41))
3777 : 0 : std::swap (_q40, _q41);
3778 : 0 : {
3779 : 0 : tree _q41_pops[1];
3780 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
3781 : : {
3782 : 0 : tree _q60 = _q41_pops[0];
3783 : 0 : switch (TREE_CODE (_q60))
3784 : : {
3785 : 0 : case SSA_NAME:
3786 : 0 : if (gimple *_d4 = get_def (valueize, _q60))
3787 : : {
3788 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
3789 : 0 : switch (gimple_assign_rhs_code (_a4))
3790 : : {
3791 : 0 : case PLUS_EXPR:
3792 : 0 : {
3793 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
3794 : 0 : _q70 = do_valueize (valueize, _q70);
3795 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
3796 : 0 : _q71 = do_valueize (valueize, _q71);
3797 : 0 : if (tree_swap_operands_p (_q70, _q71))
3798 : 0 : std::swap (_q70, _q71);
3799 : 0 : {
3800 : 0 : tree _q70_pops[1];
3801 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
3802 : : {
3803 : 0 : tree _q80 = _q70_pops[0];
3804 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
3805 : : {
3806 : 0 : {
3807 : 0 : tree _q71_pops[1];
3808 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
3809 : : {
3810 : 0 : tree _q100 = _q71_pops[0];
3811 : 0 : switch (TREE_CODE (_q31))
3812 : : {
3813 : 0 : case SSA_NAME:
3814 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
3815 : : {
3816 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
3817 : 0 : switch (gimple_assign_rhs_code (_a5))
3818 : : {
3819 : 0 : case BIT_NOT_EXPR:
3820 : 0 : {
3821 : 0 : tree _q120 = gimple_assign_rhs1 (_a5);
3822 : 0 : _q120 = do_valueize (valueize, _q120);
3823 : 0 : switch (TREE_CODE (_q120))
3824 : : {
3825 : 0 : case SSA_NAME:
3826 : 0 : if (gimple *_d6 = get_def (valueize, _q120))
3827 : : {
3828 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
3829 : 0 : switch (gimple_assign_rhs_code (_a6))
3830 : : {
3831 : 0 : case BIT_XOR_EXPR:
3832 : 0 : {
3833 : 0 : tree _q130 = gimple_assign_rhs1 (_a6);
3834 : 0 : _q130 = do_valueize (valueize, _q130);
3835 : 0 : tree _q131 = gimple_assign_rhs2 (_a6);
3836 : 0 : _q131 = do_valueize (valueize, _q131);
3837 : 0 : if (tree_swap_operands_p (_q130, _q131))
3838 : 0 : std::swap (_q130, _q131);
3839 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
3840 : : {
3841 : 0 : if ((_q131 == _q100 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q100, 0) && types_match (_q131, _q100)))
3842 : : {
3843 : 0 : if (integer_zerop (_q21))
3844 : : {
3845 : 0 : {
3846 : 0 : tree _p1_pops[1];
3847 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
3848 : : {
3849 : 0 : tree _q170 = _p1_pops[0];
3850 : 0 : if ((_q170 == _q40 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q40, 0) && types_match (_q170, _q40)))
3851 : : {
3852 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
3853 : : {
3854 : 0 : {
3855 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
3856 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
3857 : : )
3858 : : {
3859 : 0 : {
3860 : 0 : res_ops[0] = captures[0];
3861 : 0 : res_ops[1] = captures[1];
3862 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
3863 : 0 : return true;
3864 : : }
3865 : : }
3866 : : }
3867 : : }
3868 : : }
3869 : : }
3870 : : }
3871 : : }
3872 : : }
3873 : : }
3874 : 0 : if ((_q130 == _q100 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q100, 0) && types_match (_q130, _q100)))
3875 : : {
3876 : 0 : if ((_q131 == _q40 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q40, 0) && types_match (_q131, _q40)))
3877 : : {
3878 : 0 : if (integer_zerop (_q21))
3879 : : {
3880 : 0 : {
3881 : 0 : tree _p1_pops[1];
3882 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
3883 : : {
3884 : 0 : tree _q170 = _p1_pops[0];
3885 : 0 : if ((_q170 == _q40 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q40, 0) && types_match (_q170, _q40)))
3886 : : {
3887 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
3888 : : {
3889 : 0 : {
3890 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
3891 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
3892 : : )
3893 : : {
3894 : 0 : {
3895 : 0 : res_ops[0] = captures[0];
3896 : 0 : res_ops[1] = captures[1];
3897 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
3898 : 0 : return true;
3899 : : }
3900 : : }
3901 : : }
3902 : : }
3903 : : }
3904 : : }
3905 : : }
3906 : : }
3907 : : }
3908 : : }
3909 : 0 : break;
3910 : : }
3911 : : default:;
3912 : : }
3913 : : }
3914 : : break;
3915 : : default:;
3916 : : }
3917 : : break;
3918 : : }
3919 : : default:;
3920 : : }
3921 : : }
3922 : : break;
3923 : : default:;
3924 : : }
3925 : : }
3926 : : }
3927 : : }
3928 : : }
3929 : : }
3930 : 0 : break;
3931 : : }
3932 : : default:;
3933 : : }
3934 : : }
3935 : : break;
3936 : : default:;
3937 : : }
3938 : : }
3939 : : }
3940 : 0 : {
3941 : 0 : tree _q40_pops[1];
3942 : 0 : if (gimple_nop_convert (_q40, _q40_pops, valueize))
3943 : : {
3944 : 0 : tree _q50 = _q40_pops[0];
3945 : 0 : switch (TREE_CODE (_q50))
3946 : : {
3947 : 0 : case SSA_NAME:
3948 : 0 : if (gimple *_d4 = get_def (valueize, _q50))
3949 : : {
3950 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
3951 : 0 : switch (gimple_assign_rhs_code (_a4))
3952 : : {
3953 : 0 : case PLUS_EXPR:
3954 : 0 : {
3955 : 0 : tree _q60 = gimple_assign_rhs1 (_a4);
3956 : 0 : _q60 = do_valueize (valueize, _q60);
3957 : 0 : tree _q61 = gimple_assign_rhs2 (_a4);
3958 : 0 : _q61 = do_valueize (valueize, _q61);
3959 : 0 : if (tree_swap_operands_p (_q60, _q61))
3960 : 0 : std::swap (_q60, _q61);
3961 : 0 : {
3962 : 0 : tree _q60_pops[1];
3963 : 0 : if (gimple_nop_convert (_q60, _q60_pops, valueize))
3964 : : {
3965 : 0 : tree _q70 = _q60_pops[0];
3966 : 0 : switch (TREE_CODE (_q61))
3967 : : {
3968 : 0 : case INTEGER_CST:
3969 : 0 : {
3970 : 0 : if ((_q41 == _q70 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q70, 0) && types_match (_q41, _q70)))
3971 : : {
3972 : 0 : switch (TREE_CODE (_q31))
3973 : : {
3974 : 0 : case SSA_NAME:
3975 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
3976 : : {
3977 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
3978 : 0 : switch (gimple_assign_rhs_code (_a5))
3979 : : {
3980 : 0 : case BIT_XOR_EXPR:
3981 : 0 : {
3982 : 0 : tree _q110 = gimple_assign_rhs1 (_a5);
3983 : 0 : _q110 = do_valueize (valueize, _q110);
3984 : 0 : tree _q111 = gimple_assign_rhs2 (_a5);
3985 : 0 : _q111 = do_valueize (valueize, _q111);
3986 : 0 : if (tree_swap_operands_p (_q110, _q111))
3987 : 0 : std::swap (_q110, _q111);
3988 : 0 : if ((_q110 == _q70 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q70, 0) && types_match (_q110, _q70)))
3989 : : {
3990 : 0 : switch (TREE_CODE (_q111))
3991 : : {
3992 : 0 : case INTEGER_CST:
3993 : 0 : {
3994 : 0 : if (integer_zerop (_q21))
3995 : : {
3996 : 0 : {
3997 : 0 : tree _p1_pops[1];
3998 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
3999 : : {
4000 : 0 : tree _q150 = _p1_pops[0];
4001 : 0 : if ((_q150 == _q70 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q70, 0) && types_match (_q150, _q70)))
4002 : : {
4003 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
4004 : : {
4005 : 0 : {
4006 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q70, _q61, _q40, _q111 };
4007 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4008 : : )
4009 : : {
4010 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
4011 : : )
4012 : : {
4013 : 0 : {
4014 : 0 : res_ops[0] = captures[0];
4015 : 0 : res_ops[1] = captures[1];
4016 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
4017 : 0 : return true;
4018 : : }
4019 : : }
4020 : : }
4021 : : }
4022 : : }
4023 : : }
4024 : : }
4025 : : }
4026 : : }
4027 : : break;
4028 : : }
4029 : : default:;
4030 : : }
4031 : : }
4032 : 0 : switch (TREE_CODE (_q110))
4033 : : {
4034 : 0 : case INTEGER_CST:
4035 : 0 : {
4036 : 0 : if ((_q111 == _q70 && ! TREE_SIDE_EFFECTS (_q111)) || (operand_equal_p (_q111, _q70, 0) && types_match (_q111, _q70)))
4037 : : {
4038 : 0 : if (integer_zerop (_q21))
4039 : : {
4040 : 0 : {
4041 : 0 : tree _p1_pops[1];
4042 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4043 : : {
4044 : 0 : tree _q150 = _p1_pops[0];
4045 : 0 : if ((_q150 == _q70 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q70, 0) && types_match (_q150, _q70)))
4046 : : {
4047 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
4048 : : {
4049 : 0 : {
4050 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q70, _q61, _q40, _q110 };
4051 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4052 : : )
4053 : : {
4054 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
4055 : : )
4056 : : {
4057 : 0 : {
4058 : 0 : res_ops[0] = captures[0];
4059 : 0 : res_ops[1] = captures[1];
4060 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
4061 : 0 : return true;
4062 : : }
4063 : : }
4064 : : }
4065 : : }
4066 : : }
4067 : : }
4068 : : }
4069 : : }
4070 : : }
4071 : : }
4072 : : break;
4073 : : }
4074 : : default:;
4075 : : }
4076 : 0 : break;
4077 : : }
4078 : : default:;
4079 : : }
4080 : : }
4081 : : break;
4082 : : default:;
4083 : : }
4084 : : }
4085 : : break;
4086 : : }
4087 : 0 : default:;
4088 : : }
4089 : 0 : {
4090 : 0 : tree _q61_pops[1];
4091 : 0 : if (gimple_nop_convert (_q61, _q61_pops, valueize))
4092 : : {
4093 : 0 : tree _q90 = _q61_pops[0];
4094 : 0 : if ((_q41 == _q70 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q70, 0) && types_match (_q41, _q70)))
4095 : : {
4096 : 0 : switch (TREE_CODE (_q31))
4097 : : {
4098 : 0 : case SSA_NAME:
4099 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
4100 : : {
4101 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
4102 : 0 : switch (gimple_assign_rhs_code (_a5))
4103 : : {
4104 : 0 : case BIT_NOT_EXPR:
4105 : 0 : {
4106 : 0 : tree _q120 = gimple_assign_rhs1 (_a5);
4107 : 0 : _q120 = do_valueize (valueize, _q120);
4108 : 0 : switch (TREE_CODE (_q120))
4109 : : {
4110 : 0 : case SSA_NAME:
4111 : 0 : if (gimple *_d6 = get_def (valueize, _q120))
4112 : : {
4113 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
4114 : 0 : switch (gimple_assign_rhs_code (_a6))
4115 : : {
4116 : 0 : case BIT_XOR_EXPR:
4117 : 0 : {
4118 : 0 : tree _q130 = gimple_assign_rhs1 (_a6);
4119 : 0 : _q130 = do_valueize (valueize, _q130);
4120 : 0 : tree _q131 = gimple_assign_rhs2 (_a6);
4121 : 0 : _q131 = do_valueize (valueize, _q131);
4122 : 0 : if (tree_swap_operands_p (_q130, _q131))
4123 : 0 : std::swap (_q130, _q131);
4124 : 0 : if ((_q130 == _q70 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q70, 0) && types_match (_q130, _q70)))
4125 : : {
4126 : 0 : if ((_q131 == _q90 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q90, 0) && types_match (_q131, _q90)))
4127 : : {
4128 : 0 : if (integer_zerop (_q21))
4129 : : {
4130 : 0 : {
4131 : 0 : tree _p1_pops[1];
4132 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4133 : : {
4134 : 0 : tree _q170 = _p1_pops[0];
4135 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
4136 : : {
4137 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
4138 : : {
4139 : 0 : {
4140 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q70, _q90, _q40 };
4141 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4142 : : )
4143 : : {
4144 : 0 : {
4145 : 0 : res_ops[0] = captures[0];
4146 : 0 : res_ops[1] = captures[1];
4147 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
4148 : 0 : return true;
4149 : : }
4150 : : }
4151 : : }
4152 : : }
4153 : : }
4154 : : }
4155 : : }
4156 : : }
4157 : : }
4158 : : }
4159 : 0 : if ((_q130 == _q90 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q90, 0) && types_match (_q130, _q90)))
4160 : : {
4161 : 0 : if ((_q131 == _q70 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q70, 0) && types_match (_q131, _q70)))
4162 : : {
4163 : 0 : if (integer_zerop (_q21))
4164 : : {
4165 : 0 : {
4166 : 0 : tree _p1_pops[1];
4167 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4168 : : {
4169 : 0 : tree _q170 = _p1_pops[0];
4170 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
4171 : : {
4172 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
4173 : : {
4174 : 0 : {
4175 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q70, _q90, _q40 };
4176 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4177 : : )
4178 : : {
4179 : 0 : {
4180 : 0 : res_ops[0] = captures[0];
4181 : 0 : res_ops[1] = captures[1];
4182 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
4183 : 0 : return true;
4184 : : }
4185 : : }
4186 : : }
4187 : : }
4188 : : }
4189 : : }
4190 : : }
4191 : : }
4192 : : }
4193 : : }
4194 : 0 : break;
4195 : : }
4196 : : default:;
4197 : : }
4198 : : }
4199 : : break;
4200 : : default:;
4201 : : }
4202 : : break;
4203 : : }
4204 : : default:;
4205 : : }
4206 : : }
4207 : : break;
4208 : : default:;
4209 : : }
4210 : : }
4211 : : }
4212 : : }
4213 : : }
4214 : : }
4215 : 0 : break;
4216 : : }
4217 : : default:;
4218 : : }
4219 : : }
4220 : : break;
4221 : : default:;
4222 : : }
4223 : : }
4224 : : }
4225 : 0 : switch (TREE_CODE (_q41))
4226 : : {
4227 : 0 : case INTEGER_CST:
4228 : 0 : {
4229 : 0 : switch (TREE_CODE (_q31))
4230 : : {
4231 : 0 : case SSA_NAME:
4232 : 0 : if (gimple *_d4 = get_def (valueize, _q31))
4233 : : {
4234 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
4235 : 0 : switch (gimple_assign_rhs_code (_a4))
4236 : : {
4237 : 0 : case BIT_XOR_EXPR:
4238 : 0 : {
4239 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
4240 : 0 : _q70 = do_valueize (valueize, _q70);
4241 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
4242 : 0 : _q71 = do_valueize (valueize, _q71);
4243 : 0 : if (tree_swap_operands_p (_q70, _q71))
4244 : 0 : std::swap (_q70, _q71);
4245 : 0 : if ((_q70 == _q40 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q40, 0) && types_match (_q70, _q40)))
4246 : : {
4247 : 0 : {
4248 : 0 : tree _q71_pops[1];
4249 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
4250 : : {
4251 : 0 : tree _q90 = _q71_pops[0];
4252 : 0 : switch (TREE_CODE (_q90))
4253 : : {
4254 : 0 : case SSA_NAME:
4255 : 0 : if (gimple *_d5 = get_def (valueize, _q90))
4256 : : {
4257 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
4258 : 0 : switch (gimple_assign_rhs_code (_a5))
4259 : : {
4260 : 0 : case PLUS_EXPR:
4261 : 0 : {
4262 : 0 : tree _q100 = gimple_assign_rhs1 (_a5);
4263 : 0 : _q100 = do_valueize (valueize, _q100);
4264 : 0 : tree _q101 = gimple_assign_rhs2 (_a5);
4265 : 0 : _q101 = do_valueize (valueize, _q101);
4266 : 0 : if (tree_swap_operands_p (_q100, _q101))
4267 : 0 : std::swap (_q100, _q101);
4268 : 0 : {
4269 : 0 : tree _q100_pops[1];
4270 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
4271 : : {
4272 : 0 : tree _q110 = _q100_pops[0];
4273 : 0 : if ((_q110 == _q40 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q40, 0) && types_match (_q110, _q40)))
4274 : : {
4275 : 0 : switch (TREE_CODE (_q101))
4276 : : {
4277 : 0 : case INTEGER_CST:
4278 : 0 : {
4279 : 0 : if (integer_zerop (_q21))
4280 : : {
4281 : 0 : {
4282 : 0 : tree _p1_pops[1];
4283 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4284 : : {
4285 : 0 : tree _q150 = _p1_pops[0];
4286 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
4287 : : {
4288 : 0 : if ((_p2 == _q71 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q71, 0) && types_match (_p2, _q71)))
4289 : : {
4290 : 0 : {
4291 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q101, _q71, _q41 };
4292 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4293 : : )
4294 : : {
4295 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
4296 : : )
4297 : : {
4298 : 0 : {
4299 : 0 : res_ops[0] = captures[0];
4300 : 0 : res_ops[1] = captures[1];
4301 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
4302 : 0 : return true;
4303 : : }
4304 : : }
4305 : : }
4306 : : }
4307 : : }
4308 : : }
4309 : : }
4310 : : }
4311 : : }
4312 : : break;
4313 : : }
4314 : : default:;
4315 : : }
4316 : : }
4317 : : }
4318 : : }
4319 : 0 : break;
4320 : : }
4321 : : default:;
4322 : : }
4323 : : }
4324 : : break;
4325 : : default:;
4326 : : }
4327 : : }
4328 : : }
4329 : : }
4330 : 0 : break;
4331 : : }
4332 : : default:;
4333 : : }
4334 : : }
4335 : : break;
4336 : : default:;
4337 : : }
4338 : : break;
4339 : : }
4340 : 0 : default:;
4341 : : }
4342 : 0 : {
4343 : 0 : tree _q41_pops[1];
4344 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
4345 : : {
4346 : 0 : tree _q60 = _q41_pops[0];
4347 : 0 : switch (TREE_CODE (_q60))
4348 : : {
4349 : 0 : case SSA_NAME:
4350 : 0 : if (gimple *_d4 = get_def (valueize, _q60))
4351 : : {
4352 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
4353 : 0 : switch (gimple_assign_rhs_code (_a4))
4354 : : {
4355 : 0 : case PLUS_EXPR:
4356 : 0 : {
4357 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
4358 : 0 : _q70 = do_valueize (valueize, _q70);
4359 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
4360 : 0 : _q71 = do_valueize (valueize, _q71);
4361 : 0 : if (tree_swap_operands_p (_q70, _q71))
4362 : 0 : std::swap (_q70, _q71);
4363 : 0 : {
4364 : 0 : tree _q70_pops[1];
4365 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
4366 : : {
4367 : 0 : tree _q80 = _q70_pops[0];
4368 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
4369 : : {
4370 : 0 : switch (TREE_CODE (_q71))
4371 : : {
4372 : 0 : case INTEGER_CST:
4373 : 0 : {
4374 : 0 : switch (TREE_CODE (_q31))
4375 : : {
4376 : 0 : case SSA_NAME:
4377 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
4378 : : {
4379 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
4380 : 0 : switch (gimple_assign_rhs_code (_a5))
4381 : : {
4382 : 0 : case BIT_XOR_EXPR:
4383 : 0 : {
4384 : 0 : tree _q110 = gimple_assign_rhs1 (_a5);
4385 : 0 : _q110 = do_valueize (valueize, _q110);
4386 : 0 : tree _q111 = gimple_assign_rhs2 (_a5);
4387 : 0 : _q111 = do_valueize (valueize, _q111);
4388 : 0 : if (tree_swap_operands_p (_q110, _q111))
4389 : 0 : std::swap (_q110, _q111);
4390 : 0 : if ((_q110 == _q40 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q40, 0) && types_match (_q110, _q40)))
4391 : : {
4392 : 0 : switch (TREE_CODE (_q111))
4393 : : {
4394 : 0 : case INTEGER_CST:
4395 : 0 : {
4396 : 0 : if (integer_zerop (_q21))
4397 : : {
4398 : 0 : {
4399 : 0 : tree _p1_pops[1];
4400 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4401 : : {
4402 : 0 : tree _q150 = _p1_pops[0];
4403 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
4404 : : {
4405 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
4406 : : {
4407 : 0 : {
4408 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q71, _q41, _q111 };
4409 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4410 : : )
4411 : : {
4412 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
4413 : : )
4414 : : {
4415 : 0 : {
4416 : 0 : res_ops[0] = captures[0];
4417 : 0 : res_ops[1] = captures[1];
4418 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
4419 : 0 : return true;
4420 : : }
4421 : : }
4422 : : }
4423 : : }
4424 : : }
4425 : : }
4426 : : }
4427 : : }
4428 : : }
4429 : : break;
4430 : : }
4431 : : default:;
4432 : : }
4433 : : }
4434 : 0 : switch (TREE_CODE (_q110))
4435 : : {
4436 : 0 : case INTEGER_CST:
4437 : 0 : {
4438 : 0 : if ((_q111 == _q40 && ! TREE_SIDE_EFFECTS (_q111)) || (operand_equal_p (_q111, _q40, 0) && types_match (_q111, _q40)))
4439 : : {
4440 : 0 : if (integer_zerop (_q21))
4441 : : {
4442 : 0 : {
4443 : 0 : tree _p1_pops[1];
4444 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4445 : : {
4446 : 0 : tree _q150 = _p1_pops[0];
4447 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
4448 : : {
4449 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
4450 : : {
4451 : 0 : {
4452 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q71, _q41, _q110 };
4453 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4454 : : )
4455 : : {
4456 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
4457 : : )
4458 : : {
4459 : 0 : {
4460 : 0 : res_ops[0] = captures[0];
4461 : 0 : res_ops[1] = captures[1];
4462 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
4463 : 0 : return true;
4464 : : }
4465 : : }
4466 : : }
4467 : : }
4468 : : }
4469 : : }
4470 : : }
4471 : : }
4472 : : }
4473 : : }
4474 : : break;
4475 : : }
4476 : : default:;
4477 : : }
4478 : 0 : break;
4479 : : }
4480 : : default:;
4481 : : }
4482 : : }
4483 : : break;
4484 : : default:;
4485 : : }
4486 : : break;
4487 : : }
4488 : : default:;
4489 : : }
4490 : : }
4491 : : }
4492 : : }
4493 : 0 : break;
4494 : : }
4495 : : default:;
4496 : : }
4497 : : }
4498 : : break;
4499 : : default:;
4500 : : }
4501 : : }
4502 : : }
4503 : 0 : switch (TREE_CODE (_q40))
4504 : : {
4505 : 0 : case INTEGER_CST:
4506 : 0 : {
4507 : 0 : switch (TREE_CODE (_q31))
4508 : : {
4509 : 0 : case SSA_NAME:
4510 : 0 : if (gimple *_d4 = get_def (valueize, _q31))
4511 : : {
4512 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
4513 : 0 : switch (gimple_assign_rhs_code (_a4))
4514 : : {
4515 : 0 : case BIT_XOR_EXPR:
4516 : 0 : {
4517 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
4518 : 0 : _q70 = do_valueize (valueize, _q70);
4519 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
4520 : 0 : _q71 = do_valueize (valueize, _q71);
4521 : 0 : if (tree_swap_operands_p (_q70, _q71))
4522 : 0 : std::swap (_q70, _q71);
4523 : 0 : if ((_q70 == _q41 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q41, 0) && types_match (_q70, _q41)))
4524 : : {
4525 : 0 : {
4526 : 0 : tree _q71_pops[1];
4527 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
4528 : : {
4529 : 0 : tree _q90 = _q71_pops[0];
4530 : 0 : switch (TREE_CODE (_q90))
4531 : : {
4532 : 0 : case SSA_NAME:
4533 : 0 : if (gimple *_d5 = get_def (valueize, _q90))
4534 : : {
4535 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
4536 : 0 : switch (gimple_assign_rhs_code (_a5))
4537 : : {
4538 : 0 : case PLUS_EXPR:
4539 : 0 : {
4540 : 0 : tree _q100 = gimple_assign_rhs1 (_a5);
4541 : 0 : _q100 = do_valueize (valueize, _q100);
4542 : 0 : tree _q101 = gimple_assign_rhs2 (_a5);
4543 : 0 : _q101 = do_valueize (valueize, _q101);
4544 : 0 : if (tree_swap_operands_p (_q100, _q101))
4545 : 0 : std::swap (_q100, _q101);
4546 : 0 : {
4547 : 0 : tree _q100_pops[1];
4548 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
4549 : : {
4550 : 0 : tree _q110 = _q100_pops[0];
4551 : 0 : if ((_q110 == _q41 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q41, 0) && types_match (_q110, _q41)))
4552 : : {
4553 : 0 : switch (TREE_CODE (_q101))
4554 : : {
4555 : 0 : case INTEGER_CST:
4556 : 0 : {
4557 : 0 : if (integer_zerop (_q21))
4558 : : {
4559 : 0 : {
4560 : 0 : tree _p1_pops[1];
4561 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4562 : : {
4563 : 0 : tree _q150 = _p1_pops[0];
4564 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
4565 : : {
4566 : 0 : if ((_p2 == _q71 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q71, 0) && types_match (_p2, _q71)))
4567 : : {
4568 : 0 : {
4569 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q41, _q101, _q71, _q40 };
4570 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4571 : : )
4572 : : {
4573 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
4574 : : )
4575 : : {
4576 : 0 : {
4577 : 0 : res_ops[0] = captures[0];
4578 : 0 : res_ops[1] = captures[1];
4579 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
4580 : 0 : return true;
4581 : : }
4582 : : }
4583 : : }
4584 : : }
4585 : : }
4586 : : }
4587 : : }
4588 : : }
4589 : : }
4590 : : break;
4591 : : }
4592 : : default:;
4593 : : }
4594 : : }
4595 : : }
4596 : : }
4597 : 0 : break;
4598 : : }
4599 : : default:;
4600 : : }
4601 : : }
4602 : : break;
4603 : : default:;
4604 : : }
4605 : : }
4606 : : }
4607 : : }
4608 : 0 : {
4609 : 0 : tree _q70_pops[1];
4610 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
4611 : : {
4612 : 0 : tree _q80 = _q70_pops[0];
4613 : 0 : switch (TREE_CODE (_q80))
4614 : : {
4615 : 0 : case SSA_NAME:
4616 : 0 : if (gimple *_d5 = get_def (valueize, _q80))
4617 : : {
4618 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
4619 : 0 : switch (gimple_assign_rhs_code (_a5))
4620 : : {
4621 : 0 : case PLUS_EXPR:
4622 : 0 : {
4623 : 0 : tree _q90 = gimple_assign_rhs1 (_a5);
4624 : 0 : _q90 = do_valueize (valueize, _q90);
4625 : 0 : tree _q91 = gimple_assign_rhs2 (_a5);
4626 : 0 : _q91 = do_valueize (valueize, _q91);
4627 : 0 : if (tree_swap_operands_p (_q90, _q91))
4628 : 0 : std::swap (_q90, _q91);
4629 : 0 : {
4630 : 0 : tree _q90_pops[1];
4631 : 0 : if (gimple_nop_convert (_q90, _q90_pops, valueize))
4632 : : {
4633 : 0 : tree _q100 = _q90_pops[0];
4634 : 0 : if ((_q100 == _q41 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q41, 0) && types_match (_q100, _q41)))
4635 : : {
4636 : 0 : switch (TREE_CODE (_q91))
4637 : : {
4638 : 0 : case INTEGER_CST:
4639 : 0 : {
4640 : 0 : if ((_q71 == _q41 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q41, 0) && types_match (_q71, _q41)))
4641 : : {
4642 : 0 : if (integer_zerop (_q21))
4643 : : {
4644 : 0 : {
4645 : 0 : tree _p1_pops[1];
4646 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4647 : : {
4648 : 0 : tree _q150 = _p1_pops[0];
4649 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
4650 : : {
4651 : 0 : if ((_p2 == _q70 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q70, 0) && types_match (_p2, _q70)))
4652 : : {
4653 : 0 : {
4654 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q41, _q91, _q70, _q40 };
4655 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4656 : : )
4657 : : {
4658 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
4659 : : )
4660 : : {
4661 : 0 : {
4662 : 0 : res_ops[0] = captures[0];
4663 : 0 : res_ops[1] = captures[1];
4664 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
4665 : 0 : return true;
4666 : : }
4667 : : }
4668 : : }
4669 : : }
4670 : : }
4671 : : }
4672 : : }
4673 : : }
4674 : : }
4675 : : }
4676 : : break;
4677 : : }
4678 : : default:;
4679 : : }
4680 : : }
4681 : : }
4682 : : }
4683 : 0 : break;
4684 : : }
4685 : : default:;
4686 : : }
4687 : : }
4688 : : break;
4689 : : default:;
4690 : : }
4691 : : }
4692 : : }
4693 : 0 : break;
4694 : : }
4695 : : default:;
4696 : : }
4697 : : }
4698 : : break;
4699 : : default:;
4700 : : }
4701 : : break;
4702 : : }
4703 : 0 : default:;
4704 : : }
4705 : 0 : switch (TREE_CODE (_q41))
4706 : : {
4707 : 0 : case INTEGER_CST:
4708 : 0 : {
4709 : 0 : switch (TREE_CODE (_q31))
4710 : : {
4711 : 0 : case SSA_NAME:
4712 : 0 : if (gimple *_d4 = get_def (valueize, _q31))
4713 : : {
4714 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
4715 : 0 : switch (gimple_assign_rhs_code (_a4))
4716 : : {
4717 : 0 : case BIT_XOR_EXPR:
4718 : 0 : {
4719 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
4720 : 0 : _q70 = do_valueize (valueize, _q70);
4721 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
4722 : 0 : _q71 = do_valueize (valueize, _q71);
4723 : 0 : if (tree_swap_operands_p (_q70, _q71))
4724 : 0 : std::swap (_q70, _q71);
4725 : 0 : {
4726 : 0 : tree _q70_pops[1];
4727 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
4728 : : {
4729 : 0 : tree _q80 = _q70_pops[0];
4730 : 0 : switch (TREE_CODE (_q80))
4731 : : {
4732 : 0 : case SSA_NAME:
4733 : 0 : if (gimple *_d5 = get_def (valueize, _q80))
4734 : : {
4735 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
4736 : 0 : switch (gimple_assign_rhs_code (_a5))
4737 : : {
4738 : 0 : case PLUS_EXPR:
4739 : 0 : {
4740 : 0 : tree _q90 = gimple_assign_rhs1 (_a5);
4741 : 0 : _q90 = do_valueize (valueize, _q90);
4742 : 0 : tree _q91 = gimple_assign_rhs2 (_a5);
4743 : 0 : _q91 = do_valueize (valueize, _q91);
4744 : 0 : if (tree_swap_operands_p (_q90, _q91))
4745 : 0 : std::swap (_q90, _q91);
4746 : 0 : {
4747 : 0 : tree _q90_pops[1];
4748 : 0 : if (gimple_nop_convert (_q90, _q90_pops, valueize))
4749 : : {
4750 : 0 : tree _q100 = _q90_pops[0];
4751 : 0 : if ((_q100 == _q40 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q40, 0) && types_match (_q100, _q40)))
4752 : : {
4753 : 0 : switch (TREE_CODE (_q91))
4754 : : {
4755 : 0 : case INTEGER_CST:
4756 : 0 : {
4757 : 0 : if ((_q71 == _q40 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q40, 0) && types_match (_q71, _q40)))
4758 : : {
4759 : 0 : if (integer_zerop (_q21))
4760 : : {
4761 : 0 : {
4762 : 0 : tree _p1_pops[1];
4763 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4764 : : {
4765 : 0 : tree _q150 = _p1_pops[0];
4766 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
4767 : : {
4768 : 0 : if ((_p2 == _q70 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q70, 0) && types_match (_p2, _q70)))
4769 : : {
4770 : 0 : {
4771 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q91, _q70, _q41 };
4772 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4773 : : )
4774 : : {
4775 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
4776 : : )
4777 : : {
4778 : 0 : {
4779 : 0 : res_ops[0] = captures[0];
4780 : 0 : res_ops[1] = captures[1];
4781 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
4782 : 0 : return true;
4783 : : }
4784 : : }
4785 : : }
4786 : : }
4787 : : }
4788 : : }
4789 : : }
4790 : : }
4791 : : }
4792 : : }
4793 : : break;
4794 : : }
4795 : : default:;
4796 : : }
4797 : : }
4798 : : }
4799 : : }
4800 : 0 : break;
4801 : : }
4802 : : default:;
4803 : : }
4804 : : }
4805 : : break;
4806 : : default:;
4807 : : }
4808 : : }
4809 : : }
4810 : 0 : break;
4811 : : }
4812 : : default:;
4813 : : }
4814 : : }
4815 : : break;
4816 : : default:;
4817 : : }
4818 : : break;
4819 : : }
4820 : : default:;
4821 : : }
4822 : 22317700 : break;
4823 : : }
4824 : 0 : case BIT_NOT_EXPR:
4825 : 0 : {
4826 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
4827 : 0 : _q40 = do_valueize (valueize, _q40);
4828 : 0 : switch (TREE_CODE (_q40))
4829 : : {
4830 : 0 : case SSA_NAME:
4831 : 0 : if (gimple *_d4 = get_def (valueize, _q40))
4832 : : {
4833 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
4834 : 0 : switch (gimple_assign_rhs_code (_a4))
4835 : : {
4836 : 0 : case BIT_XOR_EXPR:
4837 : 0 : {
4838 : 0 : tree _q50 = gimple_assign_rhs1 (_a4);
4839 : 0 : _q50 = do_valueize (valueize, _q50);
4840 : 0 : tree _q51 = gimple_assign_rhs2 (_a4);
4841 : 0 : _q51 = do_valueize (valueize, _q51);
4842 : 0 : if (tree_swap_operands_p (_q50, _q51))
4843 : 0 : std::swap (_q50, _q51);
4844 : 0 : switch (TREE_CODE (_q31))
4845 : : {
4846 : 0 : case SSA_NAME:
4847 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
4848 : : {
4849 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
4850 : 0 : switch (gimple_assign_rhs_code (_a5))
4851 : : {
4852 : 0 : case BIT_XOR_EXPR:
4853 : 0 : {
4854 : 0 : tree _q80 = gimple_assign_rhs1 (_a5);
4855 : 0 : _q80 = do_valueize (valueize, _q80);
4856 : 0 : tree _q81 = gimple_assign_rhs2 (_a5);
4857 : 0 : _q81 = do_valueize (valueize, _q81);
4858 : 0 : if (tree_swap_operands_p (_q80, _q81))
4859 : 0 : std::swap (_q80, _q81);
4860 : 0 : if ((_q80 == _q50 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q50, 0) && types_match (_q80, _q50)))
4861 : : {
4862 : 0 : {
4863 : 0 : tree _q81_pops[1];
4864 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
4865 : : {
4866 : 0 : tree _q100 = _q81_pops[0];
4867 : 0 : switch (TREE_CODE (_q100))
4868 : : {
4869 : 0 : case SSA_NAME:
4870 : 0 : if (gimple *_d6 = get_def (valueize, _q100))
4871 : : {
4872 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
4873 : 0 : switch (gimple_assign_rhs_code (_a6))
4874 : : {
4875 : 0 : case PLUS_EXPR:
4876 : 0 : {
4877 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
4878 : 0 : _q110 = do_valueize (valueize, _q110);
4879 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
4880 : 0 : _q111 = do_valueize (valueize, _q111);
4881 : 0 : if (tree_swap_operands_p (_q110, _q111))
4882 : 0 : std::swap (_q110, _q111);
4883 : 0 : {
4884 : 0 : tree _q110_pops[1];
4885 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
4886 : : {
4887 : 0 : tree _q120 = _q110_pops[0];
4888 : 0 : if ((_q120 == _q50 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q50, 0) && types_match (_q120, _q50)))
4889 : : {
4890 : 0 : {
4891 : 0 : tree _q111_pops[1];
4892 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
4893 : : {
4894 : 0 : tree _q140 = _q111_pops[0];
4895 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
4896 : : {
4897 : 0 : if (integer_zerop (_q21))
4898 : : {
4899 : 0 : {
4900 : 0 : tree _p1_pops[1];
4901 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4902 : : {
4903 : 0 : tree _q170 = _p1_pops[0];
4904 : 0 : if ((_q170 == _q50 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q50, 0) && types_match (_q170, _q50)))
4905 : : {
4906 : 0 : if ((_p2 == _q81 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q81, 0) && types_match (_p2, _q81)))
4907 : : {
4908 : 0 : {
4909 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
4910 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4911 : : )
4912 : : {
4913 : 0 : {
4914 : 0 : res_ops[0] = captures[0];
4915 : 0 : res_ops[1] = captures[1];
4916 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
4917 : 0 : return true;
4918 : : }
4919 : : }
4920 : : }
4921 : : }
4922 : : }
4923 : : }
4924 : : }
4925 : : }
4926 : : }
4927 : : }
4928 : : }
4929 : : }
4930 : : }
4931 : : }
4932 : 0 : break;
4933 : : }
4934 : : default:;
4935 : : }
4936 : : }
4937 : : break;
4938 : : default:;
4939 : : }
4940 : : }
4941 : : }
4942 : : }
4943 : 0 : if ((_q80 == _q51 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q51, 0) && types_match (_q80, _q51)))
4944 : : {
4945 : 0 : {
4946 : 0 : tree _q81_pops[1];
4947 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
4948 : : {
4949 : 0 : tree _q100 = _q81_pops[0];
4950 : 0 : switch (TREE_CODE (_q100))
4951 : : {
4952 : 0 : case SSA_NAME:
4953 : 0 : if (gimple *_d6 = get_def (valueize, _q100))
4954 : : {
4955 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
4956 : 0 : switch (gimple_assign_rhs_code (_a6))
4957 : : {
4958 : 0 : case PLUS_EXPR:
4959 : 0 : {
4960 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
4961 : 0 : _q110 = do_valueize (valueize, _q110);
4962 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
4963 : 0 : _q111 = do_valueize (valueize, _q111);
4964 : 0 : if (tree_swap_operands_p (_q110, _q111))
4965 : 0 : std::swap (_q110, _q111);
4966 : 0 : {
4967 : 0 : tree _q110_pops[1];
4968 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
4969 : : {
4970 : 0 : tree _q120 = _q110_pops[0];
4971 : 0 : if ((_q120 == _q51 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q51, 0) && types_match (_q120, _q51)))
4972 : : {
4973 : 0 : {
4974 : 0 : tree _q111_pops[1];
4975 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
4976 : : {
4977 : 0 : tree _q140 = _q111_pops[0];
4978 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
4979 : : {
4980 : 0 : if (integer_zerop (_q21))
4981 : : {
4982 : 0 : {
4983 : 0 : tree _p1_pops[1];
4984 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
4985 : : {
4986 : 0 : tree _q170 = _p1_pops[0];
4987 : 0 : if ((_q170 == _q51 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q51, 0) && types_match (_q170, _q51)))
4988 : : {
4989 : 0 : if ((_p2 == _q81 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q81, 0) && types_match (_p2, _q81)))
4990 : : {
4991 : 0 : {
4992 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
4993 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
4994 : : )
4995 : : {
4996 : 0 : {
4997 : 0 : res_ops[0] = captures[0];
4998 : 0 : res_ops[1] = captures[1];
4999 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
5000 : 0 : return true;
5001 : : }
5002 : : }
5003 : : }
5004 : : }
5005 : : }
5006 : : }
5007 : : }
5008 : : }
5009 : : }
5010 : : }
5011 : : }
5012 : : }
5013 : : }
5014 : : }
5015 : 0 : break;
5016 : : }
5017 : : default:;
5018 : : }
5019 : : }
5020 : : break;
5021 : : default:;
5022 : : }
5023 : : }
5024 : : }
5025 : : }
5026 : 0 : {
5027 : 0 : tree _q80_pops[1];
5028 : 0 : if (gimple_nop_convert (_q80, _q80_pops, valueize))
5029 : : {
5030 : 0 : tree _q90 = _q80_pops[0];
5031 : 0 : switch (TREE_CODE (_q90))
5032 : : {
5033 : 0 : case SSA_NAME:
5034 : 0 : if (gimple *_d6 = get_def (valueize, _q90))
5035 : : {
5036 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
5037 : 0 : switch (gimple_assign_rhs_code (_a6))
5038 : : {
5039 : 0 : case PLUS_EXPR:
5040 : 0 : {
5041 : 0 : tree _q100 = gimple_assign_rhs1 (_a6);
5042 : 0 : _q100 = do_valueize (valueize, _q100);
5043 : 0 : tree _q101 = gimple_assign_rhs2 (_a6);
5044 : 0 : _q101 = do_valueize (valueize, _q101);
5045 : 0 : if (tree_swap_operands_p (_q100, _q101))
5046 : 0 : std::swap (_q100, _q101);
5047 : 0 : {
5048 : 0 : tree _q100_pops[1];
5049 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
5050 : : {
5051 : 0 : tree _q110 = _q100_pops[0];
5052 : 0 : if ((_q110 == _q50 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q50, 0) && types_match (_q110, _q50)))
5053 : : {
5054 : 0 : {
5055 : 0 : tree _q101_pops[1];
5056 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
5057 : : {
5058 : 0 : tree _q130 = _q101_pops[0];
5059 : 0 : if ((_q130 == _q51 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q51, 0) && types_match (_q130, _q51)))
5060 : : {
5061 : 0 : if ((_q81 == _q50 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q50, 0) && types_match (_q81, _q50)))
5062 : : {
5063 : 0 : if (integer_zerop (_q21))
5064 : : {
5065 : 0 : {
5066 : 0 : tree _p1_pops[1];
5067 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
5068 : : {
5069 : 0 : tree _q170 = _p1_pops[0];
5070 : 0 : if ((_q170 == _q50 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q50, 0) && types_match (_q170, _q50)))
5071 : : {
5072 : 0 : if ((_p2 == _q80 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q80, 0) && types_match (_p2, _q80)))
5073 : : {
5074 : 0 : {
5075 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q80 };
5076 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
5077 : : )
5078 : : {
5079 : 0 : {
5080 : 0 : res_ops[0] = captures[0];
5081 : 0 : res_ops[1] = captures[1];
5082 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
5083 : 0 : return true;
5084 : : }
5085 : : }
5086 : : }
5087 : : }
5088 : : }
5089 : : }
5090 : : }
5091 : : }
5092 : : }
5093 : : }
5094 : : }
5095 : : }
5096 : : }
5097 : 0 : if ((_q110 == _q51 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q51, 0) && types_match (_q110, _q51)))
5098 : : {
5099 : 0 : {
5100 : 0 : tree _q101_pops[1];
5101 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
5102 : : {
5103 : 0 : tree _q130 = _q101_pops[0];
5104 : 0 : if ((_q130 == _q50 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q50, 0) && types_match (_q130, _q50)))
5105 : : {
5106 : 0 : if ((_q81 == _q51 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q51, 0) && types_match (_q81, _q51)))
5107 : : {
5108 : 0 : if (integer_zerop (_q21))
5109 : : {
5110 : 0 : {
5111 : 0 : tree _p1_pops[1];
5112 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
5113 : : {
5114 : 0 : tree _q170 = _p1_pops[0];
5115 : 0 : if ((_q170 == _q51 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q51, 0) && types_match (_q170, _q51)))
5116 : : {
5117 : 0 : if ((_p2 == _q80 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q80, 0) && types_match (_p2, _q80)))
5118 : : {
5119 : 0 : {
5120 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q80 };
5121 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
5122 : : )
5123 : : {
5124 : 0 : {
5125 : 0 : res_ops[0] = captures[0];
5126 : 0 : res_ops[1] = captures[1];
5127 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
5128 : 0 : return true;
5129 : : }
5130 : : }
5131 : : }
5132 : : }
5133 : : }
5134 : : }
5135 : : }
5136 : : }
5137 : : }
5138 : : }
5139 : : }
5140 : : }
5141 : : }
5142 : : }
5143 : : }
5144 : 0 : break;
5145 : : }
5146 : : default:;
5147 : : }
5148 : : }
5149 : : break;
5150 : : default:;
5151 : : }
5152 : : }
5153 : : }
5154 : 0 : break;
5155 : : }
5156 : : default:;
5157 : : }
5158 : : }
5159 : : break;
5160 : : default:;
5161 : : }
5162 : 22317700 : break;
5163 : : }
5164 : : default:;
5165 : : }
5166 : : }
5167 : : break;
5168 : : default:;
5169 : : }
5170 : : break;
5171 : : }
5172 : : default:;
5173 : : }
5174 : : }
5175 : : break;
5176 : : default:;
5177 : : }
5178 : 22317700 : break;
5179 : : }
5180 : : default:;
5181 : : }
5182 : : }
5183 : : break;
5184 : : default:;
5185 : : }
5186 : : }
5187 : : }
5188 : : break;
5189 : : }
5190 : 0 : case GE_EXPR:
5191 : 0 : {
5192 : 0 : tree _q20 = TREE_OPERAND (_p0, 0);
5193 : 0 : if ((TREE_CODE (_q20) == SSA_NAME
5194 : 0 : || is_gimple_min_invariant (_q20)))
5195 : : {
5196 : 0 : _q20 = do_valueize (valueize, _q20);
5197 : 0 : tree _q21 = TREE_OPERAND (_p0, 1);
5198 : 0 : if ((TREE_CODE (_q21) == SSA_NAME
5199 : 0 : || is_gimple_min_invariant (_q21)))
5200 : : {
5201 : 0 : _q21 = do_valueize (valueize, _q21);
5202 : 0 : switch (TREE_CODE (_q20))
5203 : : {
5204 : 0 : case SSA_NAME:
5205 : 0 : if (gimple *_d2 = get_def (valueize, _q20))
5206 : : {
5207 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
5208 : 0 : switch (gimple_assign_rhs_code (_a2))
5209 : : {
5210 : 0 : case BIT_AND_EXPR:
5211 : 0 : {
5212 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
5213 : 0 : _q30 = do_valueize (valueize, _q30);
5214 : 0 : tree _q31 = gimple_assign_rhs2 (_a2);
5215 : 0 : _q31 = do_valueize (valueize, _q31);
5216 : 0 : if (tree_swap_operands_p (_q30, _q31))
5217 : 0 : std::swap (_q30, _q31);
5218 : 0 : switch (TREE_CODE (_q30))
5219 : : {
5220 : 0 : case SSA_NAME:
5221 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
5222 : : {
5223 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
5224 : 0 : switch (gimple_assign_rhs_code (_a3))
5225 : : {
5226 : 0 : case BIT_XOR_EXPR:
5227 : 0 : {
5228 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
5229 : 0 : _q40 = do_valueize (valueize, _q40);
5230 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
5231 : 0 : _q41 = do_valueize (valueize, _q41);
5232 : 0 : if (tree_swap_operands_p (_q40, _q41))
5233 : 0 : std::swap (_q40, _q41);
5234 : 0 : {
5235 : 0 : tree _q41_pops[1];
5236 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
5237 : : {
5238 : 0 : tree _q60 = _q41_pops[0];
5239 : 0 : switch (TREE_CODE (_q60))
5240 : : {
5241 : 0 : case SSA_NAME:
5242 : 0 : if (gimple *_d4 = get_def (valueize, _q60))
5243 : : {
5244 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
5245 : 0 : switch (gimple_assign_rhs_code (_a4))
5246 : : {
5247 : 0 : case PLUS_EXPR:
5248 : 0 : {
5249 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
5250 : 0 : _q70 = do_valueize (valueize, _q70);
5251 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
5252 : 0 : _q71 = do_valueize (valueize, _q71);
5253 : 0 : if (tree_swap_operands_p (_q70, _q71))
5254 : 0 : std::swap (_q70, _q71);
5255 : 0 : {
5256 : 0 : tree _q70_pops[1];
5257 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
5258 : : {
5259 : 0 : tree _q80 = _q70_pops[0];
5260 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
5261 : : {
5262 : 0 : {
5263 : 0 : tree _q71_pops[1];
5264 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
5265 : : {
5266 : 0 : tree _q100 = _q71_pops[0];
5267 : 0 : switch (TREE_CODE (_q31))
5268 : : {
5269 : 0 : case SSA_NAME:
5270 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
5271 : : {
5272 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
5273 : 0 : switch (gimple_assign_rhs_code (_a5))
5274 : : {
5275 : 0 : case BIT_NOT_EXPR:
5276 : 0 : {
5277 : 0 : tree _q120 = gimple_assign_rhs1 (_a5);
5278 : 0 : _q120 = do_valueize (valueize, _q120);
5279 : 0 : switch (TREE_CODE (_q120))
5280 : : {
5281 : 0 : case SSA_NAME:
5282 : 0 : if (gimple *_d6 = get_def (valueize, _q120))
5283 : : {
5284 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
5285 : 0 : switch (gimple_assign_rhs_code (_a6))
5286 : : {
5287 : 0 : case BIT_XOR_EXPR:
5288 : 0 : {
5289 : 0 : tree _q130 = gimple_assign_rhs1 (_a6);
5290 : 0 : _q130 = do_valueize (valueize, _q130);
5291 : 0 : tree _q131 = gimple_assign_rhs2 (_a6);
5292 : 0 : _q131 = do_valueize (valueize, _q131);
5293 : 0 : if (tree_swap_operands_p (_q130, _q131))
5294 : 0 : std::swap (_q130, _q131);
5295 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
5296 : : {
5297 : 0 : if ((_q131 == _q100 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q100, 0) && types_match (_q131, _q100)))
5298 : : {
5299 : 0 : if (integer_zerop (_q21))
5300 : : {
5301 : 0 : if ((_p1 == _q41 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q41, 0) && types_match (_p1, _q41)))
5302 : : {
5303 : 0 : switch (TREE_CODE (_p2))
5304 : : {
5305 : 0 : case SSA_NAME:
5306 : 0 : if (gimple *_d7 = get_def (valueize, _p2))
5307 : : {
5308 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
5309 : 0 : switch (gimple_assign_rhs_code (_a7))
5310 : : {
5311 : 0 : case BIT_XOR_EXPR:
5312 : 0 : {
5313 : 0 : tree _q180 = gimple_assign_rhs1 (_a7);
5314 : 0 : _q180 = do_valueize (valueize, _q180);
5315 : 0 : tree _q181 = gimple_assign_rhs2 (_a7);
5316 : 0 : _q181 = do_valueize (valueize, _q181);
5317 : 0 : if (tree_swap_operands_p (_q180, _q181))
5318 : 0 : std::swap (_q180, _q181);
5319 : 0 : switch (TREE_CODE (_q180))
5320 : : {
5321 : 0 : case SSA_NAME:
5322 : 0 : if (gimple *_d8 = get_def (valueize, _q180))
5323 : : {
5324 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
5325 : 0 : switch (gimple_assign_rhs_code (_a8))
5326 : : {
5327 : 0 : case NEGATE_EXPR:
5328 : 0 : {
5329 : 0 : tree _q190 = gimple_assign_rhs1 (_a8);
5330 : 0 : _q190 = do_valueize (valueize, _q190);
5331 : 0 : switch (TREE_CODE (_q190))
5332 : : {
5333 : 0 : case SSA_NAME:
5334 : 0 : if (gimple *_d9 = get_def (valueize, _q190))
5335 : : {
5336 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
5337 : 0 : switch (gimple_assign_rhs_code (_a9))
5338 : : {
5339 : 0 : CASE_CONVERT:
5340 : 0 : {
5341 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
5342 : 0 : _q200 = do_valueize (valueize, _q200);
5343 : 0 : switch (TREE_CODE (_q200))
5344 : : {
5345 : 0 : case SSA_NAME:
5346 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
5347 : : {
5348 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
5349 : 0 : switch (gimple_assign_rhs_code (_a10))
5350 : : {
5351 : 0 : case LT_EXPR:
5352 : 0 : {
5353 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
5354 : 0 : _q210 = do_valueize (valueize, _q210);
5355 : 0 : tree _q211 = gimple_assign_rhs2 (_a10);
5356 : 0 : _q211 = do_valueize (valueize, _q211);
5357 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
5358 : : {
5359 : 0 : if (integer_zerop (_q211))
5360 : : {
5361 : 0 : if (gimple_max_value (_q181, valueize))
5362 : : {
5363 : 0 : {
5364 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
5365 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
5366 : : )
5367 : : {
5368 : 0 : {
5369 : 0 : res_ops[0] = captures[0];
5370 : 0 : res_ops[1] = captures[1];
5371 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
5372 : 0 : return true;
5373 : : }
5374 : : }
5375 : : }
5376 : : }
5377 : : }
5378 : : }
5379 : : break;
5380 : : }
5381 : : default:;
5382 : : }
5383 : : }
5384 : : break;
5385 : : default:;
5386 : : }
5387 : : break;
5388 : : }
5389 : : default:;
5390 : : }
5391 : : }
5392 : : break;
5393 : : default:;
5394 : : }
5395 : : break;
5396 : : }
5397 : : default:;
5398 : : }
5399 : : }
5400 : : break;
5401 : 0 : default:;
5402 : : }
5403 : 0 : if (gimple_max_value (_q180, valueize))
5404 : : {
5405 : 0 : switch (TREE_CODE (_q181))
5406 : : {
5407 : 0 : case SSA_NAME:
5408 : 0 : if (gimple *_d8 = get_def (valueize, _q181))
5409 : : {
5410 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
5411 : 0 : switch (gimple_assign_rhs_code (_a8))
5412 : : {
5413 : 0 : case NEGATE_EXPR:
5414 : 0 : {
5415 : 0 : tree _q200 = gimple_assign_rhs1 (_a8);
5416 : 0 : _q200 = do_valueize (valueize, _q200);
5417 : 0 : switch (TREE_CODE (_q200))
5418 : : {
5419 : 0 : case SSA_NAME:
5420 : 0 : if (gimple *_d9 = get_def (valueize, _q200))
5421 : : {
5422 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
5423 : 0 : switch (gimple_assign_rhs_code (_a9))
5424 : : {
5425 : 0 : CASE_CONVERT:
5426 : 0 : {
5427 : 0 : tree _q210 = gimple_assign_rhs1 (_a9);
5428 : 0 : _q210 = do_valueize (valueize, _q210);
5429 : 0 : switch (TREE_CODE (_q210))
5430 : : {
5431 : 0 : case SSA_NAME:
5432 : 0 : if (gimple *_d10 = get_def (valueize, _q210))
5433 : : {
5434 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
5435 : 0 : switch (gimple_assign_rhs_code (_a10))
5436 : : {
5437 : 0 : case LT_EXPR:
5438 : 0 : {
5439 : 0 : tree _q220 = gimple_assign_rhs1 (_a10);
5440 : 0 : _q220 = do_valueize (valueize, _q220);
5441 : 0 : tree _q221 = gimple_assign_rhs2 (_a10);
5442 : 0 : _q221 = do_valueize (valueize, _q221);
5443 : 0 : if ((_q220 == _q40 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q40, 0) && types_match (_q220, _q40)))
5444 : : {
5445 : 0 : if (integer_zerop (_q221))
5446 : : {
5447 : 0 : {
5448 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
5449 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
5450 : : )
5451 : : {
5452 : 0 : {
5453 : 0 : res_ops[0] = captures[0];
5454 : 0 : res_ops[1] = captures[1];
5455 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
5456 : 0 : return true;
5457 : : }
5458 : : }
5459 : : }
5460 : : }
5461 : : }
5462 : : break;
5463 : : }
5464 : : default:;
5465 : : }
5466 : : }
5467 : : break;
5468 : : default:;
5469 : : }
5470 : : break;
5471 : : }
5472 : : default:;
5473 : : }
5474 : : }
5475 : : break;
5476 : : default:;
5477 : : }
5478 : : break;
5479 : : }
5480 : : default:;
5481 : : }
5482 : : }
5483 : : break;
5484 : : default:;
5485 : : }
5486 : : }
5487 : 0 : break;
5488 : : }
5489 : : default:;
5490 : : }
5491 : : }
5492 : : break;
5493 : : default:;
5494 : : }
5495 : : }
5496 : : }
5497 : : }
5498 : : }
5499 : 0 : if ((_q130 == _q100 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q100, 0) && types_match (_q130, _q100)))
5500 : : {
5501 : 0 : if ((_q131 == _q40 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q40, 0) && types_match (_q131, _q40)))
5502 : : {
5503 : 0 : if (integer_zerop (_q21))
5504 : : {
5505 : 0 : if ((_p1 == _q41 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q41, 0) && types_match (_p1, _q41)))
5506 : : {
5507 : 0 : switch (TREE_CODE (_p2))
5508 : : {
5509 : 0 : case SSA_NAME:
5510 : 0 : if (gimple *_d7 = get_def (valueize, _p2))
5511 : : {
5512 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
5513 : 0 : switch (gimple_assign_rhs_code (_a7))
5514 : : {
5515 : 0 : case BIT_XOR_EXPR:
5516 : 0 : {
5517 : 0 : tree _q180 = gimple_assign_rhs1 (_a7);
5518 : 0 : _q180 = do_valueize (valueize, _q180);
5519 : 0 : tree _q181 = gimple_assign_rhs2 (_a7);
5520 : 0 : _q181 = do_valueize (valueize, _q181);
5521 : 0 : if (tree_swap_operands_p (_q180, _q181))
5522 : 0 : std::swap (_q180, _q181);
5523 : 0 : switch (TREE_CODE (_q180))
5524 : : {
5525 : 0 : case SSA_NAME:
5526 : 0 : if (gimple *_d8 = get_def (valueize, _q180))
5527 : : {
5528 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
5529 : 0 : switch (gimple_assign_rhs_code (_a8))
5530 : : {
5531 : 0 : case NEGATE_EXPR:
5532 : 0 : {
5533 : 0 : tree _q190 = gimple_assign_rhs1 (_a8);
5534 : 0 : _q190 = do_valueize (valueize, _q190);
5535 : 0 : switch (TREE_CODE (_q190))
5536 : : {
5537 : 0 : case SSA_NAME:
5538 : 0 : if (gimple *_d9 = get_def (valueize, _q190))
5539 : : {
5540 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
5541 : 0 : switch (gimple_assign_rhs_code (_a9))
5542 : : {
5543 : 0 : CASE_CONVERT:
5544 : 0 : {
5545 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
5546 : 0 : _q200 = do_valueize (valueize, _q200);
5547 : 0 : switch (TREE_CODE (_q200))
5548 : : {
5549 : 0 : case SSA_NAME:
5550 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
5551 : : {
5552 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
5553 : 0 : switch (gimple_assign_rhs_code (_a10))
5554 : : {
5555 : 0 : case LT_EXPR:
5556 : 0 : {
5557 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
5558 : 0 : _q210 = do_valueize (valueize, _q210);
5559 : 0 : tree _q211 = gimple_assign_rhs2 (_a10);
5560 : 0 : _q211 = do_valueize (valueize, _q211);
5561 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
5562 : : {
5563 : 0 : if (integer_zerop (_q211))
5564 : : {
5565 : 0 : if (gimple_max_value (_q181, valueize))
5566 : : {
5567 : 0 : {
5568 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
5569 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
5570 : : )
5571 : : {
5572 : 0 : {
5573 : 0 : res_ops[0] = captures[0];
5574 : 0 : res_ops[1] = captures[1];
5575 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
5576 : 0 : return true;
5577 : : }
5578 : : }
5579 : : }
5580 : : }
5581 : : }
5582 : : }
5583 : : break;
5584 : : }
5585 : : default:;
5586 : : }
5587 : : }
5588 : : break;
5589 : : default:;
5590 : : }
5591 : : break;
5592 : : }
5593 : : default:;
5594 : : }
5595 : : }
5596 : : break;
5597 : : default:;
5598 : : }
5599 : : break;
5600 : : }
5601 : : default:;
5602 : : }
5603 : : }
5604 : : break;
5605 : 0 : default:;
5606 : : }
5607 : 0 : if (gimple_max_value (_q180, valueize))
5608 : : {
5609 : 0 : switch (TREE_CODE (_q181))
5610 : : {
5611 : 0 : case SSA_NAME:
5612 : 0 : if (gimple *_d8 = get_def (valueize, _q181))
5613 : : {
5614 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
5615 : 0 : switch (gimple_assign_rhs_code (_a8))
5616 : : {
5617 : 0 : case NEGATE_EXPR:
5618 : 0 : {
5619 : 0 : tree _q200 = gimple_assign_rhs1 (_a8);
5620 : 0 : _q200 = do_valueize (valueize, _q200);
5621 : 0 : switch (TREE_CODE (_q200))
5622 : : {
5623 : 0 : case SSA_NAME:
5624 : 0 : if (gimple *_d9 = get_def (valueize, _q200))
5625 : : {
5626 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
5627 : 0 : switch (gimple_assign_rhs_code (_a9))
5628 : : {
5629 : 0 : CASE_CONVERT:
5630 : 0 : {
5631 : 0 : tree _q210 = gimple_assign_rhs1 (_a9);
5632 : 0 : _q210 = do_valueize (valueize, _q210);
5633 : 0 : switch (TREE_CODE (_q210))
5634 : : {
5635 : 0 : case SSA_NAME:
5636 : 0 : if (gimple *_d10 = get_def (valueize, _q210))
5637 : : {
5638 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
5639 : 0 : switch (gimple_assign_rhs_code (_a10))
5640 : : {
5641 : 0 : case LT_EXPR:
5642 : 0 : {
5643 : 0 : tree _q220 = gimple_assign_rhs1 (_a10);
5644 : 0 : _q220 = do_valueize (valueize, _q220);
5645 : 0 : tree _q221 = gimple_assign_rhs2 (_a10);
5646 : 0 : _q221 = do_valueize (valueize, _q221);
5647 : 0 : if ((_q220 == _q40 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q40, 0) && types_match (_q220, _q40)))
5648 : : {
5649 : 0 : if (integer_zerop (_q221))
5650 : : {
5651 : 0 : {
5652 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
5653 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
5654 : : )
5655 : : {
5656 : 0 : {
5657 : 0 : res_ops[0] = captures[0];
5658 : 0 : res_ops[1] = captures[1];
5659 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
5660 : 0 : return true;
5661 : : }
5662 : : }
5663 : : }
5664 : : }
5665 : : }
5666 : : break;
5667 : : }
5668 : : default:;
5669 : : }
5670 : : }
5671 : : break;
5672 : : default:;
5673 : : }
5674 : : break;
5675 : : }
5676 : : default:;
5677 : : }
5678 : : }
5679 : : break;
5680 : : default:;
5681 : : }
5682 : : break;
5683 : : }
5684 : : default:;
5685 : : }
5686 : : }
5687 : : break;
5688 : : default:;
5689 : : }
5690 : : }
5691 : 0 : break;
5692 : : }
5693 : : default:;
5694 : : }
5695 : : }
5696 : : break;
5697 : : default:;
5698 : : }
5699 : : }
5700 : : }
5701 : : }
5702 : : }
5703 : 0 : break;
5704 : : }
5705 : : default:;
5706 : : }
5707 : : }
5708 : : break;
5709 : : default:;
5710 : : }
5711 : : break;
5712 : : }
5713 : : default:;
5714 : : }
5715 : : }
5716 : : break;
5717 : : default:;
5718 : : }
5719 : : }
5720 : : }
5721 : : }
5722 : : }
5723 : : }
5724 : 0 : break;
5725 : : }
5726 : : default:;
5727 : : }
5728 : : }
5729 : : break;
5730 : : default:;
5731 : : }
5732 : : }
5733 : : }
5734 : 0 : break;
5735 : : }
5736 : 0 : case BIT_NOT_EXPR:
5737 : 0 : {
5738 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
5739 : 0 : _q40 = do_valueize (valueize, _q40);
5740 : 0 : switch (TREE_CODE (_q40))
5741 : : {
5742 : 0 : case SSA_NAME:
5743 : 0 : if (gimple *_d4 = get_def (valueize, _q40))
5744 : : {
5745 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
5746 : 0 : switch (gimple_assign_rhs_code (_a4))
5747 : : {
5748 : 0 : case BIT_XOR_EXPR:
5749 : 0 : {
5750 : 0 : tree _q50 = gimple_assign_rhs1 (_a4);
5751 : 0 : _q50 = do_valueize (valueize, _q50);
5752 : 0 : tree _q51 = gimple_assign_rhs2 (_a4);
5753 : 0 : _q51 = do_valueize (valueize, _q51);
5754 : 0 : if (tree_swap_operands_p (_q50, _q51))
5755 : 0 : std::swap (_q50, _q51);
5756 : 0 : switch (TREE_CODE (_q31))
5757 : : {
5758 : 0 : case SSA_NAME:
5759 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
5760 : : {
5761 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
5762 : 0 : switch (gimple_assign_rhs_code (_a5))
5763 : : {
5764 : 0 : case BIT_XOR_EXPR:
5765 : 0 : {
5766 : 0 : tree _q80 = gimple_assign_rhs1 (_a5);
5767 : 0 : _q80 = do_valueize (valueize, _q80);
5768 : 0 : tree _q81 = gimple_assign_rhs2 (_a5);
5769 : 0 : _q81 = do_valueize (valueize, _q81);
5770 : 0 : if (tree_swap_operands_p (_q80, _q81))
5771 : 0 : std::swap (_q80, _q81);
5772 : 0 : if ((_q80 == _q50 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q50, 0) && types_match (_q80, _q50)))
5773 : : {
5774 : 0 : {
5775 : 0 : tree _q81_pops[1];
5776 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
5777 : : {
5778 : 0 : tree _q100 = _q81_pops[0];
5779 : 0 : switch (TREE_CODE (_q100))
5780 : : {
5781 : 0 : case SSA_NAME:
5782 : 0 : if (gimple *_d6 = get_def (valueize, _q100))
5783 : : {
5784 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
5785 : 0 : switch (gimple_assign_rhs_code (_a6))
5786 : : {
5787 : 0 : case PLUS_EXPR:
5788 : 0 : {
5789 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
5790 : 0 : _q110 = do_valueize (valueize, _q110);
5791 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
5792 : 0 : _q111 = do_valueize (valueize, _q111);
5793 : 0 : if (tree_swap_operands_p (_q110, _q111))
5794 : 0 : std::swap (_q110, _q111);
5795 : 0 : {
5796 : 0 : tree _q110_pops[1];
5797 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
5798 : : {
5799 : 0 : tree _q120 = _q110_pops[0];
5800 : 0 : if ((_q120 == _q50 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q50, 0) && types_match (_q120, _q50)))
5801 : : {
5802 : 0 : {
5803 : 0 : tree _q111_pops[1];
5804 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
5805 : : {
5806 : 0 : tree _q140 = _q111_pops[0];
5807 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
5808 : : {
5809 : 0 : if (integer_zerop (_q21))
5810 : : {
5811 : 0 : if ((_p1 == _q81 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q81, 0) && types_match (_p1, _q81)))
5812 : : {
5813 : 0 : switch (TREE_CODE (_p2))
5814 : : {
5815 : 0 : case SSA_NAME:
5816 : 0 : if (gimple *_d7 = get_def (valueize, _p2))
5817 : : {
5818 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
5819 : 0 : switch (gimple_assign_rhs_code (_a7))
5820 : : {
5821 : 0 : case BIT_XOR_EXPR:
5822 : 0 : {
5823 : 0 : tree _q180 = gimple_assign_rhs1 (_a7);
5824 : 0 : _q180 = do_valueize (valueize, _q180);
5825 : 0 : tree _q181 = gimple_assign_rhs2 (_a7);
5826 : 0 : _q181 = do_valueize (valueize, _q181);
5827 : 0 : if (tree_swap_operands_p (_q180, _q181))
5828 : 0 : std::swap (_q180, _q181);
5829 : 0 : switch (TREE_CODE (_q180))
5830 : : {
5831 : 0 : case SSA_NAME:
5832 : 0 : if (gimple *_d8 = get_def (valueize, _q180))
5833 : : {
5834 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
5835 : 0 : switch (gimple_assign_rhs_code (_a8))
5836 : : {
5837 : 0 : case NEGATE_EXPR:
5838 : 0 : {
5839 : 0 : tree _q190 = gimple_assign_rhs1 (_a8);
5840 : 0 : _q190 = do_valueize (valueize, _q190);
5841 : 0 : switch (TREE_CODE (_q190))
5842 : : {
5843 : 0 : case SSA_NAME:
5844 : 0 : if (gimple *_d9 = get_def (valueize, _q190))
5845 : : {
5846 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
5847 : 0 : switch (gimple_assign_rhs_code (_a9))
5848 : : {
5849 : 0 : CASE_CONVERT:
5850 : 0 : {
5851 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
5852 : 0 : _q200 = do_valueize (valueize, _q200);
5853 : 0 : switch (TREE_CODE (_q200))
5854 : : {
5855 : 0 : case SSA_NAME:
5856 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
5857 : : {
5858 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
5859 : 0 : switch (gimple_assign_rhs_code (_a10))
5860 : : {
5861 : 0 : case LT_EXPR:
5862 : 0 : {
5863 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
5864 : 0 : _q210 = do_valueize (valueize, _q210);
5865 : 0 : tree _q211 = gimple_assign_rhs2 (_a10);
5866 : 0 : _q211 = do_valueize (valueize, _q211);
5867 : 0 : if ((_q210 == _q50 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q50, 0) && types_match (_q210, _q50)))
5868 : : {
5869 : 0 : if (integer_zerop (_q211))
5870 : : {
5871 : 0 : if (gimple_max_value (_q181, valueize))
5872 : : {
5873 : 0 : {
5874 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
5875 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
5876 : : )
5877 : : {
5878 : 0 : {
5879 : 0 : res_ops[0] = captures[0];
5880 : 0 : res_ops[1] = captures[1];
5881 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
5882 : 0 : return true;
5883 : : }
5884 : : }
5885 : : }
5886 : : }
5887 : : }
5888 : : }
5889 : : break;
5890 : : }
5891 : : default:;
5892 : : }
5893 : : }
5894 : : break;
5895 : : default:;
5896 : : }
5897 : : break;
5898 : : }
5899 : : default:;
5900 : : }
5901 : : }
5902 : : break;
5903 : : default:;
5904 : : }
5905 : : break;
5906 : : }
5907 : : default:;
5908 : : }
5909 : : }
5910 : : break;
5911 : 0 : default:;
5912 : : }
5913 : 0 : if (gimple_max_value (_q180, valueize))
5914 : : {
5915 : 0 : switch (TREE_CODE (_q181))
5916 : : {
5917 : 0 : case SSA_NAME:
5918 : 0 : if (gimple *_d8 = get_def (valueize, _q181))
5919 : : {
5920 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
5921 : 0 : switch (gimple_assign_rhs_code (_a8))
5922 : : {
5923 : 0 : case NEGATE_EXPR:
5924 : 0 : {
5925 : 0 : tree _q200 = gimple_assign_rhs1 (_a8);
5926 : 0 : _q200 = do_valueize (valueize, _q200);
5927 : 0 : switch (TREE_CODE (_q200))
5928 : : {
5929 : 0 : case SSA_NAME:
5930 : 0 : if (gimple *_d9 = get_def (valueize, _q200))
5931 : : {
5932 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
5933 : 0 : switch (gimple_assign_rhs_code (_a9))
5934 : : {
5935 : 0 : CASE_CONVERT:
5936 : 0 : {
5937 : 0 : tree _q210 = gimple_assign_rhs1 (_a9);
5938 : 0 : _q210 = do_valueize (valueize, _q210);
5939 : 0 : switch (TREE_CODE (_q210))
5940 : : {
5941 : 0 : case SSA_NAME:
5942 : 0 : if (gimple *_d10 = get_def (valueize, _q210))
5943 : : {
5944 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
5945 : 0 : switch (gimple_assign_rhs_code (_a10))
5946 : : {
5947 : 0 : case LT_EXPR:
5948 : 0 : {
5949 : 0 : tree _q220 = gimple_assign_rhs1 (_a10);
5950 : 0 : _q220 = do_valueize (valueize, _q220);
5951 : 0 : tree _q221 = gimple_assign_rhs2 (_a10);
5952 : 0 : _q221 = do_valueize (valueize, _q221);
5953 : 0 : if ((_q220 == _q50 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q50, 0) && types_match (_q220, _q50)))
5954 : : {
5955 : 0 : if (integer_zerop (_q221))
5956 : : {
5957 : 0 : {
5958 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
5959 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
5960 : : )
5961 : : {
5962 : 0 : {
5963 : 0 : res_ops[0] = captures[0];
5964 : 0 : res_ops[1] = captures[1];
5965 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
5966 : 0 : return true;
5967 : : }
5968 : : }
5969 : : }
5970 : : }
5971 : : }
5972 : : break;
5973 : : }
5974 : : default:;
5975 : : }
5976 : : }
5977 : : break;
5978 : : default:;
5979 : : }
5980 : : break;
5981 : : }
5982 : : default:;
5983 : : }
5984 : : }
5985 : : break;
5986 : : default:;
5987 : : }
5988 : : break;
5989 : : }
5990 : : default:;
5991 : : }
5992 : : }
5993 : : break;
5994 : : default:;
5995 : : }
5996 : : }
5997 : 0 : break;
5998 : : }
5999 : : default:;
6000 : : }
6001 : : }
6002 : : break;
6003 : : default:;
6004 : : }
6005 : : }
6006 : : }
6007 : : }
6008 : : }
6009 : : }
6010 : : }
6011 : : }
6012 : : }
6013 : 0 : break;
6014 : : }
6015 : : default:;
6016 : : }
6017 : : }
6018 : : break;
6019 : : default:;
6020 : : }
6021 : : }
6022 : : }
6023 : : }
6024 : 0 : if ((_q80 == _q51 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q51, 0) && types_match (_q80, _q51)))
6025 : : {
6026 : 0 : {
6027 : 0 : tree _q81_pops[1];
6028 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
6029 : : {
6030 : 0 : tree _q100 = _q81_pops[0];
6031 : 0 : switch (TREE_CODE (_q100))
6032 : : {
6033 : 0 : case SSA_NAME:
6034 : 0 : if (gimple *_d6 = get_def (valueize, _q100))
6035 : : {
6036 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
6037 : 0 : switch (gimple_assign_rhs_code (_a6))
6038 : : {
6039 : 0 : case PLUS_EXPR:
6040 : 0 : {
6041 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
6042 : 0 : _q110 = do_valueize (valueize, _q110);
6043 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
6044 : 0 : _q111 = do_valueize (valueize, _q111);
6045 : 0 : if (tree_swap_operands_p (_q110, _q111))
6046 : 0 : std::swap (_q110, _q111);
6047 : 0 : {
6048 : 0 : tree _q110_pops[1];
6049 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
6050 : : {
6051 : 0 : tree _q120 = _q110_pops[0];
6052 : 0 : if ((_q120 == _q51 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q51, 0) && types_match (_q120, _q51)))
6053 : : {
6054 : 0 : {
6055 : 0 : tree _q111_pops[1];
6056 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
6057 : : {
6058 : 0 : tree _q140 = _q111_pops[0];
6059 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
6060 : : {
6061 : 0 : if (integer_zerop (_q21))
6062 : : {
6063 : 0 : if ((_p1 == _q81 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q81, 0) && types_match (_p1, _q81)))
6064 : : {
6065 : 0 : switch (TREE_CODE (_p2))
6066 : : {
6067 : 0 : case SSA_NAME:
6068 : 0 : if (gimple *_d7 = get_def (valueize, _p2))
6069 : : {
6070 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
6071 : 0 : switch (gimple_assign_rhs_code (_a7))
6072 : : {
6073 : 0 : case BIT_XOR_EXPR:
6074 : 0 : {
6075 : 0 : tree _q180 = gimple_assign_rhs1 (_a7);
6076 : 0 : _q180 = do_valueize (valueize, _q180);
6077 : 0 : tree _q181 = gimple_assign_rhs2 (_a7);
6078 : 0 : _q181 = do_valueize (valueize, _q181);
6079 : 0 : if (tree_swap_operands_p (_q180, _q181))
6080 : 0 : std::swap (_q180, _q181);
6081 : 0 : switch (TREE_CODE (_q180))
6082 : : {
6083 : 0 : case SSA_NAME:
6084 : 0 : if (gimple *_d8 = get_def (valueize, _q180))
6085 : : {
6086 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
6087 : 0 : switch (gimple_assign_rhs_code (_a8))
6088 : : {
6089 : 0 : case NEGATE_EXPR:
6090 : 0 : {
6091 : 0 : tree _q190 = gimple_assign_rhs1 (_a8);
6092 : 0 : _q190 = do_valueize (valueize, _q190);
6093 : 0 : switch (TREE_CODE (_q190))
6094 : : {
6095 : 0 : case SSA_NAME:
6096 : 0 : if (gimple *_d9 = get_def (valueize, _q190))
6097 : : {
6098 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
6099 : 0 : switch (gimple_assign_rhs_code (_a9))
6100 : : {
6101 : 0 : CASE_CONVERT:
6102 : 0 : {
6103 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
6104 : 0 : _q200 = do_valueize (valueize, _q200);
6105 : 0 : switch (TREE_CODE (_q200))
6106 : : {
6107 : 0 : case SSA_NAME:
6108 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
6109 : : {
6110 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
6111 : 0 : switch (gimple_assign_rhs_code (_a10))
6112 : : {
6113 : 0 : case LT_EXPR:
6114 : 0 : {
6115 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
6116 : 0 : _q210 = do_valueize (valueize, _q210);
6117 : 0 : tree _q211 = gimple_assign_rhs2 (_a10);
6118 : 0 : _q211 = do_valueize (valueize, _q211);
6119 : 0 : if ((_q210 == _q51 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q51, 0) && types_match (_q210, _q51)))
6120 : : {
6121 : 0 : if (integer_zerop (_q211))
6122 : : {
6123 : 0 : if (gimple_max_value (_q181, valueize))
6124 : : {
6125 : 0 : {
6126 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
6127 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
6128 : : )
6129 : : {
6130 : 0 : {
6131 : 0 : res_ops[0] = captures[0];
6132 : 0 : res_ops[1] = captures[1];
6133 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
6134 : 0 : return true;
6135 : : }
6136 : : }
6137 : : }
6138 : : }
6139 : : }
6140 : : }
6141 : : break;
6142 : : }
6143 : : default:;
6144 : : }
6145 : : }
6146 : : break;
6147 : : default:;
6148 : : }
6149 : : break;
6150 : : }
6151 : : default:;
6152 : : }
6153 : : }
6154 : : break;
6155 : : default:;
6156 : : }
6157 : : break;
6158 : : }
6159 : : default:;
6160 : : }
6161 : : }
6162 : : break;
6163 : 0 : default:;
6164 : : }
6165 : 0 : if (gimple_max_value (_q180, valueize))
6166 : : {
6167 : 0 : switch (TREE_CODE (_q181))
6168 : : {
6169 : 0 : case SSA_NAME:
6170 : 0 : if (gimple *_d8 = get_def (valueize, _q181))
6171 : : {
6172 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
6173 : 0 : switch (gimple_assign_rhs_code (_a8))
6174 : : {
6175 : 0 : case NEGATE_EXPR:
6176 : 0 : {
6177 : 0 : tree _q200 = gimple_assign_rhs1 (_a8);
6178 : 0 : _q200 = do_valueize (valueize, _q200);
6179 : 0 : switch (TREE_CODE (_q200))
6180 : : {
6181 : 0 : case SSA_NAME:
6182 : 0 : if (gimple *_d9 = get_def (valueize, _q200))
6183 : : {
6184 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
6185 : 0 : switch (gimple_assign_rhs_code (_a9))
6186 : : {
6187 : 0 : CASE_CONVERT:
6188 : 0 : {
6189 : 0 : tree _q210 = gimple_assign_rhs1 (_a9);
6190 : 0 : _q210 = do_valueize (valueize, _q210);
6191 : 0 : switch (TREE_CODE (_q210))
6192 : : {
6193 : 0 : case SSA_NAME:
6194 : 0 : if (gimple *_d10 = get_def (valueize, _q210))
6195 : : {
6196 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
6197 : 0 : switch (gimple_assign_rhs_code (_a10))
6198 : : {
6199 : 0 : case LT_EXPR:
6200 : 0 : {
6201 : 0 : tree _q220 = gimple_assign_rhs1 (_a10);
6202 : 0 : _q220 = do_valueize (valueize, _q220);
6203 : 0 : tree _q221 = gimple_assign_rhs2 (_a10);
6204 : 0 : _q221 = do_valueize (valueize, _q221);
6205 : 0 : if ((_q220 == _q51 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q51, 0) && types_match (_q220, _q51)))
6206 : : {
6207 : 0 : if (integer_zerop (_q221))
6208 : : {
6209 : 0 : {
6210 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
6211 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
6212 : : )
6213 : : {
6214 : 0 : {
6215 : 0 : res_ops[0] = captures[0];
6216 : 0 : res_ops[1] = captures[1];
6217 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
6218 : 0 : return true;
6219 : : }
6220 : : }
6221 : : }
6222 : : }
6223 : : }
6224 : : break;
6225 : : }
6226 : : default:;
6227 : : }
6228 : : }
6229 : : break;
6230 : : default:;
6231 : : }
6232 : : break;
6233 : : }
6234 : : default:;
6235 : : }
6236 : : }
6237 : : break;
6238 : : default:;
6239 : : }
6240 : : break;
6241 : : }
6242 : : default:;
6243 : : }
6244 : : }
6245 : : break;
6246 : : default:;
6247 : : }
6248 : : }
6249 : 0 : break;
6250 : : }
6251 : : default:;
6252 : : }
6253 : : }
6254 : : break;
6255 : : default:;
6256 : : }
6257 : : }
6258 : : }
6259 : : }
6260 : : }
6261 : : }
6262 : : }
6263 : : }
6264 : : }
6265 : 0 : break;
6266 : : }
6267 : : default:;
6268 : : }
6269 : : }
6270 : : break;
6271 : : default:;
6272 : : }
6273 : : }
6274 : : }
6275 : : }
6276 : 22317700 : break;
6277 : : }
6278 : : default:;
6279 : : }
6280 : : }
6281 : : break;
6282 : : default:;
6283 : : }
6284 : 22317700 : break;
6285 : : }
6286 : : default:;
6287 : : }
6288 : : }
6289 : : break;
6290 : : default:;
6291 : : }
6292 : : break;
6293 : : }
6294 : : default:;
6295 : : }
6296 : : }
6297 : : break;
6298 : : default:;
6299 : : }
6300 : 22317700 : break;
6301 : : }
6302 : : default:;
6303 : : }
6304 : : }
6305 : : break;
6306 : : default:;
6307 : : }
6308 : : }
6309 : : }
6310 : : break;
6311 : : }
6312 : 0 : case BIT_AND_EXPR:
6313 : 0 : {
6314 : 0 : tree _q20 = TREE_OPERAND (_p0, 0);
6315 : 0 : if ((TREE_CODE (_q20) == SSA_NAME
6316 : 0 : || is_gimple_min_invariant (_q20)))
6317 : : {
6318 : 0 : _q20 = do_valueize (valueize, _q20);
6319 : 0 : tree _q21 = TREE_OPERAND (_p0, 1);
6320 : 0 : if ((TREE_CODE (_q21) == SSA_NAME
6321 : 0 : || is_gimple_min_invariant (_q21)))
6322 : : {
6323 : 0 : _q21 = do_valueize (valueize, _q21);
6324 : 0 : if (tree_swap_operands_p (_q20, _q21))
6325 : 0 : std::swap (_q20, _q21);
6326 : 0 : switch (TREE_CODE (_q20))
6327 : : {
6328 : 0 : case SSA_NAME:
6329 : 0 : if (gimple *_d2 = get_def (valueize, _q20))
6330 : : {
6331 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
6332 : 0 : switch (gimple_assign_rhs_code (_a2))
6333 : : {
6334 : 0 : case LT_EXPR:
6335 : 0 : {
6336 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
6337 : 0 : _q30 = do_valueize (valueize, _q30);
6338 : 0 : tree _q31 = gimple_assign_rhs2 (_a2);
6339 : 0 : _q31 = do_valueize (valueize, _q31);
6340 : 0 : switch (TREE_CODE (_q30))
6341 : : {
6342 : 0 : case SSA_NAME:
6343 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
6344 : : {
6345 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
6346 : 0 : switch (gimple_assign_rhs_code (_a3))
6347 : : {
6348 : 0 : case BIT_XOR_EXPR:
6349 : 0 : {
6350 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
6351 : 0 : _q40 = do_valueize (valueize, _q40);
6352 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
6353 : 0 : _q41 = do_valueize (valueize, _q41);
6354 : 0 : if (tree_swap_operands_p (_q40, _q41))
6355 : 0 : std::swap (_q40, _q41);
6356 : 0 : {
6357 : 0 : tree _q41_pops[1];
6358 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
6359 : : {
6360 : 0 : tree _q60 = _q41_pops[0];
6361 : 0 : switch (TREE_CODE (_q60))
6362 : : {
6363 : 0 : case SSA_NAME:
6364 : 0 : if (gimple *_d4 = get_def (valueize, _q60))
6365 : : {
6366 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
6367 : 0 : switch (gimple_assign_rhs_code (_a4))
6368 : : {
6369 : 0 : case PLUS_EXPR:
6370 : 0 : {
6371 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
6372 : 0 : _q70 = do_valueize (valueize, _q70);
6373 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
6374 : 0 : _q71 = do_valueize (valueize, _q71);
6375 : 0 : if (tree_swap_operands_p (_q70, _q71))
6376 : 0 : std::swap (_q70, _q71);
6377 : 0 : {
6378 : 0 : tree _q70_pops[1];
6379 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
6380 : : {
6381 : 0 : tree _q80 = _q70_pops[0];
6382 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
6383 : : {
6384 : 0 : {
6385 : 0 : tree _q71_pops[1];
6386 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
6387 : : {
6388 : 0 : tree _q100 = _q71_pops[0];
6389 : 0 : if (integer_zerop (_q31))
6390 : : {
6391 : 0 : switch (TREE_CODE (_q21))
6392 : : {
6393 : 0 : case SSA_NAME:
6394 : 0 : if (gimple *_d5 = get_def (valueize, _q21))
6395 : : {
6396 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
6397 : 0 : switch (gimple_assign_rhs_code (_a5))
6398 : : {
6399 : 0 : case GE_EXPR:
6400 : 0 : {
6401 : 0 : tree _q130 = gimple_assign_rhs1 (_a5);
6402 : 0 : _q130 = do_valueize (valueize, _q130);
6403 : 0 : tree _q131 = gimple_assign_rhs2 (_a5);
6404 : 0 : _q131 = do_valueize (valueize, _q131);
6405 : 0 : switch (TREE_CODE (_q130))
6406 : : {
6407 : 0 : case SSA_NAME:
6408 : 0 : if (gimple *_d6 = get_def (valueize, _q130))
6409 : : {
6410 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
6411 : 0 : switch (gimple_assign_rhs_code (_a6))
6412 : : {
6413 : 0 : case BIT_XOR_EXPR:
6414 : 0 : {
6415 : 0 : tree _q140 = gimple_assign_rhs1 (_a6);
6416 : 0 : _q140 = do_valueize (valueize, _q140);
6417 : 0 : tree _q141 = gimple_assign_rhs2 (_a6);
6418 : 0 : _q141 = do_valueize (valueize, _q141);
6419 : 0 : if (tree_swap_operands_p (_q140, _q141))
6420 : 0 : std::swap (_q140, _q141);
6421 : 0 : if ((_q140 == _q40 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q40, 0) && types_match (_q140, _q40)))
6422 : : {
6423 : 0 : if ((_q141 == _q100 && ! TREE_SIDE_EFFECTS (_q141)) || (operand_equal_p (_q141, _q100, 0) && types_match (_q141, _q100)))
6424 : : {
6425 : 0 : if (integer_zerop (_q131))
6426 : : {
6427 : 0 : {
6428 : 0 : tree _p1_pops[1];
6429 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
6430 : : {
6431 : 0 : tree _q180 = _p1_pops[0];
6432 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
6433 : : {
6434 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
6435 : : {
6436 : 0 : {
6437 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
6438 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
6439 : : )
6440 : : {
6441 : 0 : {
6442 : 0 : res_ops[0] = captures[0];
6443 : 0 : res_ops[1] = captures[1];
6444 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
6445 : 0 : return true;
6446 : : }
6447 : : }
6448 : : }
6449 : : }
6450 : : }
6451 : : }
6452 : : }
6453 : : }
6454 : : }
6455 : : }
6456 : 0 : if ((_q140 == _q100 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q100, 0) && types_match (_q140, _q100)))
6457 : : {
6458 : 0 : if ((_q141 == _q40 && ! TREE_SIDE_EFFECTS (_q141)) || (operand_equal_p (_q141, _q40, 0) && types_match (_q141, _q40)))
6459 : : {
6460 : 0 : if (integer_zerop (_q131))
6461 : : {
6462 : 0 : {
6463 : 0 : tree _p1_pops[1];
6464 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
6465 : : {
6466 : 0 : tree _q180 = _p1_pops[0];
6467 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
6468 : : {
6469 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
6470 : : {
6471 : 0 : {
6472 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
6473 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
6474 : : )
6475 : : {
6476 : 0 : {
6477 : 0 : res_ops[0] = captures[0];
6478 : 0 : res_ops[1] = captures[1];
6479 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
6480 : 0 : return true;
6481 : : }
6482 : : }
6483 : : }
6484 : : }
6485 : : }
6486 : : }
6487 : : }
6488 : : }
6489 : : }
6490 : : }
6491 : 0 : break;
6492 : : }
6493 : : default:;
6494 : : }
6495 : : }
6496 : : break;
6497 : : default:;
6498 : : }
6499 : : break;
6500 : : }
6501 : 0 : case BIT_NOT_EXPR:
6502 : 0 : {
6503 : 0 : tree _q130 = gimple_assign_rhs1 (_a5);
6504 : 0 : _q130 = do_valueize (valueize, _q130);
6505 : 0 : switch (TREE_CODE (_q130))
6506 : : {
6507 : 0 : case SSA_NAME:
6508 : 0 : if (gimple *_d6 = get_def (valueize, _q130))
6509 : : {
6510 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
6511 : 0 : switch (gimple_assign_rhs_code (_a6))
6512 : : {
6513 : 0 : case LT_EXPR:
6514 : 0 : {
6515 : 0 : tree _q140 = gimple_assign_rhs1 (_a6);
6516 : 0 : _q140 = do_valueize (valueize, _q140);
6517 : 0 : tree _q141 = gimple_assign_rhs2 (_a6);
6518 : 0 : _q141 = do_valueize (valueize, _q141);
6519 : 0 : switch (TREE_CODE (_q140))
6520 : : {
6521 : 0 : case SSA_NAME:
6522 : 0 : if (gimple *_d7 = get_def (valueize, _q140))
6523 : : {
6524 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
6525 : 0 : switch (gimple_assign_rhs_code (_a7))
6526 : : {
6527 : 0 : case BIT_XOR_EXPR:
6528 : 0 : {
6529 : 0 : tree _q150 = gimple_assign_rhs1 (_a7);
6530 : 0 : _q150 = do_valueize (valueize, _q150);
6531 : 0 : tree _q151 = gimple_assign_rhs2 (_a7);
6532 : 0 : _q151 = do_valueize (valueize, _q151);
6533 : 0 : if (tree_swap_operands_p (_q150, _q151))
6534 : 0 : std::swap (_q150, _q151);
6535 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
6536 : : {
6537 : 0 : if ((_q151 == _q100 && ! TREE_SIDE_EFFECTS (_q151)) || (operand_equal_p (_q151, _q100, 0) && types_match (_q151, _q100)))
6538 : : {
6539 : 0 : if (integer_zerop (_q141))
6540 : : {
6541 : 0 : {
6542 : 0 : tree _p1_pops[1];
6543 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
6544 : : {
6545 : 0 : tree _q190 = _p1_pops[0];
6546 : 0 : if ((_q190 == _q40 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q40, 0) && types_match (_q190, _q40)))
6547 : : {
6548 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
6549 : : {
6550 : 0 : {
6551 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
6552 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
6553 : : )
6554 : : {
6555 : 0 : {
6556 : 0 : res_ops[0] = captures[0];
6557 : 0 : res_ops[1] = captures[1];
6558 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
6559 : 0 : return true;
6560 : : }
6561 : : }
6562 : : }
6563 : : }
6564 : : }
6565 : : }
6566 : : }
6567 : : }
6568 : : }
6569 : : }
6570 : 0 : if ((_q150 == _q100 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q100, 0) && types_match (_q150, _q100)))
6571 : : {
6572 : 0 : if ((_q151 == _q40 && ! TREE_SIDE_EFFECTS (_q151)) || (operand_equal_p (_q151, _q40, 0) && types_match (_q151, _q40)))
6573 : : {
6574 : 0 : if (integer_zerop (_q141))
6575 : : {
6576 : 0 : {
6577 : 0 : tree _p1_pops[1];
6578 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
6579 : : {
6580 : 0 : tree _q190 = _p1_pops[0];
6581 : 0 : if ((_q190 == _q40 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q40, 0) && types_match (_q190, _q40)))
6582 : : {
6583 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
6584 : : {
6585 : 0 : {
6586 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
6587 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
6588 : : )
6589 : : {
6590 : 0 : {
6591 : 0 : res_ops[0] = captures[0];
6592 : 0 : res_ops[1] = captures[1];
6593 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
6594 : 0 : return true;
6595 : : }
6596 : : }
6597 : : }
6598 : : }
6599 : : }
6600 : : }
6601 : : }
6602 : : }
6603 : : }
6604 : : }
6605 : 0 : break;
6606 : : }
6607 : : default:;
6608 : : }
6609 : : }
6610 : : break;
6611 : : default:;
6612 : : }
6613 : : break;
6614 : : }
6615 : : default:;
6616 : : }
6617 : : }
6618 : : break;
6619 : : default:;
6620 : : }
6621 : : break;
6622 : : }
6623 : : default:;
6624 : : }
6625 : : }
6626 : : break;
6627 : : default:;
6628 : : }
6629 : : }
6630 : : }
6631 : : }
6632 : : }
6633 : : }
6634 : : }
6635 : 0 : break;
6636 : : }
6637 : : default:;
6638 : : }
6639 : : }
6640 : : break;
6641 : : default:;
6642 : : }
6643 : : }
6644 : : }
6645 : 0 : break;
6646 : : }
6647 : : default:;
6648 : : }
6649 : : }
6650 : : break;
6651 : : default:;
6652 : : }
6653 : : break;
6654 : : }
6655 : 0 : case GE_EXPR:
6656 : 0 : {
6657 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
6658 : 0 : _q30 = do_valueize (valueize, _q30);
6659 : 0 : tree _q31 = gimple_assign_rhs2 (_a2);
6660 : 0 : _q31 = do_valueize (valueize, _q31);
6661 : 0 : switch (TREE_CODE (_q30))
6662 : : {
6663 : 0 : case SSA_NAME:
6664 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
6665 : : {
6666 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
6667 : 0 : switch (gimple_assign_rhs_code (_a3))
6668 : : {
6669 : 0 : case BIT_XOR_EXPR:
6670 : 0 : {
6671 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
6672 : 0 : _q40 = do_valueize (valueize, _q40);
6673 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
6674 : 0 : _q41 = do_valueize (valueize, _q41);
6675 : 0 : if (tree_swap_operands_p (_q40, _q41))
6676 : 0 : std::swap (_q40, _q41);
6677 : 0 : if (integer_zerop (_q31))
6678 : : {
6679 : 0 : switch (TREE_CODE (_q21))
6680 : : {
6681 : 0 : case SSA_NAME:
6682 : 0 : if (gimple *_d4 = get_def (valueize, _q21))
6683 : : {
6684 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
6685 : 0 : switch (gimple_assign_rhs_code (_a4))
6686 : : {
6687 : 0 : case LT_EXPR:
6688 : 0 : {
6689 : 0 : tree _q80 = gimple_assign_rhs1 (_a4);
6690 : 0 : _q80 = do_valueize (valueize, _q80);
6691 : 0 : tree _q81 = gimple_assign_rhs2 (_a4);
6692 : 0 : _q81 = do_valueize (valueize, _q81);
6693 : 0 : switch (TREE_CODE (_q80))
6694 : : {
6695 : 0 : case SSA_NAME:
6696 : 0 : if (gimple *_d5 = get_def (valueize, _q80))
6697 : : {
6698 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
6699 : 0 : switch (gimple_assign_rhs_code (_a5))
6700 : : {
6701 : 0 : case BIT_XOR_EXPR:
6702 : 0 : {
6703 : 0 : tree _q90 = gimple_assign_rhs1 (_a5);
6704 : 0 : _q90 = do_valueize (valueize, _q90);
6705 : 0 : tree _q91 = gimple_assign_rhs2 (_a5);
6706 : 0 : _q91 = do_valueize (valueize, _q91);
6707 : 0 : if (tree_swap_operands_p (_q90, _q91))
6708 : 0 : std::swap (_q90, _q91);
6709 : 0 : if ((_q90 == _q40 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q40, 0) && types_match (_q90, _q40)))
6710 : : {
6711 : 0 : {
6712 : 0 : tree _q91_pops[1];
6713 : 0 : if (gimple_nop_convert (_q91, _q91_pops, valueize))
6714 : : {
6715 : 0 : tree _q110 = _q91_pops[0];
6716 : 0 : switch (TREE_CODE (_q110))
6717 : : {
6718 : 0 : case SSA_NAME:
6719 : 0 : if (gimple *_d6 = get_def (valueize, _q110))
6720 : : {
6721 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
6722 : 0 : switch (gimple_assign_rhs_code (_a6))
6723 : : {
6724 : 0 : case PLUS_EXPR:
6725 : 0 : {
6726 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
6727 : 0 : _q120 = do_valueize (valueize, _q120);
6728 : 0 : tree _q121 = gimple_assign_rhs2 (_a6);
6729 : 0 : _q121 = do_valueize (valueize, _q121);
6730 : 0 : if (tree_swap_operands_p (_q120, _q121))
6731 : 0 : std::swap (_q120, _q121);
6732 : 0 : {
6733 : 0 : tree _q120_pops[1];
6734 : 0 : if (gimple_nop_convert (_q120, _q120_pops, valueize))
6735 : : {
6736 : 0 : tree _q130 = _q120_pops[0];
6737 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
6738 : : {
6739 : 0 : {
6740 : 0 : tree _q121_pops[1];
6741 : 0 : if (gimple_nop_convert (_q121, _q121_pops, valueize))
6742 : : {
6743 : 0 : tree _q150 = _q121_pops[0];
6744 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
6745 : : {
6746 : 0 : if (integer_zerop (_q81))
6747 : : {
6748 : 0 : {
6749 : 0 : tree _p1_pops[1];
6750 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
6751 : : {
6752 : 0 : tree _q180 = _p1_pops[0];
6753 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
6754 : : {
6755 : 0 : if ((_p2 == _q91 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q91, 0) && types_match (_p2, _q91)))
6756 : : {
6757 : 0 : {
6758 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q41, _q91 };
6759 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
6760 : : )
6761 : : {
6762 : 0 : {
6763 : 0 : res_ops[0] = captures[0];
6764 : 0 : res_ops[1] = captures[1];
6765 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
6766 : 0 : return true;
6767 : : }
6768 : : }
6769 : : }
6770 : : }
6771 : : }
6772 : : }
6773 : : }
6774 : : }
6775 : : }
6776 : : }
6777 : : }
6778 : : }
6779 : : }
6780 : : }
6781 : 0 : break;
6782 : : }
6783 : : default:;
6784 : : }
6785 : : }
6786 : : break;
6787 : : default:;
6788 : : }
6789 : : }
6790 : : }
6791 : : }
6792 : 0 : if ((_q90 == _q41 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q41, 0) && types_match (_q90, _q41)))
6793 : : {
6794 : 0 : {
6795 : 0 : tree _q91_pops[1];
6796 : 0 : if (gimple_nop_convert (_q91, _q91_pops, valueize))
6797 : : {
6798 : 0 : tree _q110 = _q91_pops[0];
6799 : 0 : switch (TREE_CODE (_q110))
6800 : : {
6801 : 0 : case SSA_NAME:
6802 : 0 : if (gimple *_d6 = get_def (valueize, _q110))
6803 : : {
6804 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
6805 : 0 : switch (gimple_assign_rhs_code (_a6))
6806 : : {
6807 : 0 : case PLUS_EXPR:
6808 : 0 : {
6809 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
6810 : 0 : _q120 = do_valueize (valueize, _q120);
6811 : 0 : tree _q121 = gimple_assign_rhs2 (_a6);
6812 : 0 : _q121 = do_valueize (valueize, _q121);
6813 : 0 : if (tree_swap_operands_p (_q120, _q121))
6814 : 0 : std::swap (_q120, _q121);
6815 : 0 : {
6816 : 0 : tree _q120_pops[1];
6817 : 0 : if (gimple_nop_convert (_q120, _q120_pops, valueize))
6818 : : {
6819 : 0 : tree _q130 = _q120_pops[0];
6820 : 0 : if ((_q130 == _q41 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q41, 0) && types_match (_q130, _q41)))
6821 : : {
6822 : 0 : {
6823 : 0 : tree _q121_pops[1];
6824 : 0 : if (gimple_nop_convert (_q121, _q121_pops, valueize))
6825 : : {
6826 : 0 : tree _q150 = _q121_pops[0];
6827 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
6828 : : {
6829 : 0 : if (integer_zerop (_q81))
6830 : : {
6831 : 0 : {
6832 : 0 : tree _p1_pops[1];
6833 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
6834 : : {
6835 : 0 : tree _q180 = _p1_pops[0];
6836 : 0 : if ((_q180 == _q41 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q41, 0) && types_match (_q180, _q41)))
6837 : : {
6838 : 0 : if ((_p2 == _q91 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q91, 0) && types_match (_p2, _q91)))
6839 : : {
6840 : 0 : {
6841 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q41, _q40, _q91 };
6842 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
6843 : : )
6844 : : {
6845 : 0 : {
6846 : 0 : res_ops[0] = captures[0];
6847 : 0 : res_ops[1] = captures[1];
6848 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
6849 : 0 : return true;
6850 : : }
6851 : : }
6852 : : }
6853 : : }
6854 : : }
6855 : : }
6856 : : }
6857 : : }
6858 : : }
6859 : : }
6860 : : }
6861 : : }
6862 : : }
6863 : : }
6864 : 0 : break;
6865 : : }
6866 : : default:;
6867 : : }
6868 : : }
6869 : : break;
6870 : : default:;
6871 : : }
6872 : : }
6873 : : }
6874 : : }
6875 : 22317700 : break;
6876 : : }
6877 : : default:;
6878 : : }
6879 : : }
6880 : : break;
6881 : : default:;
6882 : : }
6883 : : break;
6884 : : }
6885 : : default:;
6886 : : }
6887 : : }
6888 : : break;
6889 : : default:;
6890 : : }
6891 : : }
6892 : 22317700 : break;
6893 : : }
6894 : : default:;
6895 : : }
6896 : : }
6897 : : break;
6898 : : default:;
6899 : : }
6900 : : break;
6901 : : }
6902 : 0 : case BIT_NOT_EXPR:
6903 : 0 : {
6904 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
6905 : 0 : _q30 = do_valueize (valueize, _q30);
6906 : 0 : switch (TREE_CODE (_q30))
6907 : : {
6908 : 0 : case SSA_NAME:
6909 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
6910 : : {
6911 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
6912 : 0 : switch (gimple_assign_rhs_code (_a3))
6913 : : {
6914 : 0 : case LT_EXPR:
6915 : 0 : {
6916 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
6917 : 0 : _q40 = do_valueize (valueize, _q40);
6918 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
6919 : 0 : _q41 = do_valueize (valueize, _q41);
6920 : 0 : switch (TREE_CODE (_q40))
6921 : : {
6922 : 0 : case SSA_NAME:
6923 : 0 : if (gimple *_d4 = get_def (valueize, _q40))
6924 : : {
6925 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
6926 : 0 : switch (gimple_assign_rhs_code (_a4))
6927 : : {
6928 : 0 : case BIT_XOR_EXPR:
6929 : 0 : {
6930 : 0 : tree _q50 = gimple_assign_rhs1 (_a4);
6931 : 0 : _q50 = do_valueize (valueize, _q50);
6932 : 0 : tree _q51 = gimple_assign_rhs2 (_a4);
6933 : 0 : _q51 = do_valueize (valueize, _q51);
6934 : 0 : if (tree_swap_operands_p (_q50, _q51))
6935 : 0 : std::swap (_q50, _q51);
6936 : 0 : if (integer_zerop (_q41))
6937 : : {
6938 : 0 : switch (TREE_CODE (_q21))
6939 : : {
6940 : 0 : case SSA_NAME:
6941 : 0 : if (gimple *_d5 = get_def (valueize, _q21))
6942 : : {
6943 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
6944 : 0 : switch (gimple_assign_rhs_code (_a5))
6945 : : {
6946 : 0 : case LT_EXPR:
6947 : 0 : {
6948 : 0 : tree _q90 = gimple_assign_rhs1 (_a5);
6949 : 0 : _q90 = do_valueize (valueize, _q90);
6950 : 0 : tree _q91 = gimple_assign_rhs2 (_a5);
6951 : 0 : _q91 = do_valueize (valueize, _q91);
6952 : 0 : switch (TREE_CODE (_q90))
6953 : : {
6954 : 0 : case SSA_NAME:
6955 : 0 : if (gimple *_d6 = get_def (valueize, _q90))
6956 : : {
6957 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
6958 : 0 : switch (gimple_assign_rhs_code (_a6))
6959 : : {
6960 : 0 : case BIT_XOR_EXPR:
6961 : 0 : {
6962 : 0 : tree _q100 = gimple_assign_rhs1 (_a6);
6963 : 0 : _q100 = do_valueize (valueize, _q100);
6964 : 0 : tree _q101 = gimple_assign_rhs2 (_a6);
6965 : 0 : _q101 = do_valueize (valueize, _q101);
6966 : 0 : if (tree_swap_operands_p (_q100, _q101))
6967 : 0 : std::swap (_q100, _q101);
6968 : 0 : if ((_q100 == _q50 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q50, 0) && types_match (_q100, _q50)))
6969 : : {
6970 : 0 : {
6971 : 0 : tree _q101_pops[1];
6972 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
6973 : : {
6974 : 0 : tree _q120 = _q101_pops[0];
6975 : 0 : switch (TREE_CODE (_q120))
6976 : : {
6977 : 0 : case SSA_NAME:
6978 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
6979 : : {
6980 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
6981 : 0 : switch (gimple_assign_rhs_code (_a7))
6982 : : {
6983 : 0 : case PLUS_EXPR:
6984 : 0 : {
6985 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
6986 : 0 : _q130 = do_valueize (valueize, _q130);
6987 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
6988 : 0 : _q131 = do_valueize (valueize, _q131);
6989 : 0 : if (tree_swap_operands_p (_q130, _q131))
6990 : 0 : std::swap (_q130, _q131);
6991 : 0 : {
6992 : 0 : tree _q130_pops[1];
6993 : 0 : if (gimple_nop_convert (_q130, _q130_pops, valueize))
6994 : : {
6995 : 0 : tree _q140 = _q130_pops[0];
6996 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
6997 : : {
6998 : 0 : {
6999 : 0 : tree _q131_pops[1];
7000 : 0 : if (gimple_nop_convert (_q131, _q131_pops, valueize))
7001 : : {
7002 : 0 : tree _q160 = _q131_pops[0];
7003 : 0 : if ((_q160 == _q51 && ! TREE_SIDE_EFFECTS (_q160)) || (operand_equal_p (_q160, _q51, 0) && types_match (_q160, _q51)))
7004 : : {
7005 : 0 : if (integer_zerop (_q91))
7006 : : {
7007 : 0 : {
7008 : 0 : tree _p1_pops[1];
7009 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7010 : : {
7011 : 0 : tree _q190 = _p1_pops[0];
7012 : 0 : if ((_q190 == _q50 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q50, 0) && types_match (_q190, _q50)))
7013 : : {
7014 : 0 : if ((_p2 == _q101 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q101, 0) && types_match (_p2, _q101)))
7015 : : {
7016 : 0 : {
7017 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q101 };
7018 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7019 : : )
7020 : : {
7021 : 0 : {
7022 : 0 : res_ops[0] = captures[0];
7023 : 0 : res_ops[1] = captures[1];
7024 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
7025 : 0 : return true;
7026 : : }
7027 : : }
7028 : : }
7029 : : }
7030 : : }
7031 : : }
7032 : : }
7033 : : }
7034 : : }
7035 : : }
7036 : : }
7037 : : }
7038 : : }
7039 : : }
7040 : 0 : break;
7041 : : }
7042 : : default:;
7043 : : }
7044 : : }
7045 : : break;
7046 : : default:;
7047 : : }
7048 : : }
7049 : : }
7050 : : }
7051 : 0 : if ((_q100 == _q51 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q51, 0) && types_match (_q100, _q51)))
7052 : : {
7053 : 0 : {
7054 : 0 : tree _q101_pops[1];
7055 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
7056 : : {
7057 : 0 : tree _q120 = _q101_pops[0];
7058 : 0 : switch (TREE_CODE (_q120))
7059 : : {
7060 : 0 : case SSA_NAME:
7061 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
7062 : : {
7063 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
7064 : 0 : switch (gimple_assign_rhs_code (_a7))
7065 : : {
7066 : 0 : case PLUS_EXPR:
7067 : 0 : {
7068 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
7069 : 0 : _q130 = do_valueize (valueize, _q130);
7070 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
7071 : 0 : _q131 = do_valueize (valueize, _q131);
7072 : 0 : if (tree_swap_operands_p (_q130, _q131))
7073 : 0 : std::swap (_q130, _q131);
7074 : 0 : {
7075 : 0 : tree _q130_pops[1];
7076 : 0 : if (gimple_nop_convert (_q130, _q130_pops, valueize))
7077 : : {
7078 : 0 : tree _q140 = _q130_pops[0];
7079 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
7080 : : {
7081 : 0 : {
7082 : 0 : tree _q131_pops[1];
7083 : 0 : if (gimple_nop_convert (_q131, _q131_pops, valueize))
7084 : : {
7085 : 0 : tree _q160 = _q131_pops[0];
7086 : 0 : if ((_q160 == _q50 && ! TREE_SIDE_EFFECTS (_q160)) || (operand_equal_p (_q160, _q50, 0) && types_match (_q160, _q50)))
7087 : : {
7088 : 0 : if (integer_zerop (_q91))
7089 : : {
7090 : 0 : {
7091 : 0 : tree _p1_pops[1];
7092 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7093 : : {
7094 : 0 : tree _q190 = _p1_pops[0];
7095 : 0 : if ((_q190 == _q51 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q51, 0) && types_match (_q190, _q51)))
7096 : : {
7097 : 0 : if ((_p2 == _q101 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q101, 0) && types_match (_p2, _q101)))
7098 : : {
7099 : 0 : {
7100 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q101 };
7101 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7102 : : )
7103 : : {
7104 : 0 : {
7105 : 0 : res_ops[0] = captures[0];
7106 : 0 : res_ops[1] = captures[1];
7107 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
7108 : 0 : return true;
7109 : : }
7110 : : }
7111 : : }
7112 : : }
7113 : : }
7114 : : }
7115 : : }
7116 : : }
7117 : : }
7118 : : }
7119 : : }
7120 : : }
7121 : : }
7122 : : }
7123 : 0 : break;
7124 : : }
7125 : : default:;
7126 : : }
7127 : : }
7128 : : break;
7129 : : default:;
7130 : : }
7131 : : }
7132 : : }
7133 : : }
7134 : 22317700 : break;
7135 : : }
7136 : : default:;
7137 : : }
7138 : : }
7139 : : break;
7140 : : default:;
7141 : : }
7142 : : break;
7143 : : }
7144 : : default:;
7145 : : }
7146 : : }
7147 : : break;
7148 : : default:;
7149 : : }
7150 : : }
7151 : 22317700 : break;
7152 : : }
7153 : : default:;
7154 : : }
7155 : : }
7156 : : break;
7157 : : default:;
7158 : : }
7159 : : break;
7160 : : }
7161 : : default:;
7162 : : }
7163 : : }
7164 : : break;
7165 : : default:;
7166 : : }
7167 : : break;
7168 : : }
7169 : : default:;
7170 : : }
7171 : : }
7172 : : break;
7173 : : default:;
7174 : : }
7175 : : }
7176 : : }
7177 : 22317700 : break;
7178 : : }
7179 : 0 : case NE_EXPR:
7180 : 0 : {
7181 : 0 : tree _q20 = TREE_OPERAND (_p0, 0);
7182 : 0 : if ((TREE_CODE (_q20) == SSA_NAME
7183 : 0 : || is_gimple_min_invariant (_q20)))
7184 : : {
7185 : 0 : _q20 = do_valueize (valueize, _q20);
7186 : 0 : tree _q21 = TREE_OPERAND (_p0, 1);
7187 : 0 : if ((TREE_CODE (_q21) == SSA_NAME
7188 : 0 : || is_gimple_min_invariant (_q21)))
7189 : : {
7190 : 0 : _q21 = do_valueize (valueize, _q21);
7191 : 0 : if (tree_swap_operands_p (_q20, _q21))
7192 : 0 : std::swap (_q20, _q21);
7193 : 0 : switch (TREE_CODE (_q20))
7194 : : {
7195 : 0 : case SSA_NAME:
7196 : 0 : if (gimple *_d2 = get_def (valueize, _q20))
7197 : : {
7198 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
7199 : 0 : switch (gimple_assign_rhs_code (_a2))
7200 : : {
7201 : 0 : case IMAGPART_EXPR:
7202 : 0 : {
7203 : 0 : tree _q30 = TREE_OPERAND (gimple_assign_rhs1 (_a2), 0);
7204 : 0 : if ((TREE_CODE (_q30) == SSA_NAME
7205 : 0 : || is_gimple_min_invariant (_q30)))
7206 : : {
7207 : 0 : _q30 = do_valueize (valueize, _q30);
7208 : 0 : switch (TREE_CODE (_q30))
7209 : : {
7210 : 0 : case SSA_NAME:
7211 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
7212 : : {
7213 : 0 : if (gcall *_c3 = dyn_cast <gcall *> (_d3))
7214 : 0 : switch (gimple_call_combined_fn (_c3))
7215 : : {
7216 : 0 : case CFN_ADD_OVERFLOW:
7217 : 0 : if (gimple_call_num_args (_c3) == 2)
7218 : : {
7219 : 0 : tree _q40 = gimple_call_arg (_c3, 0);
7220 : 0 : _q40 = do_valueize (valueize, _q40);
7221 : 0 : tree _q41 = gimple_call_arg (_c3, 1);
7222 : 0 : _q41 = do_valueize (valueize, _q41);
7223 : 0 : if (tree_swap_operands_p (_q40, _q41))
7224 : 0 : std::swap (_q40, _q41);
7225 : 0 : if (integer_zerop (_q21))
7226 : : {
7227 : 0 : {
7228 : 0 : tree _p1_pops[1];
7229 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7230 : : {
7231 : 0 : tree _q80 = _p1_pops[0];
7232 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
7233 : : {
7234 : 0 : switch (TREE_CODE (_p2))
7235 : : {
7236 : 0 : case SSA_NAME:
7237 : 0 : if (gimple *_d4 = get_def (valueize, _p2))
7238 : : {
7239 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
7240 : 0 : switch (gimple_assign_rhs_code (_a4))
7241 : : {
7242 : 0 : case REALPART_EXPR:
7243 : 0 : {
7244 : 0 : tree _q100 = TREE_OPERAND (gimple_assign_rhs1 (_a4), 0);
7245 : 0 : if ((TREE_CODE (_q100) == SSA_NAME
7246 : 0 : || is_gimple_min_invariant (_q100)))
7247 : : {
7248 : 0 : _q100 = do_valueize (valueize, _q100);
7249 : 0 : if ((_q100 == _q30 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q30, 0) && types_match (_q100, _q30)))
7250 : : {
7251 : 0 : {
7252 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q41, _q30 };
7253 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7254 : : )
7255 : : {
7256 : 0 : {
7257 : 0 : res_ops[0] = captures[0];
7258 : 0 : res_ops[1] = captures[1];
7259 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 76, __FILE__, __LINE__, false);
7260 : 0 : return true;
7261 : : }
7262 : : }
7263 : : }
7264 : : }
7265 : : }
7266 : : break;
7267 : : }
7268 : : default:;
7269 : : }
7270 : : }
7271 : : break;
7272 : : default:;
7273 : : }
7274 : : }
7275 : 0 : if ((_q80 == _q41 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q41, 0) && types_match (_q80, _q41)))
7276 : : {
7277 : 0 : switch (TREE_CODE (_p2))
7278 : : {
7279 : 0 : case SSA_NAME:
7280 : 0 : if (gimple *_d4 = get_def (valueize, _p2))
7281 : : {
7282 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
7283 : 0 : switch (gimple_assign_rhs_code (_a4))
7284 : : {
7285 : 0 : case REALPART_EXPR:
7286 : 0 : {
7287 : 0 : tree _q100 = TREE_OPERAND (gimple_assign_rhs1 (_a4), 0);
7288 : 0 : if ((TREE_CODE (_q100) == SSA_NAME
7289 : 0 : || is_gimple_min_invariant (_q100)))
7290 : : {
7291 : 0 : _q100 = do_valueize (valueize, _q100);
7292 : 0 : if ((_q100 == _q30 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q30, 0) && types_match (_q100, _q30)))
7293 : : {
7294 : 0 : {
7295 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q41, _q40, _q30 };
7296 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7297 : : )
7298 : : {
7299 : 0 : {
7300 : 0 : res_ops[0] = captures[0];
7301 : 0 : res_ops[1] = captures[1];
7302 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 76, __FILE__, __LINE__, false);
7303 : 0 : return true;
7304 : : }
7305 : : }
7306 : : }
7307 : : }
7308 : : }
7309 : : break;
7310 : : }
7311 : : default:;
7312 : : }
7313 : : }
7314 : : break;
7315 : : default:;
7316 : : }
7317 : : }
7318 : : }
7319 : : }
7320 : : }
7321 : : }
7322 : : break;
7323 : : default:;
7324 : : }
7325 : : }
7326 : : break;
7327 : : default:;
7328 : : }
7329 : : }
7330 : : break;
7331 : : }
7332 : : default:;
7333 : : }
7334 : : }
7335 : : break;
7336 : : default:;
7337 : : }
7338 : : }
7339 : : }
7340 : 22317700 : break;
7341 : : }
7342 : : default:;
7343 : : }
7344 : : break;
7345 : : }
7346 : : default:;
7347 : : }
7348 : 3365694 : else if (gphi *_a1 = dyn_cast <gphi *> (_d1))
7349 : : {
7350 : 3365694 : basic_block _b1 = gimple_bb (_a1);
7351 : 3365694 : tree _p1, _p2;
7352 : 3365694 : gcond *_cond_1 = match_cond_with_binary_phi (_a1, &_p1, &_p2);
7353 : 3365694 : if (_cond_1)
7354 : : {
7355 : 685666 : tree _cond_lhs_1 = gimple_cond_lhs (_cond_1);
7356 : 685666 : tree _cond_rhs_1 = gimple_cond_rhs (_cond_1);
7357 : 685666 : tree _p0 = build2 (gimple_cond_code (_cond_1), boolean_type_node, _cond_lhs_1, _cond_rhs_1);
7358 : 685666 : switch (TREE_CODE (_p0))
7359 : : {
7360 : 0 : case SSA_NAME:
7361 : 0 : if (gimple *_d2 = get_def (valueize, _p0))
7362 : : {
7363 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
7364 : 0 : switch (gimple_assign_rhs_code (_a2))
7365 : : {
7366 : 0 : case LT_EXPR:
7367 : 0 : {
7368 : 0 : tree _q20 = gimple_assign_rhs1 (_a2);
7369 : 0 : _q20 = do_valueize (valueize, _q20);
7370 : 0 : tree _q21 = gimple_assign_rhs2 (_a2);
7371 : 0 : _q21 = do_valueize (valueize, _q21);
7372 : 0 : switch (TREE_CODE (_q20))
7373 : : {
7374 : 0 : case SSA_NAME:
7375 : 0 : if (gimple *_d3 = get_def (valueize, _q20))
7376 : : {
7377 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
7378 : 0 : switch (gimple_assign_rhs_code (_a3))
7379 : : {
7380 : 0 : case BIT_AND_EXPR:
7381 : 0 : {
7382 : 0 : tree _q30 = gimple_assign_rhs1 (_a3);
7383 : 0 : _q30 = do_valueize (valueize, _q30);
7384 : 0 : tree _q31 = gimple_assign_rhs2 (_a3);
7385 : 0 : _q31 = do_valueize (valueize, _q31);
7386 : 0 : if (tree_swap_operands_p (_q30, _q31))
7387 : 0 : std::swap (_q30, _q31);
7388 : 0 : switch (TREE_CODE (_q30))
7389 : : {
7390 : 0 : case SSA_NAME:
7391 : 0 : if (gimple *_d4 = get_def (valueize, _q30))
7392 : : {
7393 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
7394 : 0 : switch (gimple_assign_rhs_code (_a4))
7395 : : {
7396 : 0 : case BIT_XOR_EXPR:
7397 : 0 : {
7398 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
7399 : 0 : _q40 = do_valueize (valueize, _q40);
7400 : 0 : tree _q41 = gimple_assign_rhs2 (_a4);
7401 : 0 : _q41 = do_valueize (valueize, _q41);
7402 : 0 : if (tree_swap_operands_p (_q40, _q41))
7403 : 0 : std::swap (_q40, _q41);
7404 : 0 : {
7405 : 0 : tree _q41_pops[1];
7406 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
7407 : : {
7408 : 0 : tree _q60 = _q41_pops[0];
7409 : 0 : switch (TREE_CODE (_q60))
7410 : : {
7411 : 0 : case SSA_NAME:
7412 : 0 : if (gimple *_d5 = get_def (valueize, _q60))
7413 : : {
7414 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
7415 : 0 : switch (gimple_assign_rhs_code (_a5))
7416 : : {
7417 : 0 : case PLUS_EXPR:
7418 : 0 : {
7419 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
7420 : 0 : _q70 = do_valueize (valueize, _q70);
7421 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
7422 : 0 : _q71 = do_valueize (valueize, _q71);
7423 : 0 : if (tree_swap_operands_p (_q70, _q71))
7424 : 0 : std::swap (_q70, _q71);
7425 : 0 : {
7426 : 0 : tree _q70_pops[1];
7427 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
7428 : : {
7429 : 0 : tree _q80 = _q70_pops[0];
7430 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
7431 : : {
7432 : 0 : {
7433 : 0 : tree _q71_pops[1];
7434 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
7435 : : {
7436 : 0 : tree _q100 = _q71_pops[0];
7437 : 0 : switch (TREE_CODE (_q31))
7438 : : {
7439 : 0 : case SSA_NAME:
7440 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
7441 : : {
7442 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
7443 : 0 : switch (gimple_assign_rhs_code (_a6))
7444 : : {
7445 : 0 : case BIT_NOT_EXPR:
7446 : 0 : {
7447 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
7448 : 0 : _q120 = do_valueize (valueize, _q120);
7449 : 0 : switch (TREE_CODE (_q120))
7450 : : {
7451 : 0 : case SSA_NAME:
7452 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
7453 : : {
7454 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
7455 : 0 : switch (gimple_assign_rhs_code (_a7))
7456 : : {
7457 : 0 : case BIT_XOR_EXPR:
7458 : 0 : {
7459 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
7460 : 0 : _q130 = do_valueize (valueize, _q130);
7461 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
7462 : 0 : _q131 = do_valueize (valueize, _q131);
7463 : 0 : if (tree_swap_operands_p (_q130, _q131))
7464 : 0 : std::swap (_q130, _q131);
7465 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
7466 : : {
7467 : 0 : if ((_q131 == _q100 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q100, 0) && types_match (_q131, _q100)))
7468 : : {
7469 : 0 : if (integer_zerop (_q21))
7470 : : {
7471 : 0 : {
7472 : 0 : tree _p1_pops[1];
7473 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7474 : : {
7475 : 0 : tree _q170 = _p1_pops[0];
7476 : 0 : if ((_q170 == _q40 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q40, 0) && types_match (_q170, _q40)))
7477 : : {
7478 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
7479 : : {
7480 : 0 : {
7481 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
7482 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7483 : : )
7484 : : {
7485 : 0 : {
7486 : 0 : res_ops[0] = captures[0];
7487 : 0 : res_ops[1] = captures[1];
7488 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
7489 : 0 : return true;
7490 : : }
7491 : : }
7492 : : }
7493 : : }
7494 : : }
7495 : : }
7496 : : }
7497 : : }
7498 : : }
7499 : : }
7500 : 0 : if ((_q130 == _q100 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q100, 0) && types_match (_q130, _q100)))
7501 : : {
7502 : 0 : if ((_q131 == _q40 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q40, 0) && types_match (_q131, _q40)))
7503 : : {
7504 : 0 : if (integer_zerop (_q21))
7505 : : {
7506 : 0 : {
7507 : 0 : tree _p1_pops[1];
7508 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7509 : : {
7510 : 0 : tree _q170 = _p1_pops[0];
7511 : 0 : if ((_q170 == _q40 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q40, 0) && types_match (_q170, _q40)))
7512 : : {
7513 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
7514 : : {
7515 : 0 : {
7516 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
7517 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7518 : : )
7519 : : {
7520 : 0 : {
7521 : 0 : res_ops[0] = captures[0];
7522 : 0 : res_ops[1] = captures[1];
7523 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
7524 : 0 : return true;
7525 : : }
7526 : : }
7527 : : }
7528 : : }
7529 : : }
7530 : : }
7531 : : }
7532 : : }
7533 : : }
7534 : : }
7535 : 0 : break;
7536 : : }
7537 : : default:;
7538 : : }
7539 : : }
7540 : : break;
7541 : : default:;
7542 : : }
7543 : : break;
7544 : : }
7545 : : default:;
7546 : : }
7547 : : }
7548 : : break;
7549 : : default:;
7550 : : }
7551 : : }
7552 : : }
7553 : : }
7554 : : }
7555 : : }
7556 : 0 : break;
7557 : : }
7558 : : default:;
7559 : : }
7560 : : }
7561 : : break;
7562 : : default:;
7563 : : }
7564 : : }
7565 : : }
7566 : 0 : {
7567 : 0 : tree _q40_pops[1];
7568 : 0 : if (gimple_nop_convert (_q40, _q40_pops, valueize))
7569 : : {
7570 : 0 : tree _q50 = _q40_pops[0];
7571 : 0 : switch (TREE_CODE (_q50))
7572 : : {
7573 : 0 : case SSA_NAME:
7574 : 0 : if (gimple *_d5 = get_def (valueize, _q50))
7575 : : {
7576 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
7577 : 0 : switch (gimple_assign_rhs_code (_a5))
7578 : : {
7579 : 0 : case PLUS_EXPR:
7580 : 0 : {
7581 : 0 : tree _q60 = gimple_assign_rhs1 (_a5);
7582 : 0 : _q60 = do_valueize (valueize, _q60);
7583 : 0 : tree _q61 = gimple_assign_rhs2 (_a5);
7584 : 0 : _q61 = do_valueize (valueize, _q61);
7585 : 0 : if (tree_swap_operands_p (_q60, _q61))
7586 : 0 : std::swap (_q60, _q61);
7587 : 0 : {
7588 : 0 : tree _q60_pops[1];
7589 : 0 : if (gimple_nop_convert (_q60, _q60_pops, valueize))
7590 : : {
7591 : 0 : tree _q70 = _q60_pops[0];
7592 : 0 : switch (TREE_CODE (_q61))
7593 : : {
7594 : 0 : case INTEGER_CST:
7595 : 0 : {
7596 : 0 : if ((_q41 == _q70 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q70, 0) && types_match (_q41, _q70)))
7597 : : {
7598 : 0 : switch (TREE_CODE (_q31))
7599 : : {
7600 : 0 : case SSA_NAME:
7601 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
7602 : : {
7603 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
7604 : 0 : switch (gimple_assign_rhs_code (_a6))
7605 : : {
7606 : 0 : case BIT_XOR_EXPR:
7607 : 0 : {
7608 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
7609 : 0 : _q110 = do_valueize (valueize, _q110);
7610 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
7611 : 0 : _q111 = do_valueize (valueize, _q111);
7612 : 0 : if (tree_swap_operands_p (_q110, _q111))
7613 : 0 : std::swap (_q110, _q111);
7614 : 0 : if ((_q110 == _q70 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q70, 0) && types_match (_q110, _q70)))
7615 : : {
7616 : 0 : switch (TREE_CODE (_q111))
7617 : : {
7618 : 0 : case INTEGER_CST:
7619 : 0 : {
7620 : 0 : if (integer_zerop (_q21))
7621 : : {
7622 : 0 : {
7623 : 0 : tree _p1_pops[1];
7624 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7625 : : {
7626 : 0 : tree _q150 = _p1_pops[0];
7627 : 0 : if ((_q150 == _q70 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q70, 0) && types_match (_q150, _q70)))
7628 : : {
7629 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
7630 : : {
7631 : 0 : {
7632 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q70, _q61, _q40, _q111 };
7633 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7634 : : )
7635 : : {
7636 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
7637 : : )
7638 : : {
7639 : 0 : {
7640 : 0 : res_ops[0] = captures[0];
7641 : 0 : res_ops[1] = captures[1];
7642 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
7643 : 0 : return true;
7644 : : }
7645 : : }
7646 : : }
7647 : : }
7648 : : }
7649 : : }
7650 : : }
7651 : : }
7652 : : }
7653 : : break;
7654 : : }
7655 : : default:;
7656 : : }
7657 : : }
7658 : 0 : switch (TREE_CODE (_q110))
7659 : : {
7660 : 0 : case INTEGER_CST:
7661 : 0 : {
7662 : 0 : if ((_q111 == _q70 && ! TREE_SIDE_EFFECTS (_q111)) || (operand_equal_p (_q111, _q70, 0) && types_match (_q111, _q70)))
7663 : : {
7664 : 0 : if (integer_zerop (_q21))
7665 : : {
7666 : 0 : {
7667 : 0 : tree _p1_pops[1];
7668 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7669 : : {
7670 : 0 : tree _q150 = _p1_pops[0];
7671 : 0 : if ((_q150 == _q70 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q70, 0) && types_match (_q150, _q70)))
7672 : : {
7673 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
7674 : : {
7675 : 0 : {
7676 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q70, _q61, _q40, _q110 };
7677 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7678 : : )
7679 : : {
7680 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
7681 : : )
7682 : : {
7683 : 0 : {
7684 : 0 : res_ops[0] = captures[0];
7685 : 0 : res_ops[1] = captures[1];
7686 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
7687 : 0 : return true;
7688 : : }
7689 : : }
7690 : : }
7691 : : }
7692 : : }
7693 : : }
7694 : : }
7695 : : }
7696 : : }
7697 : : }
7698 : : break;
7699 : : }
7700 : : default:;
7701 : : }
7702 : 0 : break;
7703 : : }
7704 : : default:;
7705 : : }
7706 : : }
7707 : : break;
7708 : : default:;
7709 : : }
7710 : : }
7711 : : break;
7712 : : }
7713 : 0 : default:;
7714 : : }
7715 : 0 : {
7716 : 0 : tree _q61_pops[1];
7717 : 0 : if (gimple_nop_convert (_q61, _q61_pops, valueize))
7718 : : {
7719 : 0 : tree _q90 = _q61_pops[0];
7720 : 0 : if ((_q41 == _q70 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q70, 0) && types_match (_q41, _q70)))
7721 : : {
7722 : 0 : switch (TREE_CODE (_q31))
7723 : : {
7724 : 0 : case SSA_NAME:
7725 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
7726 : : {
7727 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
7728 : 0 : switch (gimple_assign_rhs_code (_a6))
7729 : : {
7730 : 0 : case BIT_NOT_EXPR:
7731 : 0 : {
7732 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
7733 : 0 : _q120 = do_valueize (valueize, _q120);
7734 : 0 : switch (TREE_CODE (_q120))
7735 : : {
7736 : 0 : case SSA_NAME:
7737 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
7738 : : {
7739 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
7740 : 0 : switch (gimple_assign_rhs_code (_a7))
7741 : : {
7742 : 0 : case BIT_XOR_EXPR:
7743 : 0 : {
7744 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
7745 : 0 : _q130 = do_valueize (valueize, _q130);
7746 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
7747 : 0 : _q131 = do_valueize (valueize, _q131);
7748 : 0 : if (tree_swap_operands_p (_q130, _q131))
7749 : 0 : std::swap (_q130, _q131);
7750 : 0 : if ((_q130 == _q70 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q70, 0) && types_match (_q130, _q70)))
7751 : : {
7752 : 0 : if ((_q131 == _q90 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q90, 0) && types_match (_q131, _q90)))
7753 : : {
7754 : 0 : if (integer_zerop (_q21))
7755 : : {
7756 : 0 : {
7757 : 0 : tree _p1_pops[1];
7758 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7759 : : {
7760 : 0 : tree _q170 = _p1_pops[0];
7761 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
7762 : : {
7763 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
7764 : : {
7765 : 0 : {
7766 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q70, _q90, _q40 };
7767 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7768 : : )
7769 : : {
7770 : 0 : {
7771 : 0 : res_ops[0] = captures[0];
7772 : 0 : res_ops[1] = captures[1];
7773 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
7774 : 0 : return true;
7775 : : }
7776 : : }
7777 : : }
7778 : : }
7779 : : }
7780 : : }
7781 : : }
7782 : : }
7783 : : }
7784 : : }
7785 : 0 : if ((_q130 == _q90 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q90, 0) && types_match (_q130, _q90)))
7786 : : {
7787 : 0 : if ((_q131 == _q70 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q70, 0) && types_match (_q131, _q70)))
7788 : : {
7789 : 0 : if (integer_zerop (_q21))
7790 : : {
7791 : 0 : {
7792 : 0 : tree _p1_pops[1];
7793 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7794 : : {
7795 : 0 : tree _q170 = _p1_pops[0];
7796 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
7797 : : {
7798 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
7799 : : {
7800 : 0 : {
7801 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q70, _q90, _q40 };
7802 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7803 : : )
7804 : : {
7805 : 0 : {
7806 : 0 : res_ops[0] = captures[0];
7807 : 0 : res_ops[1] = captures[1];
7808 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
7809 : 0 : return true;
7810 : : }
7811 : : }
7812 : : }
7813 : : }
7814 : : }
7815 : : }
7816 : : }
7817 : : }
7818 : : }
7819 : : }
7820 : 0 : break;
7821 : : }
7822 : : default:;
7823 : : }
7824 : : }
7825 : : break;
7826 : : default:;
7827 : : }
7828 : : break;
7829 : : }
7830 : : default:;
7831 : : }
7832 : : }
7833 : : break;
7834 : : default:;
7835 : : }
7836 : : }
7837 : : }
7838 : : }
7839 : : }
7840 : : }
7841 : 0 : break;
7842 : : }
7843 : : default:;
7844 : : }
7845 : : }
7846 : : break;
7847 : : default:;
7848 : : }
7849 : : }
7850 : : }
7851 : 0 : switch (TREE_CODE (_q41))
7852 : : {
7853 : 0 : case INTEGER_CST:
7854 : 0 : {
7855 : 0 : switch (TREE_CODE (_q31))
7856 : : {
7857 : 0 : case SSA_NAME:
7858 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
7859 : : {
7860 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
7861 : 0 : switch (gimple_assign_rhs_code (_a5))
7862 : : {
7863 : 0 : case BIT_XOR_EXPR:
7864 : 0 : {
7865 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
7866 : 0 : _q70 = do_valueize (valueize, _q70);
7867 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
7868 : 0 : _q71 = do_valueize (valueize, _q71);
7869 : 0 : if (tree_swap_operands_p (_q70, _q71))
7870 : 0 : std::swap (_q70, _q71);
7871 : 0 : if ((_q70 == _q40 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q40, 0) && types_match (_q70, _q40)))
7872 : : {
7873 : 0 : {
7874 : 0 : tree _q71_pops[1];
7875 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
7876 : : {
7877 : 0 : tree _q90 = _q71_pops[0];
7878 : 0 : switch (TREE_CODE (_q90))
7879 : : {
7880 : 0 : case SSA_NAME:
7881 : 0 : if (gimple *_d6 = get_def (valueize, _q90))
7882 : : {
7883 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
7884 : 0 : switch (gimple_assign_rhs_code (_a6))
7885 : : {
7886 : 0 : case PLUS_EXPR:
7887 : 0 : {
7888 : 0 : tree _q100 = gimple_assign_rhs1 (_a6);
7889 : 0 : _q100 = do_valueize (valueize, _q100);
7890 : 0 : tree _q101 = gimple_assign_rhs2 (_a6);
7891 : 0 : _q101 = do_valueize (valueize, _q101);
7892 : 0 : if (tree_swap_operands_p (_q100, _q101))
7893 : 0 : std::swap (_q100, _q101);
7894 : 0 : {
7895 : 0 : tree _q100_pops[1];
7896 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
7897 : : {
7898 : 0 : tree _q110 = _q100_pops[0];
7899 : 0 : if ((_q110 == _q40 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q40, 0) && types_match (_q110, _q40)))
7900 : : {
7901 : 0 : switch (TREE_CODE (_q101))
7902 : : {
7903 : 0 : case INTEGER_CST:
7904 : 0 : {
7905 : 0 : if (integer_zerop (_q21))
7906 : : {
7907 : 0 : {
7908 : 0 : tree _p1_pops[1];
7909 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
7910 : : {
7911 : 0 : tree _q150 = _p1_pops[0];
7912 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
7913 : : {
7914 : 0 : if ((_p2 == _q71 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q71, 0) && types_match (_p2, _q71)))
7915 : : {
7916 : 0 : {
7917 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q101, _q71, _q41 };
7918 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
7919 : : )
7920 : : {
7921 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
7922 : : )
7923 : : {
7924 : 0 : {
7925 : 0 : res_ops[0] = captures[0];
7926 : 0 : res_ops[1] = captures[1];
7927 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
7928 : 0 : return true;
7929 : : }
7930 : : }
7931 : : }
7932 : : }
7933 : : }
7934 : : }
7935 : : }
7936 : : }
7937 : : }
7938 : : break;
7939 : : }
7940 : : default:;
7941 : : }
7942 : : }
7943 : : }
7944 : : }
7945 : 0 : break;
7946 : : }
7947 : : default:;
7948 : : }
7949 : : }
7950 : : break;
7951 : : default:;
7952 : : }
7953 : : }
7954 : : }
7955 : : }
7956 : 0 : break;
7957 : : }
7958 : : default:;
7959 : : }
7960 : : }
7961 : : break;
7962 : : default:;
7963 : : }
7964 : : break;
7965 : : }
7966 : 0 : default:;
7967 : : }
7968 : 0 : {
7969 : 0 : tree _q41_pops[1];
7970 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
7971 : : {
7972 : 0 : tree _q60 = _q41_pops[0];
7973 : 0 : switch (TREE_CODE (_q60))
7974 : : {
7975 : 0 : case SSA_NAME:
7976 : 0 : if (gimple *_d5 = get_def (valueize, _q60))
7977 : : {
7978 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
7979 : 0 : switch (gimple_assign_rhs_code (_a5))
7980 : : {
7981 : 0 : case PLUS_EXPR:
7982 : 0 : {
7983 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
7984 : 0 : _q70 = do_valueize (valueize, _q70);
7985 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
7986 : 0 : _q71 = do_valueize (valueize, _q71);
7987 : 0 : if (tree_swap_operands_p (_q70, _q71))
7988 : 0 : std::swap (_q70, _q71);
7989 : 0 : {
7990 : 0 : tree _q70_pops[1];
7991 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
7992 : : {
7993 : 0 : tree _q80 = _q70_pops[0];
7994 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
7995 : : {
7996 : 0 : switch (TREE_CODE (_q71))
7997 : : {
7998 : 0 : case INTEGER_CST:
7999 : 0 : {
8000 : 0 : switch (TREE_CODE (_q31))
8001 : : {
8002 : 0 : case SSA_NAME:
8003 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
8004 : : {
8005 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
8006 : 0 : switch (gimple_assign_rhs_code (_a6))
8007 : : {
8008 : 0 : case BIT_XOR_EXPR:
8009 : 0 : {
8010 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
8011 : 0 : _q110 = do_valueize (valueize, _q110);
8012 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
8013 : 0 : _q111 = do_valueize (valueize, _q111);
8014 : 0 : if (tree_swap_operands_p (_q110, _q111))
8015 : 0 : std::swap (_q110, _q111);
8016 : 0 : if ((_q110 == _q40 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q40, 0) && types_match (_q110, _q40)))
8017 : : {
8018 : 0 : switch (TREE_CODE (_q111))
8019 : : {
8020 : 0 : case INTEGER_CST:
8021 : 0 : {
8022 : 0 : if (integer_zerop (_q21))
8023 : : {
8024 : 0 : {
8025 : 0 : tree _p1_pops[1];
8026 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8027 : : {
8028 : 0 : tree _q150 = _p1_pops[0];
8029 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
8030 : : {
8031 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
8032 : : {
8033 : 0 : {
8034 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q71, _q41, _q111 };
8035 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8036 : : )
8037 : : {
8038 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
8039 : : )
8040 : : {
8041 : 0 : {
8042 : 0 : res_ops[0] = captures[0];
8043 : 0 : res_ops[1] = captures[1];
8044 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
8045 : 0 : return true;
8046 : : }
8047 : : }
8048 : : }
8049 : : }
8050 : : }
8051 : : }
8052 : : }
8053 : : }
8054 : : }
8055 : : break;
8056 : : }
8057 : : default:;
8058 : : }
8059 : : }
8060 : 0 : switch (TREE_CODE (_q110))
8061 : : {
8062 : 0 : case INTEGER_CST:
8063 : 0 : {
8064 : 0 : if ((_q111 == _q40 && ! TREE_SIDE_EFFECTS (_q111)) || (operand_equal_p (_q111, _q40, 0) && types_match (_q111, _q40)))
8065 : : {
8066 : 0 : if (integer_zerop (_q21))
8067 : : {
8068 : 0 : {
8069 : 0 : tree _p1_pops[1];
8070 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8071 : : {
8072 : 0 : tree _q150 = _p1_pops[0];
8073 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
8074 : : {
8075 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
8076 : : {
8077 : 0 : {
8078 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q71, _q41, _q110 };
8079 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8080 : : )
8081 : : {
8082 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
8083 : : )
8084 : : {
8085 : 0 : {
8086 : 0 : res_ops[0] = captures[0];
8087 : 0 : res_ops[1] = captures[1];
8088 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
8089 : 0 : return true;
8090 : : }
8091 : : }
8092 : : }
8093 : : }
8094 : : }
8095 : : }
8096 : : }
8097 : : }
8098 : : }
8099 : : }
8100 : : break;
8101 : : }
8102 : : default:;
8103 : : }
8104 : 0 : break;
8105 : : }
8106 : : default:;
8107 : : }
8108 : : }
8109 : : break;
8110 : : default:;
8111 : : }
8112 : : break;
8113 : : }
8114 : : default:;
8115 : : }
8116 : : }
8117 : : }
8118 : : }
8119 : 0 : break;
8120 : : }
8121 : : default:;
8122 : : }
8123 : : }
8124 : : break;
8125 : : default:;
8126 : : }
8127 : : }
8128 : : }
8129 : 0 : switch (TREE_CODE (_q40))
8130 : : {
8131 : 0 : case INTEGER_CST:
8132 : 0 : {
8133 : 0 : switch (TREE_CODE (_q31))
8134 : : {
8135 : 0 : case SSA_NAME:
8136 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
8137 : : {
8138 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
8139 : 0 : switch (gimple_assign_rhs_code (_a5))
8140 : : {
8141 : 0 : case BIT_XOR_EXPR:
8142 : 0 : {
8143 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
8144 : 0 : _q70 = do_valueize (valueize, _q70);
8145 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
8146 : 0 : _q71 = do_valueize (valueize, _q71);
8147 : 0 : if (tree_swap_operands_p (_q70, _q71))
8148 : 0 : std::swap (_q70, _q71);
8149 : 0 : if ((_q70 == _q41 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q41, 0) && types_match (_q70, _q41)))
8150 : : {
8151 : 0 : {
8152 : 0 : tree _q71_pops[1];
8153 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
8154 : : {
8155 : 0 : tree _q90 = _q71_pops[0];
8156 : 0 : switch (TREE_CODE (_q90))
8157 : : {
8158 : 0 : case SSA_NAME:
8159 : 0 : if (gimple *_d6 = get_def (valueize, _q90))
8160 : : {
8161 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
8162 : 0 : switch (gimple_assign_rhs_code (_a6))
8163 : : {
8164 : 0 : case PLUS_EXPR:
8165 : 0 : {
8166 : 0 : tree _q100 = gimple_assign_rhs1 (_a6);
8167 : 0 : _q100 = do_valueize (valueize, _q100);
8168 : 0 : tree _q101 = gimple_assign_rhs2 (_a6);
8169 : 0 : _q101 = do_valueize (valueize, _q101);
8170 : 0 : if (tree_swap_operands_p (_q100, _q101))
8171 : 0 : std::swap (_q100, _q101);
8172 : 0 : {
8173 : 0 : tree _q100_pops[1];
8174 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
8175 : : {
8176 : 0 : tree _q110 = _q100_pops[0];
8177 : 0 : if ((_q110 == _q41 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q41, 0) && types_match (_q110, _q41)))
8178 : : {
8179 : 0 : switch (TREE_CODE (_q101))
8180 : : {
8181 : 0 : case INTEGER_CST:
8182 : 0 : {
8183 : 0 : if (integer_zerop (_q21))
8184 : : {
8185 : 0 : {
8186 : 0 : tree _p1_pops[1];
8187 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8188 : : {
8189 : 0 : tree _q150 = _p1_pops[0];
8190 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
8191 : : {
8192 : 0 : if ((_p2 == _q71 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q71, 0) && types_match (_p2, _q71)))
8193 : : {
8194 : 0 : {
8195 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q41, _q101, _q71, _q40 };
8196 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8197 : : )
8198 : : {
8199 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
8200 : : )
8201 : : {
8202 : 0 : {
8203 : 0 : res_ops[0] = captures[0];
8204 : 0 : res_ops[1] = captures[1];
8205 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
8206 : 0 : return true;
8207 : : }
8208 : : }
8209 : : }
8210 : : }
8211 : : }
8212 : : }
8213 : : }
8214 : : }
8215 : : }
8216 : : break;
8217 : : }
8218 : : default:;
8219 : : }
8220 : : }
8221 : : }
8222 : : }
8223 : 0 : break;
8224 : : }
8225 : : default:;
8226 : : }
8227 : : }
8228 : : break;
8229 : : default:;
8230 : : }
8231 : : }
8232 : : }
8233 : : }
8234 : 0 : {
8235 : 0 : tree _q70_pops[1];
8236 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
8237 : : {
8238 : 0 : tree _q80 = _q70_pops[0];
8239 : 0 : switch (TREE_CODE (_q80))
8240 : : {
8241 : 0 : case SSA_NAME:
8242 : 0 : if (gimple *_d6 = get_def (valueize, _q80))
8243 : : {
8244 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
8245 : 0 : switch (gimple_assign_rhs_code (_a6))
8246 : : {
8247 : 0 : case PLUS_EXPR:
8248 : 0 : {
8249 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
8250 : 0 : _q90 = do_valueize (valueize, _q90);
8251 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
8252 : 0 : _q91 = do_valueize (valueize, _q91);
8253 : 0 : if (tree_swap_operands_p (_q90, _q91))
8254 : 0 : std::swap (_q90, _q91);
8255 : 0 : {
8256 : 0 : tree _q90_pops[1];
8257 : 0 : if (gimple_nop_convert (_q90, _q90_pops, valueize))
8258 : : {
8259 : 0 : tree _q100 = _q90_pops[0];
8260 : 0 : if ((_q100 == _q41 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q41, 0) && types_match (_q100, _q41)))
8261 : : {
8262 : 0 : switch (TREE_CODE (_q91))
8263 : : {
8264 : 0 : case INTEGER_CST:
8265 : 0 : {
8266 : 0 : if ((_q71 == _q41 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q41, 0) && types_match (_q71, _q41)))
8267 : : {
8268 : 0 : if (integer_zerop (_q21))
8269 : : {
8270 : 0 : {
8271 : 0 : tree _p1_pops[1];
8272 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8273 : : {
8274 : 0 : tree _q150 = _p1_pops[0];
8275 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
8276 : : {
8277 : 0 : if ((_p2 == _q70 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q70, 0) && types_match (_p2, _q70)))
8278 : : {
8279 : 0 : {
8280 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q41, _q91, _q70, _q40 };
8281 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8282 : : )
8283 : : {
8284 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
8285 : : )
8286 : : {
8287 : 0 : {
8288 : 0 : res_ops[0] = captures[0];
8289 : 0 : res_ops[1] = captures[1];
8290 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
8291 : 0 : return true;
8292 : : }
8293 : : }
8294 : : }
8295 : : }
8296 : : }
8297 : : }
8298 : : }
8299 : : }
8300 : : }
8301 : : }
8302 : : break;
8303 : : }
8304 : : default:;
8305 : : }
8306 : : }
8307 : : }
8308 : : }
8309 : 0 : break;
8310 : : }
8311 : : default:;
8312 : : }
8313 : : }
8314 : : break;
8315 : : default:;
8316 : : }
8317 : : }
8318 : : }
8319 : 0 : break;
8320 : : }
8321 : : default:;
8322 : : }
8323 : : }
8324 : : break;
8325 : : default:;
8326 : : }
8327 : : break;
8328 : : }
8329 : 0 : default:;
8330 : : }
8331 : 0 : switch (TREE_CODE (_q41))
8332 : : {
8333 : 0 : case INTEGER_CST:
8334 : 0 : {
8335 : 0 : switch (TREE_CODE (_q31))
8336 : : {
8337 : 0 : case SSA_NAME:
8338 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
8339 : : {
8340 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
8341 : 0 : switch (gimple_assign_rhs_code (_a5))
8342 : : {
8343 : 0 : case BIT_XOR_EXPR:
8344 : 0 : {
8345 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
8346 : 0 : _q70 = do_valueize (valueize, _q70);
8347 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
8348 : 0 : _q71 = do_valueize (valueize, _q71);
8349 : 0 : if (tree_swap_operands_p (_q70, _q71))
8350 : 0 : std::swap (_q70, _q71);
8351 : 0 : {
8352 : 0 : tree _q70_pops[1];
8353 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
8354 : : {
8355 : 0 : tree _q80 = _q70_pops[0];
8356 : 0 : switch (TREE_CODE (_q80))
8357 : : {
8358 : 0 : case SSA_NAME:
8359 : 0 : if (gimple *_d6 = get_def (valueize, _q80))
8360 : : {
8361 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
8362 : 0 : switch (gimple_assign_rhs_code (_a6))
8363 : : {
8364 : 0 : case PLUS_EXPR:
8365 : 0 : {
8366 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
8367 : 0 : _q90 = do_valueize (valueize, _q90);
8368 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
8369 : 0 : _q91 = do_valueize (valueize, _q91);
8370 : 0 : if (tree_swap_operands_p (_q90, _q91))
8371 : 0 : std::swap (_q90, _q91);
8372 : 0 : {
8373 : 0 : tree _q90_pops[1];
8374 : 0 : if (gimple_nop_convert (_q90, _q90_pops, valueize))
8375 : : {
8376 : 0 : tree _q100 = _q90_pops[0];
8377 : 0 : if ((_q100 == _q40 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q40, 0) && types_match (_q100, _q40)))
8378 : : {
8379 : 0 : switch (TREE_CODE (_q91))
8380 : : {
8381 : 0 : case INTEGER_CST:
8382 : 0 : {
8383 : 0 : if ((_q71 == _q40 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q40, 0) && types_match (_q71, _q40)))
8384 : : {
8385 : 0 : if (integer_zerop (_q21))
8386 : : {
8387 : 0 : {
8388 : 0 : tree _p1_pops[1];
8389 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8390 : : {
8391 : 0 : tree _q150 = _p1_pops[0];
8392 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
8393 : : {
8394 : 0 : if ((_p2 == _q70 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q70, 0) && types_match (_p2, _q70)))
8395 : : {
8396 : 0 : {
8397 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q91, _q70, _q41 };
8398 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8399 : : )
8400 : : {
8401 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
8402 : : )
8403 : : {
8404 : 0 : {
8405 : 0 : res_ops[0] = captures[0];
8406 : 0 : res_ops[1] = captures[1];
8407 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
8408 : 0 : return true;
8409 : : }
8410 : : }
8411 : : }
8412 : : }
8413 : : }
8414 : : }
8415 : : }
8416 : : }
8417 : : }
8418 : : }
8419 : : break;
8420 : : }
8421 : : default:;
8422 : : }
8423 : : }
8424 : : }
8425 : : }
8426 : 0 : break;
8427 : : }
8428 : : default:;
8429 : : }
8430 : : }
8431 : : break;
8432 : : default:;
8433 : : }
8434 : : }
8435 : : }
8436 : 0 : break;
8437 : : }
8438 : : default:;
8439 : : }
8440 : : }
8441 : : break;
8442 : : default:;
8443 : : }
8444 : : break;
8445 : : }
8446 : : default:;
8447 : : }
8448 : 3365690 : break;
8449 : : }
8450 : 0 : case BIT_NOT_EXPR:
8451 : 0 : {
8452 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
8453 : 0 : _q40 = do_valueize (valueize, _q40);
8454 : 0 : switch (TREE_CODE (_q40))
8455 : : {
8456 : 0 : case SSA_NAME:
8457 : 0 : if (gimple *_d5 = get_def (valueize, _q40))
8458 : : {
8459 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
8460 : 0 : switch (gimple_assign_rhs_code (_a5))
8461 : : {
8462 : 0 : case BIT_XOR_EXPR:
8463 : 0 : {
8464 : 0 : tree _q50 = gimple_assign_rhs1 (_a5);
8465 : 0 : _q50 = do_valueize (valueize, _q50);
8466 : 0 : tree _q51 = gimple_assign_rhs2 (_a5);
8467 : 0 : _q51 = do_valueize (valueize, _q51);
8468 : 0 : if (tree_swap_operands_p (_q50, _q51))
8469 : 0 : std::swap (_q50, _q51);
8470 : 0 : switch (TREE_CODE (_q31))
8471 : : {
8472 : 0 : case SSA_NAME:
8473 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
8474 : : {
8475 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
8476 : 0 : switch (gimple_assign_rhs_code (_a6))
8477 : : {
8478 : 0 : case BIT_XOR_EXPR:
8479 : 0 : {
8480 : 0 : tree _q80 = gimple_assign_rhs1 (_a6);
8481 : 0 : _q80 = do_valueize (valueize, _q80);
8482 : 0 : tree _q81 = gimple_assign_rhs2 (_a6);
8483 : 0 : _q81 = do_valueize (valueize, _q81);
8484 : 0 : if (tree_swap_operands_p (_q80, _q81))
8485 : 0 : std::swap (_q80, _q81);
8486 : 0 : if ((_q80 == _q50 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q50, 0) && types_match (_q80, _q50)))
8487 : : {
8488 : 0 : {
8489 : 0 : tree _q81_pops[1];
8490 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
8491 : : {
8492 : 0 : tree _q100 = _q81_pops[0];
8493 : 0 : switch (TREE_CODE (_q100))
8494 : : {
8495 : 0 : case SSA_NAME:
8496 : 0 : if (gimple *_d7 = get_def (valueize, _q100))
8497 : : {
8498 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
8499 : 0 : switch (gimple_assign_rhs_code (_a7))
8500 : : {
8501 : 0 : case PLUS_EXPR:
8502 : 0 : {
8503 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
8504 : 0 : _q110 = do_valueize (valueize, _q110);
8505 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
8506 : 0 : _q111 = do_valueize (valueize, _q111);
8507 : 0 : if (tree_swap_operands_p (_q110, _q111))
8508 : 0 : std::swap (_q110, _q111);
8509 : 0 : {
8510 : 0 : tree _q110_pops[1];
8511 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
8512 : : {
8513 : 0 : tree _q120 = _q110_pops[0];
8514 : 0 : if ((_q120 == _q50 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q50, 0) && types_match (_q120, _q50)))
8515 : : {
8516 : 0 : {
8517 : 0 : tree _q111_pops[1];
8518 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
8519 : : {
8520 : 0 : tree _q140 = _q111_pops[0];
8521 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
8522 : : {
8523 : 0 : if (integer_zerop (_q21))
8524 : : {
8525 : 0 : {
8526 : 0 : tree _p1_pops[1];
8527 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8528 : : {
8529 : 0 : tree _q170 = _p1_pops[0];
8530 : 0 : if ((_q170 == _q50 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q50, 0) && types_match (_q170, _q50)))
8531 : : {
8532 : 0 : if ((_p2 == _q81 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q81, 0) && types_match (_p2, _q81)))
8533 : : {
8534 : 0 : {
8535 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
8536 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8537 : : )
8538 : : {
8539 : 0 : {
8540 : 0 : res_ops[0] = captures[0];
8541 : 0 : res_ops[1] = captures[1];
8542 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
8543 : 0 : return true;
8544 : : }
8545 : : }
8546 : : }
8547 : : }
8548 : : }
8549 : : }
8550 : : }
8551 : : }
8552 : : }
8553 : : }
8554 : : }
8555 : : }
8556 : : }
8557 : : }
8558 : 0 : break;
8559 : : }
8560 : : default:;
8561 : : }
8562 : : }
8563 : : break;
8564 : : default:;
8565 : : }
8566 : : }
8567 : : }
8568 : : }
8569 : 0 : if ((_q80 == _q51 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q51, 0) && types_match (_q80, _q51)))
8570 : : {
8571 : 0 : {
8572 : 0 : tree _q81_pops[1];
8573 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
8574 : : {
8575 : 0 : tree _q100 = _q81_pops[0];
8576 : 0 : switch (TREE_CODE (_q100))
8577 : : {
8578 : 0 : case SSA_NAME:
8579 : 0 : if (gimple *_d7 = get_def (valueize, _q100))
8580 : : {
8581 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
8582 : 0 : switch (gimple_assign_rhs_code (_a7))
8583 : : {
8584 : 0 : case PLUS_EXPR:
8585 : 0 : {
8586 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
8587 : 0 : _q110 = do_valueize (valueize, _q110);
8588 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
8589 : 0 : _q111 = do_valueize (valueize, _q111);
8590 : 0 : if (tree_swap_operands_p (_q110, _q111))
8591 : 0 : std::swap (_q110, _q111);
8592 : 0 : {
8593 : 0 : tree _q110_pops[1];
8594 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
8595 : : {
8596 : 0 : tree _q120 = _q110_pops[0];
8597 : 0 : if ((_q120 == _q51 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q51, 0) && types_match (_q120, _q51)))
8598 : : {
8599 : 0 : {
8600 : 0 : tree _q111_pops[1];
8601 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
8602 : : {
8603 : 0 : tree _q140 = _q111_pops[0];
8604 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
8605 : : {
8606 : 0 : if (integer_zerop (_q21))
8607 : : {
8608 : 0 : {
8609 : 0 : tree _p1_pops[1];
8610 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8611 : : {
8612 : 0 : tree _q170 = _p1_pops[0];
8613 : 0 : if ((_q170 == _q51 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q51, 0) && types_match (_q170, _q51)))
8614 : : {
8615 : 0 : if ((_p2 == _q81 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q81, 0) && types_match (_p2, _q81)))
8616 : : {
8617 : 0 : {
8618 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
8619 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8620 : : )
8621 : : {
8622 : 0 : {
8623 : 0 : res_ops[0] = captures[0];
8624 : 0 : res_ops[1] = captures[1];
8625 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
8626 : 0 : return true;
8627 : : }
8628 : : }
8629 : : }
8630 : : }
8631 : : }
8632 : : }
8633 : : }
8634 : : }
8635 : : }
8636 : : }
8637 : : }
8638 : : }
8639 : : }
8640 : : }
8641 : 0 : break;
8642 : : }
8643 : : default:;
8644 : : }
8645 : : }
8646 : : break;
8647 : : default:;
8648 : : }
8649 : : }
8650 : : }
8651 : : }
8652 : 0 : {
8653 : 0 : tree _q80_pops[1];
8654 : 0 : if (gimple_nop_convert (_q80, _q80_pops, valueize))
8655 : : {
8656 : 0 : tree _q90 = _q80_pops[0];
8657 : 0 : switch (TREE_CODE (_q90))
8658 : : {
8659 : 0 : case SSA_NAME:
8660 : 0 : if (gimple *_d7 = get_def (valueize, _q90))
8661 : : {
8662 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
8663 : 0 : switch (gimple_assign_rhs_code (_a7))
8664 : : {
8665 : 0 : case PLUS_EXPR:
8666 : 0 : {
8667 : 0 : tree _q100 = gimple_assign_rhs1 (_a7);
8668 : 0 : _q100 = do_valueize (valueize, _q100);
8669 : 0 : tree _q101 = gimple_assign_rhs2 (_a7);
8670 : 0 : _q101 = do_valueize (valueize, _q101);
8671 : 0 : if (tree_swap_operands_p (_q100, _q101))
8672 : 0 : std::swap (_q100, _q101);
8673 : 0 : {
8674 : 0 : tree _q100_pops[1];
8675 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
8676 : : {
8677 : 0 : tree _q110 = _q100_pops[0];
8678 : 0 : if ((_q110 == _q50 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q50, 0) && types_match (_q110, _q50)))
8679 : : {
8680 : 0 : {
8681 : 0 : tree _q101_pops[1];
8682 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
8683 : : {
8684 : 0 : tree _q130 = _q101_pops[0];
8685 : 0 : if ((_q130 == _q51 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q51, 0) && types_match (_q130, _q51)))
8686 : : {
8687 : 0 : if ((_q81 == _q50 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q50, 0) && types_match (_q81, _q50)))
8688 : : {
8689 : 0 : if (integer_zerop (_q21))
8690 : : {
8691 : 0 : {
8692 : 0 : tree _p1_pops[1];
8693 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8694 : : {
8695 : 0 : tree _q170 = _p1_pops[0];
8696 : 0 : if ((_q170 == _q50 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q50, 0) && types_match (_q170, _q50)))
8697 : : {
8698 : 0 : if ((_p2 == _q80 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q80, 0) && types_match (_p2, _q80)))
8699 : : {
8700 : 0 : {
8701 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q80 };
8702 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8703 : : )
8704 : : {
8705 : 0 : {
8706 : 0 : res_ops[0] = captures[0];
8707 : 0 : res_ops[1] = captures[1];
8708 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
8709 : 0 : return true;
8710 : : }
8711 : : }
8712 : : }
8713 : : }
8714 : : }
8715 : : }
8716 : : }
8717 : : }
8718 : : }
8719 : : }
8720 : : }
8721 : : }
8722 : : }
8723 : 0 : if ((_q110 == _q51 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q51, 0) && types_match (_q110, _q51)))
8724 : : {
8725 : 0 : {
8726 : 0 : tree _q101_pops[1];
8727 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
8728 : : {
8729 : 0 : tree _q130 = _q101_pops[0];
8730 : 0 : if ((_q130 == _q50 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q50, 0) && types_match (_q130, _q50)))
8731 : : {
8732 : 0 : if ((_q81 == _q51 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q51, 0) && types_match (_q81, _q51)))
8733 : : {
8734 : 0 : if (integer_zerop (_q21))
8735 : : {
8736 : 0 : {
8737 : 0 : tree _p1_pops[1];
8738 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
8739 : : {
8740 : 0 : tree _q170 = _p1_pops[0];
8741 : 0 : if ((_q170 == _q51 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q51, 0) && types_match (_q170, _q51)))
8742 : : {
8743 : 0 : if ((_p2 == _q80 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q80, 0) && types_match (_p2, _q80)))
8744 : : {
8745 : 0 : {
8746 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q80 };
8747 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8748 : : )
8749 : : {
8750 : 0 : {
8751 : 0 : res_ops[0] = captures[0];
8752 : 0 : res_ops[1] = captures[1];
8753 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
8754 : 0 : return true;
8755 : : }
8756 : : }
8757 : : }
8758 : : }
8759 : : }
8760 : : }
8761 : : }
8762 : : }
8763 : : }
8764 : : }
8765 : : }
8766 : : }
8767 : : }
8768 : : }
8769 : : }
8770 : 0 : break;
8771 : : }
8772 : : default:;
8773 : : }
8774 : : }
8775 : : break;
8776 : : default:;
8777 : : }
8778 : : }
8779 : : }
8780 : 0 : break;
8781 : : }
8782 : : default:;
8783 : : }
8784 : : }
8785 : : break;
8786 : : default:;
8787 : : }
8788 : 3365690 : break;
8789 : : }
8790 : : default:;
8791 : : }
8792 : : }
8793 : : break;
8794 : : default:;
8795 : : }
8796 : : break;
8797 : : }
8798 : : default:;
8799 : : }
8800 : : }
8801 : : break;
8802 : : default:;
8803 : : }
8804 : 3365690 : break;
8805 : : }
8806 : : default:;
8807 : : }
8808 : : }
8809 : : break;
8810 : : default:;
8811 : : }
8812 : : break;
8813 : : }
8814 : 0 : case GE_EXPR:
8815 : 0 : {
8816 : 0 : tree _q20 = gimple_assign_rhs1 (_a2);
8817 : 0 : _q20 = do_valueize (valueize, _q20);
8818 : 0 : tree _q21 = gimple_assign_rhs2 (_a2);
8819 : 0 : _q21 = do_valueize (valueize, _q21);
8820 : 0 : switch (TREE_CODE (_q20))
8821 : : {
8822 : 0 : case SSA_NAME:
8823 : 0 : if (gimple *_d3 = get_def (valueize, _q20))
8824 : : {
8825 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
8826 : 0 : switch (gimple_assign_rhs_code (_a3))
8827 : : {
8828 : 0 : case BIT_AND_EXPR:
8829 : 0 : {
8830 : 0 : tree _q30 = gimple_assign_rhs1 (_a3);
8831 : 0 : _q30 = do_valueize (valueize, _q30);
8832 : 0 : tree _q31 = gimple_assign_rhs2 (_a3);
8833 : 0 : _q31 = do_valueize (valueize, _q31);
8834 : 0 : if (tree_swap_operands_p (_q30, _q31))
8835 : 0 : std::swap (_q30, _q31);
8836 : 0 : switch (TREE_CODE (_q30))
8837 : : {
8838 : 0 : case SSA_NAME:
8839 : 0 : if (gimple *_d4 = get_def (valueize, _q30))
8840 : : {
8841 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
8842 : 0 : switch (gimple_assign_rhs_code (_a4))
8843 : : {
8844 : 0 : case BIT_XOR_EXPR:
8845 : 0 : {
8846 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
8847 : 0 : _q40 = do_valueize (valueize, _q40);
8848 : 0 : tree _q41 = gimple_assign_rhs2 (_a4);
8849 : 0 : _q41 = do_valueize (valueize, _q41);
8850 : 0 : if (tree_swap_operands_p (_q40, _q41))
8851 : 0 : std::swap (_q40, _q41);
8852 : 0 : {
8853 : 0 : tree _q41_pops[1];
8854 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
8855 : : {
8856 : 0 : tree _q60 = _q41_pops[0];
8857 : 0 : switch (TREE_CODE (_q60))
8858 : : {
8859 : 0 : case SSA_NAME:
8860 : 0 : if (gimple *_d5 = get_def (valueize, _q60))
8861 : : {
8862 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
8863 : 0 : switch (gimple_assign_rhs_code (_a5))
8864 : : {
8865 : 0 : case PLUS_EXPR:
8866 : 0 : {
8867 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
8868 : 0 : _q70 = do_valueize (valueize, _q70);
8869 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
8870 : 0 : _q71 = do_valueize (valueize, _q71);
8871 : 0 : if (tree_swap_operands_p (_q70, _q71))
8872 : 0 : std::swap (_q70, _q71);
8873 : 0 : {
8874 : 0 : tree _q70_pops[1];
8875 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
8876 : : {
8877 : 0 : tree _q80 = _q70_pops[0];
8878 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
8879 : : {
8880 : 0 : {
8881 : 0 : tree _q71_pops[1];
8882 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
8883 : : {
8884 : 0 : tree _q100 = _q71_pops[0];
8885 : 0 : switch (TREE_CODE (_q31))
8886 : : {
8887 : 0 : case SSA_NAME:
8888 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
8889 : : {
8890 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
8891 : 0 : switch (gimple_assign_rhs_code (_a6))
8892 : : {
8893 : 0 : case BIT_NOT_EXPR:
8894 : 0 : {
8895 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
8896 : 0 : _q120 = do_valueize (valueize, _q120);
8897 : 0 : switch (TREE_CODE (_q120))
8898 : : {
8899 : 0 : case SSA_NAME:
8900 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
8901 : : {
8902 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
8903 : 0 : switch (gimple_assign_rhs_code (_a7))
8904 : : {
8905 : 0 : case BIT_XOR_EXPR:
8906 : 0 : {
8907 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
8908 : 0 : _q130 = do_valueize (valueize, _q130);
8909 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
8910 : 0 : _q131 = do_valueize (valueize, _q131);
8911 : 0 : if (tree_swap_operands_p (_q130, _q131))
8912 : 0 : std::swap (_q130, _q131);
8913 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
8914 : : {
8915 : 0 : if ((_q131 == _q100 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q100, 0) && types_match (_q131, _q100)))
8916 : : {
8917 : 0 : if (integer_zerop (_q21))
8918 : : {
8919 : 0 : if ((_p1 == _q41 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q41, 0) && types_match (_p1, _q41)))
8920 : : {
8921 : 0 : switch (TREE_CODE (_p2))
8922 : : {
8923 : 0 : case SSA_NAME:
8924 : 0 : if (gimple *_d8 = get_def (valueize, _p2))
8925 : : {
8926 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
8927 : 0 : switch (gimple_assign_rhs_code (_a8))
8928 : : {
8929 : 0 : case BIT_XOR_EXPR:
8930 : 0 : {
8931 : 0 : tree _q180 = gimple_assign_rhs1 (_a8);
8932 : 0 : _q180 = do_valueize (valueize, _q180);
8933 : 0 : tree _q181 = gimple_assign_rhs2 (_a8);
8934 : 0 : _q181 = do_valueize (valueize, _q181);
8935 : 0 : if (tree_swap_operands_p (_q180, _q181))
8936 : 0 : std::swap (_q180, _q181);
8937 : 0 : switch (TREE_CODE (_q180))
8938 : : {
8939 : 0 : case SSA_NAME:
8940 : 0 : if (gimple *_d9 = get_def (valueize, _q180))
8941 : : {
8942 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
8943 : 0 : switch (gimple_assign_rhs_code (_a9))
8944 : : {
8945 : 0 : case NEGATE_EXPR:
8946 : 0 : {
8947 : 0 : tree _q190 = gimple_assign_rhs1 (_a9);
8948 : 0 : _q190 = do_valueize (valueize, _q190);
8949 : 0 : switch (TREE_CODE (_q190))
8950 : : {
8951 : 0 : case SSA_NAME:
8952 : 0 : if (gimple *_d10 = get_def (valueize, _q190))
8953 : : {
8954 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
8955 : 0 : switch (gimple_assign_rhs_code (_a10))
8956 : : {
8957 : 0 : CASE_CONVERT:
8958 : 0 : {
8959 : 0 : tree _q200 = gimple_assign_rhs1 (_a10);
8960 : 0 : _q200 = do_valueize (valueize, _q200);
8961 : 0 : switch (TREE_CODE (_q200))
8962 : : {
8963 : 0 : case SSA_NAME:
8964 : 0 : if (gimple *_d11 = get_def (valueize, _q200))
8965 : : {
8966 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
8967 : 0 : switch (gimple_assign_rhs_code (_a11))
8968 : : {
8969 : 0 : case LT_EXPR:
8970 : 0 : {
8971 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
8972 : 0 : _q210 = do_valueize (valueize, _q210);
8973 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
8974 : 0 : _q211 = do_valueize (valueize, _q211);
8975 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
8976 : : {
8977 : 0 : if (integer_zerop (_q211))
8978 : : {
8979 : 0 : if (gimple_max_value (_q181, valueize))
8980 : : {
8981 : 0 : {
8982 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
8983 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
8984 : : )
8985 : : {
8986 : 0 : {
8987 : 0 : res_ops[0] = captures[0];
8988 : 0 : res_ops[1] = captures[1];
8989 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
8990 : 0 : return true;
8991 : : }
8992 : : }
8993 : : }
8994 : : }
8995 : : }
8996 : : }
8997 : : break;
8998 : : }
8999 : : default:;
9000 : : }
9001 : : }
9002 : : break;
9003 : : default:;
9004 : : }
9005 : : break;
9006 : : }
9007 : : default:;
9008 : : }
9009 : : }
9010 : : break;
9011 : : default:;
9012 : : }
9013 : : break;
9014 : : }
9015 : : default:;
9016 : : }
9017 : : }
9018 : : break;
9019 : 0 : default:;
9020 : : }
9021 : 0 : if (gimple_max_value (_q180, valueize))
9022 : : {
9023 : 0 : switch (TREE_CODE (_q181))
9024 : : {
9025 : 0 : case SSA_NAME:
9026 : 0 : if (gimple *_d9 = get_def (valueize, _q181))
9027 : : {
9028 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
9029 : 0 : switch (gimple_assign_rhs_code (_a9))
9030 : : {
9031 : 0 : case NEGATE_EXPR:
9032 : 0 : {
9033 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
9034 : 0 : _q200 = do_valueize (valueize, _q200);
9035 : 0 : switch (TREE_CODE (_q200))
9036 : : {
9037 : 0 : case SSA_NAME:
9038 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
9039 : : {
9040 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
9041 : 0 : switch (gimple_assign_rhs_code (_a10))
9042 : : {
9043 : 0 : CASE_CONVERT:
9044 : 0 : {
9045 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
9046 : 0 : _q210 = do_valueize (valueize, _q210);
9047 : 0 : switch (TREE_CODE (_q210))
9048 : : {
9049 : 0 : case SSA_NAME:
9050 : 0 : if (gimple *_d11 = get_def (valueize, _q210))
9051 : : {
9052 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
9053 : 0 : switch (gimple_assign_rhs_code (_a11))
9054 : : {
9055 : 0 : case LT_EXPR:
9056 : 0 : {
9057 : 0 : tree _q220 = gimple_assign_rhs1 (_a11);
9058 : 0 : _q220 = do_valueize (valueize, _q220);
9059 : 0 : tree _q221 = gimple_assign_rhs2 (_a11);
9060 : 0 : _q221 = do_valueize (valueize, _q221);
9061 : 0 : if ((_q220 == _q40 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q40, 0) && types_match (_q220, _q40)))
9062 : : {
9063 : 0 : if (integer_zerop (_q221))
9064 : : {
9065 : 0 : {
9066 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
9067 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
9068 : : )
9069 : : {
9070 : 0 : {
9071 : 0 : res_ops[0] = captures[0];
9072 : 0 : res_ops[1] = captures[1];
9073 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
9074 : 0 : return true;
9075 : : }
9076 : : }
9077 : : }
9078 : : }
9079 : : }
9080 : : break;
9081 : : }
9082 : : default:;
9083 : : }
9084 : : }
9085 : : break;
9086 : : default:;
9087 : : }
9088 : : break;
9089 : : }
9090 : : default:;
9091 : : }
9092 : : }
9093 : : break;
9094 : : default:;
9095 : : }
9096 : : break;
9097 : : }
9098 : : default:;
9099 : : }
9100 : : }
9101 : : break;
9102 : : default:;
9103 : : }
9104 : : }
9105 : 0 : break;
9106 : : }
9107 : : default:;
9108 : : }
9109 : : }
9110 : : break;
9111 : : default:;
9112 : : }
9113 : : }
9114 : : }
9115 : : }
9116 : : }
9117 : 0 : if ((_q130 == _q100 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q100, 0) && types_match (_q130, _q100)))
9118 : : {
9119 : 0 : if ((_q131 == _q40 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q40, 0) && types_match (_q131, _q40)))
9120 : : {
9121 : 0 : if (integer_zerop (_q21))
9122 : : {
9123 : 0 : if ((_p1 == _q41 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q41, 0) && types_match (_p1, _q41)))
9124 : : {
9125 : 0 : switch (TREE_CODE (_p2))
9126 : : {
9127 : 0 : case SSA_NAME:
9128 : 0 : if (gimple *_d8 = get_def (valueize, _p2))
9129 : : {
9130 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
9131 : 0 : switch (gimple_assign_rhs_code (_a8))
9132 : : {
9133 : 0 : case BIT_XOR_EXPR:
9134 : 0 : {
9135 : 0 : tree _q180 = gimple_assign_rhs1 (_a8);
9136 : 0 : _q180 = do_valueize (valueize, _q180);
9137 : 0 : tree _q181 = gimple_assign_rhs2 (_a8);
9138 : 0 : _q181 = do_valueize (valueize, _q181);
9139 : 0 : if (tree_swap_operands_p (_q180, _q181))
9140 : 0 : std::swap (_q180, _q181);
9141 : 0 : switch (TREE_CODE (_q180))
9142 : : {
9143 : 0 : case SSA_NAME:
9144 : 0 : if (gimple *_d9 = get_def (valueize, _q180))
9145 : : {
9146 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
9147 : 0 : switch (gimple_assign_rhs_code (_a9))
9148 : : {
9149 : 0 : case NEGATE_EXPR:
9150 : 0 : {
9151 : 0 : tree _q190 = gimple_assign_rhs1 (_a9);
9152 : 0 : _q190 = do_valueize (valueize, _q190);
9153 : 0 : switch (TREE_CODE (_q190))
9154 : : {
9155 : 0 : case SSA_NAME:
9156 : 0 : if (gimple *_d10 = get_def (valueize, _q190))
9157 : : {
9158 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
9159 : 0 : switch (gimple_assign_rhs_code (_a10))
9160 : : {
9161 : 0 : CASE_CONVERT:
9162 : 0 : {
9163 : 0 : tree _q200 = gimple_assign_rhs1 (_a10);
9164 : 0 : _q200 = do_valueize (valueize, _q200);
9165 : 0 : switch (TREE_CODE (_q200))
9166 : : {
9167 : 0 : case SSA_NAME:
9168 : 0 : if (gimple *_d11 = get_def (valueize, _q200))
9169 : : {
9170 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
9171 : 0 : switch (gimple_assign_rhs_code (_a11))
9172 : : {
9173 : 0 : case LT_EXPR:
9174 : 0 : {
9175 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
9176 : 0 : _q210 = do_valueize (valueize, _q210);
9177 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
9178 : 0 : _q211 = do_valueize (valueize, _q211);
9179 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
9180 : : {
9181 : 0 : if (integer_zerop (_q211))
9182 : : {
9183 : 0 : if (gimple_max_value (_q181, valueize))
9184 : : {
9185 : 0 : {
9186 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
9187 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
9188 : : )
9189 : : {
9190 : 0 : {
9191 : 0 : res_ops[0] = captures[0];
9192 : 0 : res_ops[1] = captures[1];
9193 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
9194 : 0 : return true;
9195 : : }
9196 : : }
9197 : : }
9198 : : }
9199 : : }
9200 : : }
9201 : : break;
9202 : : }
9203 : : default:;
9204 : : }
9205 : : }
9206 : : break;
9207 : : default:;
9208 : : }
9209 : : break;
9210 : : }
9211 : : default:;
9212 : : }
9213 : : }
9214 : : break;
9215 : : default:;
9216 : : }
9217 : : break;
9218 : : }
9219 : : default:;
9220 : : }
9221 : : }
9222 : : break;
9223 : 0 : default:;
9224 : : }
9225 : 0 : if (gimple_max_value (_q180, valueize))
9226 : : {
9227 : 0 : switch (TREE_CODE (_q181))
9228 : : {
9229 : 0 : case SSA_NAME:
9230 : 0 : if (gimple *_d9 = get_def (valueize, _q181))
9231 : : {
9232 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
9233 : 0 : switch (gimple_assign_rhs_code (_a9))
9234 : : {
9235 : 0 : case NEGATE_EXPR:
9236 : 0 : {
9237 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
9238 : 0 : _q200 = do_valueize (valueize, _q200);
9239 : 0 : switch (TREE_CODE (_q200))
9240 : : {
9241 : 0 : case SSA_NAME:
9242 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
9243 : : {
9244 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
9245 : 0 : switch (gimple_assign_rhs_code (_a10))
9246 : : {
9247 : 0 : CASE_CONVERT:
9248 : 0 : {
9249 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
9250 : 0 : _q210 = do_valueize (valueize, _q210);
9251 : 0 : switch (TREE_CODE (_q210))
9252 : : {
9253 : 0 : case SSA_NAME:
9254 : 0 : if (gimple *_d11 = get_def (valueize, _q210))
9255 : : {
9256 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
9257 : 0 : switch (gimple_assign_rhs_code (_a11))
9258 : : {
9259 : 0 : case LT_EXPR:
9260 : 0 : {
9261 : 0 : tree _q220 = gimple_assign_rhs1 (_a11);
9262 : 0 : _q220 = do_valueize (valueize, _q220);
9263 : 0 : tree _q221 = gimple_assign_rhs2 (_a11);
9264 : 0 : _q221 = do_valueize (valueize, _q221);
9265 : 0 : if ((_q220 == _q40 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q40, 0) && types_match (_q220, _q40)))
9266 : : {
9267 : 0 : if (integer_zerop (_q221))
9268 : : {
9269 : 0 : {
9270 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
9271 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
9272 : : )
9273 : : {
9274 : 0 : {
9275 : 0 : res_ops[0] = captures[0];
9276 : 0 : res_ops[1] = captures[1];
9277 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
9278 : 0 : return true;
9279 : : }
9280 : : }
9281 : : }
9282 : : }
9283 : : }
9284 : : break;
9285 : : }
9286 : : default:;
9287 : : }
9288 : : }
9289 : : break;
9290 : : default:;
9291 : : }
9292 : : break;
9293 : : }
9294 : : default:;
9295 : : }
9296 : : }
9297 : : break;
9298 : : default:;
9299 : : }
9300 : : break;
9301 : : }
9302 : : default:;
9303 : : }
9304 : : }
9305 : : break;
9306 : : default:;
9307 : : }
9308 : : }
9309 : 0 : break;
9310 : : }
9311 : : default:;
9312 : : }
9313 : : }
9314 : : break;
9315 : : default:;
9316 : : }
9317 : : }
9318 : : }
9319 : : }
9320 : : }
9321 : 0 : break;
9322 : : }
9323 : : default:;
9324 : : }
9325 : : }
9326 : : break;
9327 : : default:;
9328 : : }
9329 : : break;
9330 : : }
9331 : : default:;
9332 : : }
9333 : : }
9334 : : break;
9335 : : default:;
9336 : : }
9337 : : }
9338 : : }
9339 : : }
9340 : : }
9341 : : }
9342 : 0 : break;
9343 : : }
9344 : : default:;
9345 : : }
9346 : : }
9347 : : break;
9348 : : default:;
9349 : : }
9350 : : }
9351 : : }
9352 : 0 : break;
9353 : : }
9354 : 0 : case BIT_NOT_EXPR:
9355 : 0 : {
9356 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
9357 : 0 : _q40 = do_valueize (valueize, _q40);
9358 : 0 : switch (TREE_CODE (_q40))
9359 : : {
9360 : 0 : case SSA_NAME:
9361 : 0 : if (gimple *_d5 = get_def (valueize, _q40))
9362 : : {
9363 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
9364 : 0 : switch (gimple_assign_rhs_code (_a5))
9365 : : {
9366 : 0 : case BIT_XOR_EXPR:
9367 : 0 : {
9368 : 0 : tree _q50 = gimple_assign_rhs1 (_a5);
9369 : 0 : _q50 = do_valueize (valueize, _q50);
9370 : 0 : tree _q51 = gimple_assign_rhs2 (_a5);
9371 : 0 : _q51 = do_valueize (valueize, _q51);
9372 : 0 : if (tree_swap_operands_p (_q50, _q51))
9373 : 0 : std::swap (_q50, _q51);
9374 : 0 : switch (TREE_CODE (_q31))
9375 : : {
9376 : 0 : case SSA_NAME:
9377 : 0 : if (gimple *_d6 = get_def (valueize, _q31))
9378 : : {
9379 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
9380 : 0 : switch (gimple_assign_rhs_code (_a6))
9381 : : {
9382 : 0 : case BIT_XOR_EXPR:
9383 : 0 : {
9384 : 0 : tree _q80 = gimple_assign_rhs1 (_a6);
9385 : 0 : _q80 = do_valueize (valueize, _q80);
9386 : 0 : tree _q81 = gimple_assign_rhs2 (_a6);
9387 : 0 : _q81 = do_valueize (valueize, _q81);
9388 : 0 : if (tree_swap_operands_p (_q80, _q81))
9389 : 0 : std::swap (_q80, _q81);
9390 : 0 : if ((_q80 == _q50 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q50, 0) && types_match (_q80, _q50)))
9391 : : {
9392 : 0 : {
9393 : 0 : tree _q81_pops[1];
9394 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
9395 : : {
9396 : 0 : tree _q100 = _q81_pops[0];
9397 : 0 : switch (TREE_CODE (_q100))
9398 : : {
9399 : 0 : case SSA_NAME:
9400 : 0 : if (gimple *_d7 = get_def (valueize, _q100))
9401 : : {
9402 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
9403 : 0 : switch (gimple_assign_rhs_code (_a7))
9404 : : {
9405 : 0 : case PLUS_EXPR:
9406 : 0 : {
9407 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
9408 : 0 : _q110 = do_valueize (valueize, _q110);
9409 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
9410 : 0 : _q111 = do_valueize (valueize, _q111);
9411 : 0 : if (tree_swap_operands_p (_q110, _q111))
9412 : 0 : std::swap (_q110, _q111);
9413 : 0 : {
9414 : 0 : tree _q110_pops[1];
9415 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
9416 : : {
9417 : 0 : tree _q120 = _q110_pops[0];
9418 : 0 : if ((_q120 == _q50 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q50, 0) && types_match (_q120, _q50)))
9419 : : {
9420 : 0 : {
9421 : 0 : tree _q111_pops[1];
9422 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
9423 : : {
9424 : 0 : tree _q140 = _q111_pops[0];
9425 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
9426 : : {
9427 : 0 : if (integer_zerop (_q21))
9428 : : {
9429 : 0 : if ((_p1 == _q81 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q81, 0) && types_match (_p1, _q81)))
9430 : : {
9431 : 0 : switch (TREE_CODE (_p2))
9432 : : {
9433 : 0 : case SSA_NAME:
9434 : 0 : if (gimple *_d8 = get_def (valueize, _p2))
9435 : : {
9436 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
9437 : 0 : switch (gimple_assign_rhs_code (_a8))
9438 : : {
9439 : 0 : case BIT_XOR_EXPR:
9440 : 0 : {
9441 : 0 : tree _q180 = gimple_assign_rhs1 (_a8);
9442 : 0 : _q180 = do_valueize (valueize, _q180);
9443 : 0 : tree _q181 = gimple_assign_rhs2 (_a8);
9444 : 0 : _q181 = do_valueize (valueize, _q181);
9445 : 0 : if (tree_swap_operands_p (_q180, _q181))
9446 : 0 : std::swap (_q180, _q181);
9447 : 0 : switch (TREE_CODE (_q180))
9448 : : {
9449 : 0 : case SSA_NAME:
9450 : 0 : if (gimple *_d9 = get_def (valueize, _q180))
9451 : : {
9452 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
9453 : 0 : switch (gimple_assign_rhs_code (_a9))
9454 : : {
9455 : 0 : case NEGATE_EXPR:
9456 : 0 : {
9457 : 0 : tree _q190 = gimple_assign_rhs1 (_a9);
9458 : 0 : _q190 = do_valueize (valueize, _q190);
9459 : 0 : switch (TREE_CODE (_q190))
9460 : : {
9461 : 0 : case SSA_NAME:
9462 : 0 : if (gimple *_d10 = get_def (valueize, _q190))
9463 : : {
9464 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
9465 : 0 : switch (gimple_assign_rhs_code (_a10))
9466 : : {
9467 : 0 : CASE_CONVERT:
9468 : 0 : {
9469 : 0 : tree _q200 = gimple_assign_rhs1 (_a10);
9470 : 0 : _q200 = do_valueize (valueize, _q200);
9471 : 0 : switch (TREE_CODE (_q200))
9472 : : {
9473 : 0 : case SSA_NAME:
9474 : 0 : if (gimple *_d11 = get_def (valueize, _q200))
9475 : : {
9476 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
9477 : 0 : switch (gimple_assign_rhs_code (_a11))
9478 : : {
9479 : 0 : case LT_EXPR:
9480 : 0 : {
9481 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
9482 : 0 : _q210 = do_valueize (valueize, _q210);
9483 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
9484 : 0 : _q211 = do_valueize (valueize, _q211);
9485 : 0 : if ((_q210 == _q50 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q50, 0) && types_match (_q210, _q50)))
9486 : : {
9487 : 0 : if (integer_zerop (_q211))
9488 : : {
9489 : 0 : if (gimple_max_value (_q181, valueize))
9490 : : {
9491 : 0 : {
9492 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
9493 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
9494 : : )
9495 : : {
9496 : 0 : {
9497 : 0 : res_ops[0] = captures[0];
9498 : 0 : res_ops[1] = captures[1];
9499 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
9500 : 0 : return true;
9501 : : }
9502 : : }
9503 : : }
9504 : : }
9505 : : }
9506 : : }
9507 : : break;
9508 : : }
9509 : : default:;
9510 : : }
9511 : : }
9512 : : break;
9513 : : default:;
9514 : : }
9515 : : break;
9516 : : }
9517 : : default:;
9518 : : }
9519 : : }
9520 : : break;
9521 : : default:;
9522 : : }
9523 : : break;
9524 : : }
9525 : : default:;
9526 : : }
9527 : : }
9528 : : break;
9529 : 0 : default:;
9530 : : }
9531 : 0 : if (gimple_max_value (_q180, valueize))
9532 : : {
9533 : 0 : switch (TREE_CODE (_q181))
9534 : : {
9535 : 0 : case SSA_NAME:
9536 : 0 : if (gimple *_d9 = get_def (valueize, _q181))
9537 : : {
9538 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
9539 : 0 : switch (gimple_assign_rhs_code (_a9))
9540 : : {
9541 : 0 : case NEGATE_EXPR:
9542 : 0 : {
9543 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
9544 : 0 : _q200 = do_valueize (valueize, _q200);
9545 : 0 : switch (TREE_CODE (_q200))
9546 : : {
9547 : 0 : case SSA_NAME:
9548 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
9549 : : {
9550 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
9551 : 0 : switch (gimple_assign_rhs_code (_a10))
9552 : : {
9553 : 0 : CASE_CONVERT:
9554 : 0 : {
9555 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
9556 : 0 : _q210 = do_valueize (valueize, _q210);
9557 : 0 : switch (TREE_CODE (_q210))
9558 : : {
9559 : 0 : case SSA_NAME:
9560 : 0 : if (gimple *_d11 = get_def (valueize, _q210))
9561 : : {
9562 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
9563 : 0 : switch (gimple_assign_rhs_code (_a11))
9564 : : {
9565 : 0 : case LT_EXPR:
9566 : 0 : {
9567 : 0 : tree _q220 = gimple_assign_rhs1 (_a11);
9568 : 0 : _q220 = do_valueize (valueize, _q220);
9569 : 0 : tree _q221 = gimple_assign_rhs2 (_a11);
9570 : 0 : _q221 = do_valueize (valueize, _q221);
9571 : 0 : if ((_q220 == _q50 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q50, 0) && types_match (_q220, _q50)))
9572 : : {
9573 : 0 : if (integer_zerop (_q221))
9574 : : {
9575 : 0 : {
9576 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
9577 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
9578 : : )
9579 : : {
9580 : 0 : {
9581 : 0 : res_ops[0] = captures[0];
9582 : 0 : res_ops[1] = captures[1];
9583 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
9584 : 0 : return true;
9585 : : }
9586 : : }
9587 : : }
9588 : : }
9589 : : }
9590 : : break;
9591 : : }
9592 : : default:;
9593 : : }
9594 : : }
9595 : : break;
9596 : : default:;
9597 : : }
9598 : : break;
9599 : : }
9600 : : default:;
9601 : : }
9602 : : }
9603 : : break;
9604 : : default:;
9605 : : }
9606 : : break;
9607 : : }
9608 : : default:;
9609 : : }
9610 : : }
9611 : : break;
9612 : : default:;
9613 : : }
9614 : : }
9615 : 0 : break;
9616 : : }
9617 : : default:;
9618 : : }
9619 : : }
9620 : : break;
9621 : : default:;
9622 : : }
9623 : : }
9624 : : }
9625 : : }
9626 : : }
9627 : : }
9628 : : }
9629 : : }
9630 : : }
9631 : 0 : break;
9632 : : }
9633 : : default:;
9634 : : }
9635 : : }
9636 : : break;
9637 : : default:;
9638 : : }
9639 : : }
9640 : : }
9641 : : }
9642 : 0 : if ((_q80 == _q51 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q51, 0) && types_match (_q80, _q51)))
9643 : : {
9644 : 0 : {
9645 : 0 : tree _q81_pops[1];
9646 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
9647 : : {
9648 : 0 : tree _q100 = _q81_pops[0];
9649 : 0 : switch (TREE_CODE (_q100))
9650 : : {
9651 : 0 : case SSA_NAME:
9652 : 0 : if (gimple *_d7 = get_def (valueize, _q100))
9653 : : {
9654 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
9655 : 0 : switch (gimple_assign_rhs_code (_a7))
9656 : : {
9657 : 0 : case PLUS_EXPR:
9658 : 0 : {
9659 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
9660 : 0 : _q110 = do_valueize (valueize, _q110);
9661 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
9662 : 0 : _q111 = do_valueize (valueize, _q111);
9663 : 0 : if (tree_swap_operands_p (_q110, _q111))
9664 : 0 : std::swap (_q110, _q111);
9665 : 0 : {
9666 : 0 : tree _q110_pops[1];
9667 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
9668 : : {
9669 : 0 : tree _q120 = _q110_pops[0];
9670 : 0 : if ((_q120 == _q51 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q51, 0) && types_match (_q120, _q51)))
9671 : : {
9672 : 0 : {
9673 : 0 : tree _q111_pops[1];
9674 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
9675 : : {
9676 : 0 : tree _q140 = _q111_pops[0];
9677 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
9678 : : {
9679 : 0 : if (integer_zerop (_q21))
9680 : : {
9681 : 0 : if ((_p1 == _q81 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q81, 0) && types_match (_p1, _q81)))
9682 : : {
9683 : 0 : switch (TREE_CODE (_p2))
9684 : : {
9685 : 0 : case SSA_NAME:
9686 : 0 : if (gimple *_d8 = get_def (valueize, _p2))
9687 : : {
9688 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
9689 : 0 : switch (gimple_assign_rhs_code (_a8))
9690 : : {
9691 : 0 : case BIT_XOR_EXPR:
9692 : 0 : {
9693 : 0 : tree _q180 = gimple_assign_rhs1 (_a8);
9694 : 0 : _q180 = do_valueize (valueize, _q180);
9695 : 0 : tree _q181 = gimple_assign_rhs2 (_a8);
9696 : 0 : _q181 = do_valueize (valueize, _q181);
9697 : 0 : if (tree_swap_operands_p (_q180, _q181))
9698 : 0 : std::swap (_q180, _q181);
9699 : 0 : switch (TREE_CODE (_q180))
9700 : : {
9701 : 0 : case SSA_NAME:
9702 : 0 : if (gimple *_d9 = get_def (valueize, _q180))
9703 : : {
9704 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
9705 : 0 : switch (gimple_assign_rhs_code (_a9))
9706 : : {
9707 : 0 : case NEGATE_EXPR:
9708 : 0 : {
9709 : 0 : tree _q190 = gimple_assign_rhs1 (_a9);
9710 : 0 : _q190 = do_valueize (valueize, _q190);
9711 : 0 : switch (TREE_CODE (_q190))
9712 : : {
9713 : 0 : case SSA_NAME:
9714 : 0 : if (gimple *_d10 = get_def (valueize, _q190))
9715 : : {
9716 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
9717 : 0 : switch (gimple_assign_rhs_code (_a10))
9718 : : {
9719 : 0 : CASE_CONVERT:
9720 : 0 : {
9721 : 0 : tree _q200 = gimple_assign_rhs1 (_a10);
9722 : 0 : _q200 = do_valueize (valueize, _q200);
9723 : 0 : switch (TREE_CODE (_q200))
9724 : : {
9725 : 0 : case SSA_NAME:
9726 : 0 : if (gimple *_d11 = get_def (valueize, _q200))
9727 : : {
9728 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
9729 : 0 : switch (gimple_assign_rhs_code (_a11))
9730 : : {
9731 : 0 : case LT_EXPR:
9732 : 0 : {
9733 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
9734 : 0 : _q210 = do_valueize (valueize, _q210);
9735 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
9736 : 0 : _q211 = do_valueize (valueize, _q211);
9737 : 0 : if ((_q210 == _q51 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q51, 0) && types_match (_q210, _q51)))
9738 : : {
9739 : 0 : if (integer_zerop (_q211))
9740 : : {
9741 : 0 : if (gimple_max_value (_q181, valueize))
9742 : : {
9743 : 0 : {
9744 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
9745 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
9746 : : )
9747 : : {
9748 : 0 : {
9749 : 0 : res_ops[0] = captures[0];
9750 : 0 : res_ops[1] = captures[1];
9751 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
9752 : 0 : return true;
9753 : : }
9754 : : }
9755 : : }
9756 : : }
9757 : : }
9758 : : }
9759 : : break;
9760 : : }
9761 : : default:;
9762 : : }
9763 : : }
9764 : : break;
9765 : : default:;
9766 : : }
9767 : : break;
9768 : : }
9769 : : default:;
9770 : : }
9771 : : }
9772 : : break;
9773 : : default:;
9774 : : }
9775 : : break;
9776 : : }
9777 : : default:;
9778 : : }
9779 : : }
9780 : : break;
9781 : 0 : default:;
9782 : : }
9783 : 0 : if (gimple_max_value (_q180, valueize))
9784 : : {
9785 : 0 : switch (TREE_CODE (_q181))
9786 : : {
9787 : 0 : case SSA_NAME:
9788 : 0 : if (gimple *_d9 = get_def (valueize, _q181))
9789 : : {
9790 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
9791 : 0 : switch (gimple_assign_rhs_code (_a9))
9792 : : {
9793 : 0 : case NEGATE_EXPR:
9794 : 0 : {
9795 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
9796 : 0 : _q200 = do_valueize (valueize, _q200);
9797 : 0 : switch (TREE_CODE (_q200))
9798 : : {
9799 : 0 : case SSA_NAME:
9800 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
9801 : : {
9802 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
9803 : 0 : switch (gimple_assign_rhs_code (_a10))
9804 : : {
9805 : 0 : CASE_CONVERT:
9806 : 0 : {
9807 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
9808 : 0 : _q210 = do_valueize (valueize, _q210);
9809 : 0 : switch (TREE_CODE (_q210))
9810 : : {
9811 : 0 : case SSA_NAME:
9812 : 0 : if (gimple *_d11 = get_def (valueize, _q210))
9813 : : {
9814 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
9815 : 0 : switch (gimple_assign_rhs_code (_a11))
9816 : : {
9817 : 0 : case LT_EXPR:
9818 : 0 : {
9819 : 0 : tree _q220 = gimple_assign_rhs1 (_a11);
9820 : 0 : _q220 = do_valueize (valueize, _q220);
9821 : 0 : tree _q221 = gimple_assign_rhs2 (_a11);
9822 : 0 : _q221 = do_valueize (valueize, _q221);
9823 : 0 : if ((_q220 == _q51 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q51, 0) && types_match (_q220, _q51)))
9824 : : {
9825 : 0 : if (integer_zerop (_q221))
9826 : : {
9827 : 0 : {
9828 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
9829 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
9830 : : )
9831 : : {
9832 : 0 : {
9833 : 0 : res_ops[0] = captures[0];
9834 : 0 : res_ops[1] = captures[1];
9835 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
9836 : 0 : return true;
9837 : : }
9838 : : }
9839 : : }
9840 : : }
9841 : : }
9842 : : break;
9843 : : }
9844 : : default:;
9845 : : }
9846 : : }
9847 : : break;
9848 : : default:;
9849 : : }
9850 : : break;
9851 : : }
9852 : : default:;
9853 : : }
9854 : : }
9855 : : break;
9856 : : default:;
9857 : : }
9858 : : break;
9859 : : }
9860 : : default:;
9861 : : }
9862 : : }
9863 : : break;
9864 : : default:;
9865 : : }
9866 : : }
9867 : 0 : break;
9868 : : }
9869 : : default:;
9870 : : }
9871 : : }
9872 : : break;
9873 : : default:;
9874 : : }
9875 : : }
9876 : : }
9877 : : }
9878 : : }
9879 : : }
9880 : : }
9881 : : }
9882 : : }
9883 : 0 : break;
9884 : : }
9885 : : default:;
9886 : : }
9887 : : }
9888 : : break;
9889 : : default:;
9890 : : }
9891 : : }
9892 : : }
9893 : : }
9894 : 3365690 : break;
9895 : : }
9896 : : default:;
9897 : : }
9898 : : }
9899 : : break;
9900 : : default:;
9901 : : }
9902 : 3365690 : break;
9903 : : }
9904 : : default:;
9905 : : }
9906 : : }
9907 : : break;
9908 : : default:;
9909 : : }
9910 : : break;
9911 : : }
9912 : : default:;
9913 : : }
9914 : : }
9915 : : break;
9916 : : default:;
9917 : : }
9918 : 3365690 : break;
9919 : : }
9920 : : default:;
9921 : : }
9922 : : }
9923 : : break;
9924 : : default:;
9925 : : }
9926 : : break;
9927 : : }
9928 : 0 : case BIT_AND_EXPR:
9929 : 0 : {
9930 : 0 : tree _q20 = gimple_assign_rhs1 (_a2);
9931 : 0 : _q20 = do_valueize (valueize, _q20);
9932 : 0 : tree _q21 = gimple_assign_rhs2 (_a2);
9933 : 0 : _q21 = do_valueize (valueize, _q21);
9934 : 0 : if (tree_swap_operands_p (_q20, _q21))
9935 : 0 : std::swap (_q20, _q21);
9936 : 0 : switch (TREE_CODE (_q20))
9937 : : {
9938 : 0 : case SSA_NAME:
9939 : 0 : if (gimple *_d3 = get_def (valueize, _q20))
9940 : : {
9941 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
9942 : 0 : switch (gimple_assign_rhs_code (_a3))
9943 : : {
9944 : 0 : case LT_EXPR:
9945 : 0 : {
9946 : 0 : tree _q30 = gimple_assign_rhs1 (_a3);
9947 : 0 : _q30 = do_valueize (valueize, _q30);
9948 : 0 : tree _q31 = gimple_assign_rhs2 (_a3);
9949 : 0 : _q31 = do_valueize (valueize, _q31);
9950 : 0 : switch (TREE_CODE (_q30))
9951 : : {
9952 : 0 : case SSA_NAME:
9953 : 0 : if (gimple *_d4 = get_def (valueize, _q30))
9954 : : {
9955 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
9956 : 0 : switch (gimple_assign_rhs_code (_a4))
9957 : : {
9958 : 0 : case BIT_XOR_EXPR:
9959 : 0 : {
9960 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
9961 : 0 : _q40 = do_valueize (valueize, _q40);
9962 : 0 : tree _q41 = gimple_assign_rhs2 (_a4);
9963 : 0 : _q41 = do_valueize (valueize, _q41);
9964 : 0 : if (tree_swap_operands_p (_q40, _q41))
9965 : 0 : std::swap (_q40, _q41);
9966 : 0 : {
9967 : 0 : tree _q41_pops[1];
9968 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
9969 : : {
9970 : 0 : tree _q60 = _q41_pops[0];
9971 : 0 : switch (TREE_CODE (_q60))
9972 : : {
9973 : 0 : case SSA_NAME:
9974 : 0 : if (gimple *_d5 = get_def (valueize, _q60))
9975 : : {
9976 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
9977 : 0 : switch (gimple_assign_rhs_code (_a5))
9978 : : {
9979 : 0 : case PLUS_EXPR:
9980 : 0 : {
9981 : 0 : tree _q70 = gimple_assign_rhs1 (_a5);
9982 : 0 : _q70 = do_valueize (valueize, _q70);
9983 : 0 : tree _q71 = gimple_assign_rhs2 (_a5);
9984 : 0 : _q71 = do_valueize (valueize, _q71);
9985 : 0 : if (tree_swap_operands_p (_q70, _q71))
9986 : 0 : std::swap (_q70, _q71);
9987 : 0 : {
9988 : 0 : tree _q70_pops[1];
9989 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
9990 : : {
9991 : 0 : tree _q80 = _q70_pops[0];
9992 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
9993 : : {
9994 : 0 : {
9995 : 0 : tree _q71_pops[1];
9996 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
9997 : : {
9998 : 0 : tree _q100 = _q71_pops[0];
9999 : 0 : if (integer_zerop (_q31))
10000 : : {
10001 : 0 : switch (TREE_CODE (_q21))
10002 : : {
10003 : 0 : case SSA_NAME:
10004 : 0 : if (gimple *_d6 = get_def (valueize, _q21))
10005 : : {
10006 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
10007 : 0 : switch (gimple_assign_rhs_code (_a6))
10008 : : {
10009 : 0 : case GE_EXPR:
10010 : 0 : {
10011 : 0 : tree _q130 = gimple_assign_rhs1 (_a6);
10012 : 0 : _q130 = do_valueize (valueize, _q130);
10013 : 0 : tree _q131 = gimple_assign_rhs2 (_a6);
10014 : 0 : _q131 = do_valueize (valueize, _q131);
10015 : 0 : switch (TREE_CODE (_q130))
10016 : : {
10017 : 0 : case SSA_NAME:
10018 : 0 : if (gimple *_d7 = get_def (valueize, _q130))
10019 : : {
10020 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
10021 : 0 : switch (gimple_assign_rhs_code (_a7))
10022 : : {
10023 : 0 : case BIT_XOR_EXPR:
10024 : 0 : {
10025 : 0 : tree _q140 = gimple_assign_rhs1 (_a7);
10026 : 0 : _q140 = do_valueize (valueize, _q140);
10027 : 0 : tree _q141 = gimple_assign_rhs2 (_a7);
10028 : 0 : _q141 = do_valueize (valueize, _q141);
10029 : 0 : if (tree_swap_operands_p (_q140, _q141))
10030 : 0 : std::swap (_q140, _q141);
10031 : 0 : if ((_q140 == _q40 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q40, 0) && types_match (_q140, _q40)))
10032 : : {
10033 : 0 : if ((_q141 == _q100 && ! TREE_SIDE_EFFECTS (_q141)) || (operand_equal_p (_q141, _q100, 0) && types_match (_q141, _q100)))
10034 : : {
10035 : 0 : if (integer_zerop (_q131))
10036 : : {
10037 : 0 : {
10038 : 0 : tree _p1_pops[1];
10039 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10040 : : {
10041 : 0 : tree _q180 = _p1_pops[0];
10042 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
10043 : : {
10044 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
10045 : : {
10046 : 0 : {
10047 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
10048 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10049 : : )
10050 : : {
10051 : 0 : {
10052 : 0 : res_ops[0] = captures[0];
10053 : 0 : res_ops[1] = captures[1];
10054 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
10055 : 0 : return true;
10056 : : }
10057 : : }
10058 : : }
10059 : : }
10060 : : }
10061 : : }
10062 : : }
10063 : : }
10064 : : }
10065 : : }
10066 : 0 : if ((_q140 == _q100 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q100, 0) && types_match (_q140, _q100)))
10067 : : {
10068 : 0 : if ((_q141 == _q40 && ! TREE_SIDE_EFFECTS (_q141)) || (operand_equal_p (_q141, _q40, 0) && types_match (_q141, _q40)))
10069 : : {
10070 : 0 : if (integer_zerop (_q131))
10071 : : {
10072 : 0 : {
10073 : 0 : tree _p1_pops[1];
10074 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10075 : : {
10076 : 0 : tree _q180 = _p1_pops[0];
10077 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
10078 : : {
10079 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
10080 : : {
10081 : 0 : {
10082 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
10083 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10084 : : )
10085 : : {
10086 : 0 : {
10087 : 0 : res_ops[0] = captures[0];
10088 : 0 : res_ops[1] = captures[1];
10089 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
10090 : 0 : return true;
10091 : : }
10092 : : }
10093 : : }
10094 : : }
10095 : : }
10096 : : }
10097 : : }
10098 : : }
10099 : : }
10100 : : }
10101 : 0 : break;
10102 : : }
10103 : : default:;
10104 : : }
10105 : : }
10106 : : break;
10107 : : default:;
10108 : : }
10109 : : break;
10110 : : }
10111 : 0 : case BIT_NOT_EXPR:
10112 : 0 : {
10113 : 0 : tree _q130 = gimple_assign_rhs1 (_a6);
10114 : 0 : _q130 = do_valueize (valueize, _q130);
10115 : 0 : switch (TREE_CODE (_q130))
10116 : : {
10117 : 0 : case SSA_NAME:
10118 : 0 : if (gimple *_d7 = get_def (valueize, _q130))
10119 : : {
10120 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
10121 : 0 : switch (gimple_assign_rhs_code (_a7))
10122 : : {
10123 : 0 : case LT_EXPR:
10124 : 0 : {
10125 : 0 : tree _q140 = gimple_assign_rhs1 (_a7);
10126 : 0 : _q140 = do_valueize (valueize, _q140);
10127 : 0 : tree _q141 = gimple_assign_rhs2 (_a7);
10128 : 0 : _q141 = do_valueize (valueize, _q141);
10129 : 0 : switch (TREE_CODE (_q140))
10130 : : {
10131 : 0 : case SSA_NAME:
10132 : 0 : if (gimple *_d8 = get_def (valueize, _q140))
10133 : : {
10134 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
10135 : 0 : switch (gimple_assign_rhs_code (_a8))
10136 : : {
10137 : 0 : case BIT_XOR_EXPR:
10138 : 0 : {
10139 : 0 : tree _q150 = gimple_assign_rhs1 (_a8);
10140 : 0 : _q150 = do_valueize (valueize, _q150);
10141 : 0 : tree _q151 = gimple_assign_rhs2 (_a8);
10142 : 0 : _q151 = do_valueize (valueize, _q151);
10143 : 0 : if (tree_swap_operands_p (_q150, _q151))
10144 : 0 : std::swap (_q150, _q151);
10145 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
10146 : : {
10147 : 0 : if ((_q151 == _q100 && ! TREE_SIDE_EFFECTS (_q151)) || (operand_equal_p (_q151, _q100, 0) && types_match (_q151, _q100)))
10148 : : {
10149 : 0 : if (integer_zerop (_q141))
10150 : : {
10151 : 0 : {
10152 : 0 : tree _p1_pops[1];
10153 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10154 : : {
10155 : 0 : tree _q190 = _p1_pops[0];
10156 : 0 : if ((_q190 == _q40 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q40, 0) && types_match (_q190, _q40)))
10157 : : {
10158 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
10159 : : {
10160 : 0 : {
10161 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
10162 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10163 : : )
10164 : : {
10165 : 0 : {
10166 : 0 : res_ops[0] = captures[0];
10167 : 0 : res_ops[1] = captures[1];
10168 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
10169 : 0 : return true;
10170 : : }
10171 : : }
10172 : : }
10173 : : }
10174 : : }
10175 : : }
10176 : : }
10177 : : }
10178 : : }
10179 : : }
10180 : 0 : if ((_q150 == _q100 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q100, 0) && types_match (_q150, _q100)))
10181 : : {
10182 : 0 : if ((_q151 == _q40 && ! TREE_SIDE_EFFECTS (_q151)) || (operand_equal_p (_q151, _q40, 0) && types_match (_q151, _q40)))
10183 : : {
10184 : 0 : if (integer_zerop (_q141))
10185 : : {
10186 : 0 : {
10187 : 0 : tree _p1_pops[1];
10188 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10189 : : {
10190 : 0 : tree _q190 = _p1_pops[0];
10191 : 0 : if ((_q190 == _q40 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q40, 0) && types_match (_q190, _q40)))
10192 : : {
10193 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
10194 : : {
10195 : 0 : {
10196 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
10197 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10198 : : )
10199 : : {
10200 : 0 : {
10201 : 0 : res_ops[0] = captures[0];
10202 : 0 : res_ops[1] = captures[1];
10203 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
10204 : 0 : return true;
10205 : : }
10206 : : }
10207 : : }
10208 : : }
10209 : : }
10210 : : }
10211 : : }
10212 : : }
10213 : : }
10214 : : }
10215 : 0 : break;
10216 : : }
10217 : : default:;
10218 : : }
10219 : : }
10220 : : break;
10221 : : default:;
10222 : : }
10223 : : break;
10224 : : }
10225 : : default:;
10226 : : }
10227 : : }
10228 : : break;
10229 : : default:;
10230 : : }
10231 : : break;
10232 : : }
10233 : : default:;
10234 : : }
10235 : : }
10236 : : break;
10237 : : default:;
10238 : : }
10239 : : }
10240 : : }
10241 : : }
10242 : : }
10243 : : }
10244 : : }
10245 : 0 : break;
10246 : : }
10247 : : default:;
10248 : : }
10249 : : }
10250 : : break;
10251 : : default:;
10252 : : }
10253 : : }
10254 : : }
10255 : 0 : break;
10256 : : }
10257 : : default:;
10258 : : }
10259 : : }
10260 : : break;
10261 : : default:;
10262 : : }
10263 : : break;
10264 : : }
10265 : 0 : case GE_EXPR:
10266 : 0 : {
10267 : 0 : tree _q30 = gimple_assign_rhs1 (_a3);
10268 : 0 : _q30 = do_valueize (valueize, _q30);
10269 : 0 : tree _q31 = gimple_assign_rhs2 (_a3);
10270 : 0 : _q31 = do_valueize (valueize, _q31);
10271 : 0 : switch (TREE_CODE (_q30))
10272 : : {
10273 : 0 : case SSA_NAME:
10274 : 0 : if (gimple *_d4 = get_def (valueize, _q30))
10275 : : {
10276 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
10277 : 0 : switch (gimple_assign_rhs_code (_a4))
10278 : : {
10279 : 0 : case BIT_XOR_EXPR:
10280 : 0 : {
10281 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
10282 : 0 : _q40 = do_valueize (valueize, _q40);
10283 : 0 : tree _q41 = gimple_assign_rhs2 (_a4);
10284 : 0 : _q41 = do_valueize (valueize, _q41);
10285 : 0 : if (tree_swap_operands_p (_q40, _q41))
10286 : 0 : std::swap (_q40, _q41);
10287 : 0 : if (integer_zerop (_q31))
10288 : : {
10289 : 0 : switch (TREE_CODE (_q21))
10290 : : {
10291 : 0 : case SSA_NAME:
10292 : 0 : if (gimple *_d5 = get_def (valueize, _q21))
10293 : : {
10294 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
10295 : 0 : switch (gimple_assign_rhs_code (_a5))
10296 : : {
10297 : 0 : case LT_EXPR:
10298 : 0 : {
10299 : 0 : tree _q80 = gimple_assign_rhs1 (_a5);
10300 : 0 : _q80 = do_valueize (valueize, _q80);
10301 : 0 : tree _q81 = gimple_assign_rhs2 (_a5);
10302 : 0 : _q81 = do_valueize (valueize, _q81);
10303 : 0 : switch (TREE_CODE (_q80))
10304 : : {
10305 : 0 : case SSA_NAME:
10306 : 0 : if (gimple *_d6 = get_def (valueize, _q80))
10307 : : {
10308 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
10309 : 0 : switch (gimple_assign_rhs_code (_a6))
10310 : : {
10311 : 0 : case BIT_XOR_EXPR:
10312 : 0 : {
10313 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
10314 : 0 : _q90 = do_valueize (valueize, _q90);
10315 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
10316 : 0 : _q91 = do_valueize (valueize, _q91);
10317 : 0 : if (tree_swap_operands_p (_q90, _q91))
10318 : 0 : std::swap (_q90, _q91);
10319 : 0 : if ((_q90 == _q40 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q40, 0) && types_match (_q90, _q40)))
10320 : : {
10321 : 0 : {
10322 : 0 : tree _q91_pops[1];
10323 : 0 : if (gimple_nop_convert (_q91, _q91_pops, valueize))
10324 : : {
10325 : 0 : tree _q110 = _q91_pops[0];
10326 : 0 : switch (TREE_CODE (_q110))
10327 : : {
10328 : 0 : case SSA_NAME:
10329 : 0 : if (gimple *_d7 = get_def (valueize, _q110))
10330 : : {
10331 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
10332 : 0 : switch (gimple_assign_rhs_code (_a7))
10333 : : {
10334 : 0 : case PLUS_EXPR:
10335 : 0 : {
10336 : 0 : tree _q120 = gimple_assign_rhs1 (_a7);
10337 : 0 : _q120 = do_valueize (valueize, _q120);
10338 : 0 : tree _q121 = gimple_assign_rhs2 (_a7);
10339 : 0 : _q121 = do_valueize (valueize, _q121);
10340 : 0 : if (tree_swap_operands_p (_q120, _q121))
10341 : 0 : std::swap (_q120, _q121);
10342 : 0 : {
10343 : 0 : tree _q120_pops[1];
10344 : 0 : if (gimple_nop_convert (_q120, _q120_pops, valueize))
10345 : : {
10346 : 0 : tree _q130 = _q120_pops[0];
10347 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
10348 : : {
10349 : 0 : {
10350 : 0 : tree _q121_pops[1];
10351 : 0 : if (gimple_nop_convert (_q121, _q121_pops, valueize))
10352 : : {
10353 : 0 : tree _q150 = _q121_pops[0];
10354 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
10355 : : {
10356 : 0 : if (integer_zerop (_q81))
10357 : : {
10358 : 0 : {
10359 : 0 : tree _p1_pops[1];
10360 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10361 : : {
10362 : 0 : tree _q180 = _p1_pops[0];
10363 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
10364 : : {
10365 : 0 : if ((_p2 == _q91 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q91, 0) && types_match (_p2, _q91)))
10366 : : {
10367 : 0 : {
10368 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q41, _q91 };
10369 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10370 : : )
10371 : : {
10372 : 0 : {
10373 : 0 : res_ops[0] = captures[0];
10374 : 0 : res_ops[1] = captures[1];
10375 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
10376 : 0 : return true;
10377 : : }
10378 : : }
10379 : : }
10380 : : }
10381 : : }
10382 : : }
10383 : : }
10384 : : }
10385 : : }
10386 : : }
10387 : : }
10388 : : }
10389 : : }
10390 : : }
10391 : 0 : break;
10392 : : }
10393 : : default:;
10394 : : }
10395 : : }
10396 : : break;
10397 : : default:;
10398 : : }
10399 : : }
10400 : : }
10401 : : }
10402 : 0 : if ((_q90 == _q41 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q41, 0) && types_match (_q90, _q41)))
10403 : : {
10404 : 0 : {
10405 : 0 : tree _q91_pops[1];
10406 : 0 : if (gimple_nop_convert (_q91, _q91_pops, valueize))
10407 : : {
10408 : 0 : tree _q110 = _q91_pops[0];
10409 : 0 : switch (TREE_CODE (_q110))
10410 : : {
10411 : 0 : case SSA_NAME:
10412 : 0 : if (gimple *_d7 = get_def (valueize, _q110))
10413 : : {
10414 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
10415 : 0 : switch (gimple_assign_rhs_code (_a7))
10416 : : {
10417 : 0 : case PLUS_EXPR:
10418 : 0 : {
10419 : 0 : tree _q120 = gimple_assign_rhs1 (_a7);
10420 : 0 : _q120 = do_valueize (valueize, _q120);
10421 : 0 : tree _q121 = gimple_assign_rhs2 (_a7);
10422 : 0 : _q121 = do_valueize (valueize, _q121);
10423 : 0 : if (tree_swap_operands_p (_q120, _q121))
10424 : 0 : std::swap (_q120, _q121);
10425 : 0 : {
10426 : 0 : tree _q120_pops[1];
10427 : 0 : if (gimple_nop_convert (_q120, _q120_pops, valueize))
10428 : : {
10429 : 0 : tree _q130 = _q120_pops[0];
10430 : 0 : if ((_q130 == _q41 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q41, 0) && types_match (_q130, _q41)))
10431 : : {
10432 : 0 : {
10433 : 0 : tree _q121_pops[1];
10434 : 0 : if (gimple_nop_convert (_q121, _q121_pops, valueize))
10435 : : {
10436 : 0 : tree _q150 = _q121_pops[0];
10437 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
10438 : : {
10439 : 0 : if (integer_zerop (_q81))
10440 : : {
10441 : 0 : {
10442 : 0 : tree _p1_pops[1];
10443 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10444 : : {
10445 : 0 : tree _q180 = _p1_pops[0];
10446 : 0 : if ((_q180 == _q41 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q41, 0) && types_match (_q180, _q41)))
10447 : : {
10448 : 0 : if ((_p2 == _q91 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q91, 0) && types_match (_p2, _q91)))
10449 : : {
10450 : 0 : {
10451 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q41, _q40, _q91 };
10452 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10453 : : )
10454 : : {
10455 : 0 : {
10456 : 0 : res_ops[0] = captures[0];
10457 : 0 : res_ops[1] = captures[1];
10458 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
10459 : 0 : return true;
10460 : : }
10461 : : }
10462 : : }
10463 : : }
10464 : : }
10465 : : }
10466 : : }
10467 : : }
10468 : : }
10469 : : }
10470 : : }
10471 : : }
10472 : : }
10473 : : }
10474 : 0 : break;
10475 : : }
10476 : : default:;
10477 : : }
10478 : : }
10479 : : break;
10480 : : default:;
10481 : : }
10482 : : }
10483 : : }
10484 : : }
10485 : 3365690 : break;
10486 : : }
10487 : : default:;
10488 : : }
10489 : : }
10490 : : break;
10491 : : default:;
10492 : : }
10493 : : break;
10494 : : }
10495 : : default:;
10496 : : }
10497 : : }
10498 : : break;
10499 : : default:;
10500 : : }
10501 : : }
10502 : 3365690 : break;
10503 : : }
10504 : : default:;
10505 : : }
10506 : : }
10507 : : break;
10508 : : default:;
10509 : : }
10510 : : break;
10511 : : }
10512 : 0 : case BIT_NOT_EXPR:
10513 : 0 : {
10514 : 0 : tree _q30 = gimple_assign_rhs1 (_a3);
10515 : 0 : _q30 = do_valueize (valueize, _q30);
10516 : 0 : switch (TREE_CODE (_q30))
10517 : : {
10518 : 0 : case SSA_NAME:
10519 : 0 : if (gimple *_d4 = get_def (valueize, _q30))
10520 : : {
10521 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
10522 : 0 : switch (gimple_assign_rhs_code (_a4))
10523 : : {
10524 : 0 : case LT_EXPR:
10525 : 0 : {
10526 : 0 : tree _q40 = gimple_assign_rhs1 (_a4);
10527 : 0 : _q40 = do_valueize (valueize, _q40);
10528 : 0 : tree _q41 = gimple_assign_rhs2 (_a4);
10529 : 0 : _q41 = do_valueize (valueize, _q41);
10530 : 0 : switch (TREE_CODE (_q40))
10531 : : {
10532 : 0 : case SSA_NAME:
10533 : 0 : if (gimple *_d5 = get_def (valueize, _q40))
10534 : : {
10535 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
10536 : 0 : switch (gimple_assign_rhs_code (_a5))
10537 : : {
10538 : 0 : case BIT_XOR_EXPR:
10539 : 0 : {
10540 : 0 : tree _q50 = gimple_assign_rhs1 (_a5);
10541 : 0 : _q50 = do_valueize (valueize, _q50);
10542 : 0 : tree _q51 = gimple_assign_rhs2 (_a5);
10543 : 0 : _q51 = do_valueize (valueize, _q51);
10544 : 0 : if (tree_swap_operands_p (_q50, _q51))
10545 : 0 : std::swap (_q50, _q51);
10546 : 0 : if (integer_zerop (_q41))
10547 : : {
10548 : 0 : switch (TREE_CODE (_q21))
10549 : : {
10550 : 0 : case SSA_NAME:
10551 : 0 : if (gimple *_d6 = get_def (valueize, _q21))
10552 : : {
10553 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
10554 : 0 : switch (gimple_assign_rhs_code (_a6))
10555 : : {
10556 : 0 : case LT_EXPR:
10557 : 0 : {
10558 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
10559 : 0 : _q90 = do_valueize (valueize, _q90);
10560 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
10561 : 0 : _q91 = do_valueize (valueize, _q91);
10562 : 0 : switch (TREE_CODE (_q90))
10563 : : {
10564 : 0 : case SSA_NAME:
10565 : 0 : if (gimple *_d7 = get_def (valueize, _q90))
10566 : : {
10567 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
10568 : 0 : switch (gimple_assign_rhs_code (_a7))
10569 : : {
10570 : 0 : case BIT_XOR_EXPR:
10571 : 0 : {
10572 : 0 : tree _q100 = gimple_assign_rhs1 (_a7);
10573 : 0 : _q100 = do_valueize (valueize, _q100);
10574 : 0 : tree _q101 = gimple_assign_rhs2 (_a7);
10575 : 0 : _q101 = do_valueize (valueize, _q101);
10576 : 0 : if (tree_swap_operands_p (_q100, _q101))
10577 : 0 : std::swap (_q100, _q101);
10578 : 0 : if ((_q100 == _q50 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q50, 0) && types_match (_q100, _q50)))
10579 : : {
10580 : 0 : {
10581 : 0 : tree _q101_pops[1];
10582 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
10583 : : {
10584 : 0 : tree _q120 = _q101_pops[0];
10585 : 0 : switch (TREE_CODE (_q120))
10586 : : {
10587 : 0 : case SSA_NAME:
10588 : 0 : if (gimple *_d8 = get_def (valueize, _q120))
10589 : : {
10590 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
10591 : 0 : switch (gimple_assign_rhs_code (_a8))
10592 : : {
10593 : 0 : case PLUS_EXPR:
10594 : 0 : {
10595 : 0 : tree _q130 = gimple_assign_rhs1 (_a8);
10596 : 0 : _q130 = do_valueize (valueize, _q130);
10597 : 0 : tree _q131 = gimple_assign_rhs2 (_a8);
10598 : 0 : _q131 = do_valueize (valueize, _q131);
10599 : 0 : if (tree_swap_operands_p (_q130, _q131))
10600 : 0 : std::swap (_q130, _q131);
10601 : 0 : {
10602 : 0 : tree _q130_pops[1];
10603 : 0 : if (gimple_nop_convert (_q130, _q130_pops, valueize))
10604 : : {
10605 : 0 : tree _q140 = _q130_pops[0];
10606 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
10607 : : {
10608 : 0 : {
10609 : 0 : tree _q131_pops[1];
10610 : 0 : if (gimple_nop_convert (_q131, _q131_pops, valueize))
10611 : : {
10612 : 0 : tree _q160 = _q131_pops[0];
10613 : 0 : if ((_q160 == _q51 && ! TREE_SIDE_EFFECTS (_q160)) || (operand_equal_p (_q160, _q51, 0) && types_match (_q160, _q51)))
10614 : : {
10615 : 0 : if (integer_zerop (_q91))
10616 : : {
10617 : 0 : {
10618 : 0 : tree _p1_pops[1];
10619 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10620 : : {
10621 : 0 : tree _q190 = _p1_pops[0];
10622 : 0 : if ((_q190 == _q50 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q50, 0) && types_match (_q190, _q50)))
10623 : : {
10624 : 0 : if ((_p2 == _q101 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q101, 0) && types_match (_p2, _q101)))
10625 : : {
10626 : 0 : {
10627 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q101 };
10628 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10629 : : )
10630 : : {
10631 : 0 : {
10632 : 0 : res_ops[0] = captures[0];
10633 : 0 : res_ops[1] = captures[1];
10634 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
10635 : 0 : return true;
10636 : : }
10637 : : }
10638 : : }
10639 : : }
10640 : : }
10641 : : }
10642 : : }
10643 : : }
10644 : : }
10645 : : }
10646 : : }
10647 : : }
10648 : : }
10649 : : }
10650 : 0 : break;
10651 : : }
10652 : : default:;
10653 : : }
10654 : : }
10655 : : break;
10656 : : default:;
10657 : : }
10658 : : }
10659 : : }
10660 : : }
10661 : 0 : if ((_q100 == _q51 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q51, 0) && types_match (_q100, _q51)))
10662 : : {
10663 : 0 : {
10664 : 0 : tree _q101_pops[1];
10665 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
10666 : : {
10667 : 0 : tree _q120 = _q101_pops[0];
10668 : 0 : switch (TREE_CODE (_q120))
10669 : : {
10670 : 0 : case SSA_NAME:
10671 : 0 : if (gimple *_d8 = get_def (valueize, _q120))
10672 : : {
10673 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
10674 : 0 : switch (gimple_assign_rhs_code (_a8))
10675 : : {
10676 : 0 : case PLUS_EXPR:
10677 : 0 : {
10678 : 0 : tree _q130 = gimple_assign_rhs1 (_a8);
10679 : 0 : _q130 = do_valueize (valueize, _q130);
10680 : 0 : tree _q131 = gimple_assign_rhs2 (_a8);
10681 : 0 : _q131 = do_valueize (valueize, _q131);
10682 : 0 : if (tree_swap_operands_p (_q130, _q131))
10683 : 0 : std::swap (_q130, _q131);
10684 : 0 : {
10685 : 0 : tree _q130_pops[1];
10686 : 0 : if (gimple_nop_convert (_q130, _q130_pops, valueize))
10687 : : {
10688 : 0 : tree _q140 = _q130_pops[0];
10689 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
10690 : : {
10691 : 0 : {
10692 : 0 : tree _q131_pops[1];
10693 : 0 : if (gimple_nop_convert (_q131, _q131_pops, valueize))
10694 : : {
10695 : 0 : tree _q160 = _q131_pops[0];
10696 : 0 : if ((_q160 == _q50 && ! TREE_SIDE_EFFECTS (_q160)) || (operand_equal_p (_q160, _q50, 0) && types_match (_q160, _q50)))
10697 : : {
10698 : 0 : if (integer_zerop (_q91))
10699 : : {
10700 : 0 : {
10701 : 0 : tree _p1_pops[1];
10702 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10703 : : {
10704 : 0 : tree _q190 = _p1_pops[0];
10705 : 0 : if ((_q190 == _q51 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q51, 0) && types_match (_q190, _q51)))
10706 : : {
10707 : 0 : if ((_p2 == _q101 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q101, 0) && types_match (_p2, _q101)))
10708 : : {
10709 : 0 : {
10710 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q101 };
10711 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10712 : : )
10713 : : {
10714 : 0 : {
10715 : 0 : res_ops[0] = captures[0];
10716 : 0 : res_ops[1] = captures[1];
10717 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
10718 : 0 : return true;
10719 : : }
10720 : : }
10721 : : }
10722 : : }
10723 : : }
10724 : : }
10725 : : }
10726 : : }
10727 : : }
10728 : : }
10729 : : }
10730 : : }
10731 : : }
10732 : : }
10733 : 0 : break;
10734 : : }
10735 : : default:;
10736 : : }
10737 : : }
10738 : : break;
10739 : : default:;
10740 : : }
10741 : : }
10742 : : }
10743 : : }
10744 : 3365690 : break;
10745 : : }
10746 : : default:;
10747 : : }
10748 : : }
10749 : : break;
10750 : : default:;
10751 : : }
10752 : : break;
10753 : : }
10754 : : default:;
10755 : : }
10756 : : }
10757 : : break;
10758 : : default:;
10759 : : }
10760 : : }
10761 : 3365690 : break;
10762 : : }
10763 : : default:;
10764 : : }
10765 : : }
10766 : : break;
10767 : : default:;
10768 : : }
10769 : : break;
10770 : : }
10771 : : default:;
10772 : : }
10773 : : }
10774 : : break;
10775 : : default:;
10776 : : }
10777 : : break;
10778 : : }
10779 : : default:;
10780 : : }
10781 : : }
10782 : : break;
10783 : : default:;
10784 : : }
10785 : 3365690 : break;
10786 : : }
10787 : 0 : case NE_EXPR:
10788 : 0 : {
10789 : 0 : tree _q20 = gimple_assign_rhs1 (_a2);
10790 : 0 : _q20 = do_valueize (valueize, _q20);
10791 : 0 : tree _q21 = gimple_assign_rhs2 (_a2);
10792 : 0 : _q21 = do_valueize (valueize, _q21);
10793 : 0 : if (tree_swap_operands_p (_q20, _q21))
10794 : 0 : std::swap (_q20, _q21);
10795 : 0 : switch (TREE_CODE (_q20))
10796 : : {
10797 : 0 : case SSA_NAME:
10798 : 0 : if (gimple *_d3 = get_def (valueize, _q20))
10799 : : {
10800 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
10801 : 0 : switch (gimple_assign_rhs_code (_a3))
10802 : : {
10803 : 0 : case IMAGPART_EXPR:
10804 : 0 : {
10805 : 0 : tree _q30 = TREE_OPERAND (gimple_assign_rhs1 (_a3), 0);
10806 : 0 : if ((TREE_CODE (_q30) == SSA_NAME
10807 : 0 : || is_gimple_min_invariant (_q30)))
10808 : : {
10809 : 0 : _q30 = do_valueize (valueize, _q30);
10810 : 0 : switch (TREE_CODE (_q30))
10811 : : {
10812 : 0 : case SSA_NAME:
10813 : 0 : if (gimple *_d4 = get_def (valueize, _q30))
10814 : : {
10815 : 0 : if (gcall *_c4 = dyn_cast <gcall *> (_d4))
10816 : 0 : switch (gimple_call_combined_fn (_c4))
10817 : : {
10818 : 0 : case CFN_ADD_OVERFLOW:
10819 : 0 : if (gimple_call_num_args (_c4) == 2)
10820 : : {
10821 : 0 : tree _q40 = gimple_call_arg (_c4, 0);
10822 : 0 : _q40 = do_valueize (valueize, _q40);
10823 : 0 : tree _q41 = gimple_call_arg (_c4, 1);
10824 : 0 : _q41 = do_valueize (valueize, _q41);
10825 : 0 : if (tree_swap_operands_p (_q40, _q41))
10826 : 0 : std::swap (_q40, _q41);
10827 : 0 : if (integer_zerop (_q21))
10828 : : {
10829 : 0 : {
10830 : 0 : tree _p1_pops[1];
10831 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
10832 : : {
10833 : 0 : tree _q80 = _p1_pops[0];
10834 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
10835 : : {
10836 : 0 : switch (TREE_CODE (_p2))
10837 : : {
10838 : 0 : case SSA_NAME:
10839 : 0 : if (gimple *_d5 = get_def (valueize, _p2))
10840 : : {
10841 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
10842 : 0 : switch (gimple_assign_rhs_code (_a5))
10843 : : {
10844 : 0 : case REALPART_EXPR:
10845 : 0 : {
10846 : 0 : tree _q100 = TREE_OPERAND (gimple_assign_rhs1 (_a5), 0);
10847 : 0 : if ((TREE_CODE (_q100) == SSA_NAME
10848 : 0 : || is_gimple_min_invariant (_q100)))
10849 : : {
10850 : 0 : _q100 = do_valueize (valueize, _q100);
10851 : 0 : if ((_q100 == _q30 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q30, 0) && types_match (_q100, _q30)))
10852 : : {
10853 : 0 : {
10854 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q41, _q30 };
10855 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10856 : : )
10857 : : {
10858 : 0 : {
10859 : 0 : res_ops[0] = captures[0];
10860 : 0 : res_ops[1] = captures[1];
10861 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 76, __FILE__, __LINE__, false);
10862 : 0 : return true;
10863 : : }
10864 : : }
10865 : : }
10866 : : }
10867 : : }
10868 : : break;
10869 : : }
10870 : : default:;
10871 : : }
10872 : : }
10873 : : break;
10874 : : default:;
10875 : : }
10876 : : }
10877 : 0 : if ((_q80 == _q41 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q41, 0) && types_match (_q80, _q41)))
10878 : : {
10879 : 0 : switch (TREE_CODE (_p2))
10880 : : {
10881 : 0 : case SSA_NAME:
10882 : 0 : if (gimple *_d5 = get_def (valueize, _p2))
10883 : : {
10884 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
10885 : 0 : switch (gimple_assign_rhs_code (_a5))
10886 : : {
10887 : 0 : case REALPART_EXPR:
10888 : 0 : {
10889 : 0 : tree _q100 = TREE_OPERAND (gimple_assign_rhs1 (_a5), 0);
10890 : 0 : if ((TREE_CODE (_q100) == SSA_NAME
10891 : 0 : || is_gimple_min_invariant (_q100)))
10892 : : {
10893 : 0 : _q100 = do_valueize (valueize, _q100);
10894 : 0 : if ((_q100 == _q30 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q30, 0) && types_match (_q100, _q30)))
10895 : : {
10896 : 0 : {
10897 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q41, _q40, _q30 };
10898 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
10899 : : )
10900 : : {
10901 : 0 : {
10902 : 0 : res_ops[0] = captures[0];
10903 : 0 : res_ops[1] = captures[1];
10904 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 76, __FILE__, __LINE__, false);
10905 : 0 : return true;
10906 : : }
10907 : : }
10908 : : }
10909 : : }
10910 : : }
10911 : : break;
10912 : : }
10913 : : default:;
10914 : : }
10915 : : }
10916 : : break;
10917 : : default:;
10918 : : }
10919 : : }
10920 : : }
10921 : : }
10922 : : }
10923 : : }
10924 : : break;
10925 : : default:;
10926 : : }
10927 : : }
10928 : : break;
10929 : : default:;
10930 : : }
10931 : : }
10932 : : break;
10933 : : }
10934 : : default:;
10935 : : }
10936 : : }
10937 : : break;
10938 : : default:;
10939 : : }
10940 : 3365690 : break;
10941 : : }
10942 : : default:;
10943 : : }
10944 : : }
10945 : : break;
10946 : 42924 : case LT_EXPR:
10947 : 42924 : {
10948 : 42924 : tree _q20 = TREE_OPERAND (_p0, 0);
10949 : 42924 : if ((TREE_CODE (_q20) == SSA_NAME
10950 : 42924 : || is_gimple_min_invariant (_q20)))
10951 : : {
10952 : 42924 : _q20 = do_valueize (valueize, _q20);
10953 : 42924 : tree _q21 = TREE_OPERAND (_p0, 1);
10954 : 42924 : if ((TREE_CODE (_q21) == SSA_NAME
10955 : 42924 : || is_gimple_min_invariant (_q21)))
10956 : : {
10957 : 42924 : _q21 = do_valueize (valueize, _q21);
10958 : 42924 : switch (TREE_CODE (_q20))
10959 : : {
10960 : 42924 : case SSA_NAME:
10961 : 42924 : if (gimple *_d2 = get_def (valueize, _q20))
10962 : : {
10963 : 42924 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
10964 : 34083 : switch (gimple_assign_rhs_code (_a2))
10965 : : {
10966 : 334 : case BIT_AND_EXPR:
10967 : 334 : {
10968 : 334 : tree _q30 = gimple_assign_rhs1 (_a2);
10969 : 334 : _q30 = do_valueize (valueize, _q30);
10970 : 334 : tree _q31 = gimple_assign_rhs2 (_a2);
10971 : 334 : _q31 = do_valueize (valueize, _q31);
10972 : 334 : if (tree_swap_operands_p (_q30, _q31))
10973 : 0 : std::swap (_q30, _q31);
10974 : 334 : switch (TREE_CODE (_q30))
10975 : : {
10976 : 334 : case SSA_NAME:
10977 : 334 : if (gimple *_d3 = get_def (valueize, _q30))
10978 : : {
10979 : 334 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
10980 : 343 : switch (gimple_assign_rhs_code (_a3))
10981 : : {
10982 : 6 : case BIT_XOR_EXPR:
10983 : 6 : {
10984 : 6 : tree _q40 = gimple_assign_rhs1 (_a3);
10985 : 6 : _q40 = do_valueize (valueize, _q40);
10986 : 6 : tree _q41 = gimple_assign_rhs2 (_a3);
10987 : 6 : _q41 = do_valueize (valueize, _q41);
10988 : 6 : if (tree_swap_operands_p (_q40, _q41))
10989 : 0 : std::swap (_q40, _q41);
10990 : 6 : {
10991 : 6 : tree _q41_pops[1];
10992 : 6 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
10993 : : {
10994 : 2 : tree _q60 = _q41_pops[0];
10995 : 2 : switch (TREE_CODE (_q60))
10996 : : {
10997 : 2 : case SSA_NAME:
10998 : 2 : if (gimple *_d4 = get_def (valueize, _q60))
10999 : : {
11000 : 2 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
11001 : 2 : switch (gimple_assign_rhs_code (_a4))
11002 : : {
11003 : 2 : case PLUS_EXPR:
11004 : 2 : {
11005 : 2 : tree _q70 = gimple_assign_rhs1 (_a4);
11006 : 2 : _q70 = do_valueize (valueize, _q70);
11007 : 2 : tree _q71 = gimple_assign_rhs2 (_a4);
11008 : 2 : _q71 = do_valueize (valueize, _q71);
11009 : 2 : if (tree_swap_operands_p (_q70, _q71))
11010 : 0 : std::swap (_q70, _q71);
11011 : 2 : {
11012 : 2 : tree _q70_pops[1];
11013 : 2 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
11014 : : {
11015 : 2 : tree _q80 = _q70_pops[0];
11016 : 2 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
11017 : : {
11018 : 2 : {
11019 : 2 : tree _q71_pops[1];
11020 : 2 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
11021 : : {
11022 : 2 : tree _q100 = _q71_pops[0];
11023 : 2 : switch (TREE_CODE (_q31))
11024 : : {
11025 : 2 : case SSA_NAME:
11026 : 2 : if (gimple *_d5 = get_def (valueize, _q31))
11027 : : {
11028 : 2 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
11029 : 2 : switch (gimple_assign_rhs_code (_a5))
11030 : : {
11031 : 2 : case BIT_NOT_EXPR:
11032 : 2 : {
11033 : 2 : tree _q120 = gimple_assign_rhs1 (_a5);
11034 : 2 : _q120 = do_valueize (valueize, _q120);
11035 : 2 : switch (TREE_CODE (_q120))
11036 : : {
11037 : 2 : case SSA_NAME:
11038 : 2 : if (gimple *_d6 = get_def (valueize, _q120))
11039 : : {
11040 : 2 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
11041 : 2 : switch (gimple_assign_rhs_code (_a6))
11042 : : {
11043 : 2 : case BIT_XOR_EXPR:
11044 : 2 : {
11045 : 2 : tree _q130 = gimple_assign_rhs1 (_a6);
11046 : 2 : _q130 = do_valueize (valueize, _q130);
11047 : 2 : tree _q131 = gimple_assign_rhs2 (_a6);
11048 : 2 : _q131 = do_valueize (valueize, _q131);
11049 : 2 : if (tree_swap_operands_p (_q130, _q131))
11050 : 0 : std::swap (_q130, _q131);
11051 : 2 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
11052 : : {
11053 : 2 : if ((_q131 == _q100 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q100, 0) && types_match (_q131, _q100)))
11054 : : {
11055 : 2 : if (integer_zerop (_q21))
11056 : : {
11057 : 2 : {
11058 : 2 : tree _p1_pops[1];
11059 : 2 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11060 : : {
11061 : 2 : tree _q170 = _p1_pops[0];
11062 : 2 : if ((_q170 == _q40 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q40, 0) && types_match (_q170, _q40)))
11063 : : {
11064 : 2 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
11065 : : {
11066 : 2 : {
11067 : 2 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
11068 : 2 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11069 : : )
11070 : : {
11071 : 2 : {
11072 : 2 : res_ops[0] = captures[0];
11073 : 2 : res_ops[1] = captures[1];
11074 : 2 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
11075 : 2 : return true;
11076 : : }
11077 : : }
11078 : : }
11079 : : }
11080 : : }
11081 : : }
11082 : : }
11083 : : }
11084 : : }
11085 : : }
11086 : 0 : if ((_q130 == _q100 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q100, 0) && types_match (_q130, _q100)))
11087 : : {
11088 : 0 : if ((_q131 == _q40 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q40, 0) && types_match (_q131, _q40)))
11089 : : {
11090 : 0 : if (integer_zerop (_q21))
11091 : : {
11092 : 0 : {
11093 : 0 : tree _p1_pops[1];
11094 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11095 : : {
11096 : 0 : tree _q170 = _p1_pops[0];
11097 : 0 : if ((_q170 == _q40 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q40, 0) && types_match (_q170, _q40)))
11098 : : {
11099 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
11100 : : {
11101 : 0 : {
11102 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
11103 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11104 : : )
11105 : : {
11106 : 0 : {
11107 : 0 : res_ops[0] = captures[0];
11108 : 0 : res_ops[1] = captures[1];
11109 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
11110 : 0 : return true;
11111 : : }
11112 : : }
11113 : : }
11114 : : }
11115 : : }
11116 : : }
11117 : : }
11118 : : }
11119 : : }
11120 : : }
11121 : 0 : break;
11122 : : }
11123 : : default:;
11124 : : }
11125 : : }
11126 : : break;
11127 : : default:;
11128 : : }
11129 : : break;
11130 : : }
11131 : : default:;
11132 : : }
11133 : : }
11134 : : break;
11135 : : default:;
11136 : : }
11137 : : }
11138 : : }
11139 : : }
11140 : : }
11141 : : }
11142 : 0 : break;
11143 : : }
11144 : : default:;
11145 : : }
11146 : : }
11147 : : break;
11148 : : default:;
11149 : : }
11150 : : }
11151 : : }
11152 : 4 : {
11153 : 4 : tree _q40_pops[1];
11154 : 4 : if (gimple_nop_convert (_q40, _q40_pops, valueize))
11155 : : {
11156 : 0 : tree _q50 = _q40_pops[0];
11157 : 0 : switch (TREE_CODE (_q50))
11158 : : {
11159 : 0 : case SSA_NAME:
11160 : 0 : if (gimple *_d4 = get_def (valueize, _q50))
11161 : : {
11162 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
11163 : 0 : switch (gimple_assign_rhs_code (_a4))
11164 : : {
11165 : 0 : case PLUS_EXPR:
11166 : 0 : {
11167 : 0 : tree _q60 = gimple_assign_rhs1 (_a4);
11168 : 0 : _q60 = do_valueize (valueize, _q60);
11169 : 0 : tree _q61 = gimple_assign_rhs2 (_a4);
11170 : 0 : _q61 = do_valueize (valueize, _q61);
11171 : 0 : if (tree_swap_operands_p (_q60, _q61))
11172 : 0 : std::swap (_q60, _q61);
11173 : 0 : {
11174 : 0 : tree _q60_pops[1];
11175 : 0 : if (gimple_nop_convert (_q60, _q60_pops, valueize))
11176 : : {
11177 : 0 : tree _q70 = _q60_pops[0];
11178 : 0 : switch (TREE_CODE (_q61))
11179 : : {
11180 : 0 : case INTEGER_CST:
11181 : 0 : {
11182 : 0 : if ((_q41 == _q70 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q70, 0) && types_match (_q41, _q70)))
11183 : : {
11184 : 0 : switch (TREE_CODE (_q31))
11185 : : {
11186 : 0 : case SSA_NAME:
11187 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
11188 : : {
11189 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
11190 : 0 : switch (gimple_assign_rhs_code (_a5))
11191 : : {
11192 : 0 : case BIT_XOR_EXPR:
11193 : 0 : {
11194 : 0 : tree _q110 = gimple_assign_rhs1 (_a5);
11195 : 0 : _q110 = do_valueize (valueize, _q110);
11196 : 0 : tree _q111 = gimple_assign_rhs2 (_a5);
11197 : 0 : _q111 = do_valueize (valueize, _q111);
11198 : 0 : if (tree_swap_operands_p (_q110, _q111))
11199 : 0 : std::swap (_q110, _q111);
11200 : 0 : if ((_q110 == _q70 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q70, 0) && types_match (_q110, _q70)))
11201 : : {
11202 : 0 : switch (TREE_CODE (_q111))
11203 : : {
11204 : 0 : case INTEGER_CST:
11205 : 0 : {
11206 : 0 : if (integer_zerop (_q21))
11207 : : {
11208 : 0 : {
11209 : 0 : tree _p1_pops[1];
11210 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11211 : : {
11212 : 0 : tree _q150 = _p1_pops[0];
11213 : 0 : if ((_q150 == _q70 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q70, 0) && types_match (_q150, _q70)))
11214 : : {
11215 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
11216 : : {
11217 : 0 : {
11218 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q70, _q61, _q40, _q111 };
11219 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11220 : : )
11221 : : {
11222 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
11223 : : )
11224 : : {
11225 : 0 : {
11226 : 0 : res_ops[0] = captures[0];
11227 : 0 : res_ops[1] = captures[1];
11228 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
11229 : 0 : return true;
11230 : : }
11231 : : }
11232 : : }
11233 : : }
11234 : : }
11235 : : }
11236 : : }
11237 : : }
11238 : : }
11239 : : break;
11240 : : }
11241 : : default:;
11242 : : }
11243 : : }
11244 : 0 : switch (TREE_CODE (_q110))
11245 : : {
11246 : 0 : case INTEGER_CST:
11247 : 0 : {
11248 : 0 : if ((_q111 == _q70 && ! TREE_SIDE_EFFECTS (_q111)) || (operand_equal_p (_q111, _q70, 0) && types_match (_q111, _q70)))
11249 : : {
11250 : 0 : if (integer_zerop (_q21))
11251 : : {
11252 : 0 : {
11253 : 0 : tree _p1_pops[1];
11254 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11255 : : {
11256 : 0 : tree _q150 = _p1_pops[0];
11257 : 0 : if ((_q150 == _q70 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q70, 0) && types_match (_q150, _q70)))
11258 : : {
11259 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
11260 : : {
11261 : 0 : {
11262 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q70, _q61, _q40, _q110 };
11263 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11264 : : )
11265 : : {
11266 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
11267 : : )
11268 : : {
11269 : 0 : {
11270 : 0 : res_ops[0] = captures[0];
11271 : 0 : res_ops[1] = captures[1];
11272 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
11273 : 0 : return true;
11274 : : }
11275 : : }
11276 : : }
11277 : : }
11278 : : }
11279 : : }
11280 : : }
11281 : : }
11282 : : }
11283 : : }
11284 : : break;
11285 : : }
11286 : : default:;
11287 : : }
11288 : 0 : break;
11289 : : }
11290 : : default:;
11291 : : }
11292 : : }
11293 : : break;
11294 : : default:;
11295 : : }
11296 : : }
11297 : : break;
11298 : : }
11299 : 0 : default:;
11300 : : }
11301 : 0 : {
11302 : 0 : tree _q61_pops[1];
11303 : 0 : if (gimple_nop_convert (_q61, _q61_pops, valueize))
11304 : : {
11305 : 0 : tree _q90 = _q61_pops[0];
11306 : 0 : if ((_q41 == _q70 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q70, 0) && types_match (_q41, _q70)))
11307 : : {
11308 : 0 : switch (TREE_CODE (_q31))
11309 : : {
11310 : 0 : case SSA_NAME:
11311 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
11312 : : {
11313 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
11314 : 0 : switch (gimple_assign_rhs_code (_a5))
11315 : : {
11316 : 0 : case BIT_NOT_EXPR:
11317 : 0 : {
11318 : 0 : tree _q120 = gimple_assign_rhs1 (_a5);
11319 : 0 : _q120 = do_valueize (valueize, _q120);
11320 : 0 : switch (TREE_CODE (_q120))
11321 : : {
11322 : 0 : case SSA_NAME:
11323 : 0 : if (gimple *_d6 = get_def (valueize, _q120))
11324 : : {
11325 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
11326 : 0 : switch (gimple_assign_rhs_code (_a6))
11327 : : {
11328 : 0 : case BIT_XOR_EXPR:
11329 : 0 : {
11330 : 0 : tree _q130 = gimple_assign_rhs1 (_a6);
11331 : 0 : _q130 = do_valueize (valueize, _q130);
11332 : 0 : tree _q131 = gimple_assign_rhs2 (_a6);
11333 : 0 : _q131 = do_valueize (valueize, _q131);
11334 : 0 : if (tree_swap_operands_p (_q130, _q131))
11335 : 0 : std::swap (_q130, _q131);
11336 : 0 : if ((_q130 == _q70 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q70, 0) && types_match (_q130, _q70)))
11337 : : {
11338 : 0 : if ((_q131 == _q90 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q90, 0) && types_match (_q131, _q90)))
11339 : : {
11340 : 0 : if (integer_zerop (_q21))
11341 : : {
11342 : 0 : {
11343 : 0 : tree _p1_pops[1];
11344 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11345 : : {
11346 : 0 : tree _q170 = _p1_pops[0];
11347 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
11348 : : {
11349 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
11350 : : {
11351 : 0 : {
11352 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q70, _q90, _q40 };
11353 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11354 : : )
11355 : : {
11356 : 0 : {
11357 : 0 : res_ops[0] = captures[0];
11358 : 0 : res_ops[1] = captures[1];
11359 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
11360 : 0 : return true;
11361 : : }
11362 : : }
11363 : : }
11364 : : }
11365 : : }
11366 : : }
11367 : : }
11368 : : }
11369 : : }
11370 : : }
11371 : 0 : if ((_q130 == _q90 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q90, 0) && types_match (_q130, _q90)))
11372 : : {
11373 : 0 : if ((_q131 == _q70 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q70, 0) && types_match (_q131, _q70)))
11374 : : {
11375 : 0 : if (integer_zerop (_q21))
11376 : : {
11377 : 0 : {
11378 : 0 : tree _p1_pops[1];
11379 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11380 : : {
11381 : 0 : tree _q170 = _p1_pops[0];
11382 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
11383 : : {
11384 : 0 : if ((_p2 == _q40 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q40, 0) && types_match (_p2, _q40)))
11385 : : {
11386 : 0 : {
11387 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q70, _q90, _q40 };
11388 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11389 : : )
11390 : : {
11391 : 0 : {
11392 : 0 : res_ops[0] = captures[0];
11393 : 0 : res_ops[1] = captures[1];
11394 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
11395 : 0 : return true;
11396 : : }
11397 : : }
11398 : : }
11399 : : }
11400 : : }
11401 : : }
11402 : : }
11403 : : }
11404 : : }
11405 : : }
11406 : 0 : break;
11407 : : }
11408 : : default:;
11409 : : }
11410 : : }
11411 : : break;
11412 : : default:;
11413 : : }
11414 : : break;
11415 : : }
11416 : : default:;
11417 : : }
11418 : : }
11419 : : break;
11420 : : default:;
11421 : : }
11422 : : }
11423 : : }
11424 : : }
11425 : : }
11426 : : }
11427 : 0 : break;
11428 : : }
11429 : : default:;
11430 : : }
11431 : : }
11432 : : break;
11433 : : default:;
11434 : : }
11435 : : }
11436 : : }
11437 : 4 : switch (TREE_CODE (_q41))
11438 : : {
11439 : 0 : case INTEGER_CST:
11440 : 0 : {
11441 : 0 : switch (TREE_CODE (_q31))
11442 : : {
11443 : 0 : case SSA_NAME:
11444 : 0 : if (gimple *_d4 = get_def (valueize, _q31))
11445 : : {
11446 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
11447 : 0 : switch (gimple_assign_rhs_code (_a4))
11448 : : {
11449 : 0 : case BIT_XOR_EXPR:
11450 : 0 : {
11451 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
11452 : 0 : _q70 = do_valueize (valueize, _q70);
11453 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
11454 : 0 : _q71 = do_valueize (valueize, _q71);
11455 : 0 : if (tree_swap_operands_p (_q70, _q71))
11456 : 0 : std::swap (_q70, _q71);
11457 : 0 : if ((_q70 == _q40 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q40, 0) && types_match (_q70, _q40)))
11458 : : {
11459 : 0 : {
11460 : 0 : tree _q71_pops[1];
11461 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
11462 : : {
11463 : 0 : tree _q90 = _q71_pops[0];
11464 : 0 : switch (TREE_CODE (_q90))
11465 : : {
11466 : 0 : case SSA_NAME:
11467 : 0 : if (gimple *_d5 = get_def (valueize, _q90))
11468 : : {
11469 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
11470 : 0 : switch (gimple_assign_rhs_code (_a5))
11471 : : {
11472 : 0 : case PLUS_EXPR:
11473 : 0 : {
11474 : 0 : tree _q100 = gimple_assign_rhs1 (_a5);
11475 : 0 : _q100 = do_valueize (valueize, _q100);
11476 : 0 : tree _q101 = gimple_assign_rhs2 (_a5);
11477 : 0 : _q101 = do_valueize (valueize, _q101);
11478 : 0 : if (tree_swap_operands_p (_q100, _q101))
11479 : 0 : std::swap (_q100, _q101);
11480 : 0 : {
11481 : 0 : tree _q100_pops[1];
11482 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
11483 : : {
11484 : 0 : tree _q110 = _q100_pops[0];
11485 : 0 : if ((_q110 == _q40 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q40, 0) && types_match (_q110, _q40)))
11486 : : {
11487 : 0 : switch (TREE_CODE (_q101))
11488 : : {
11489 : 0 : case INTEGER_CST:
11490 : 0 : {
11491 : 0 : if (integer_zerop (_q21))
11492 : : {
11493 : 0 : {
11494 : 0 : tree _p1_pops[1];
11495 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11496 : : {
11497 : 0 : tree _q150 = _p1_pops[0];
11498 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
11499 : : {
11500 : 0 : if ((_p2 == _q71 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q71, 0) && types_match (_p2, _q71)))
11501 : : {
11502 : 0 : {
11503 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q101, _q71, _q41 };
11504 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11505 : : )
11506 : : {
11507 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
11508 : : )
11509 : : {
11510 : 0 : {
11511 : 0 : res_ops[0] = captures[0];
11512 : 0 : res_ops[1] = captures[1];
11513 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
11514 : 0 : return true;
11515 : : }
11516 : : }
11517 : : }
11518 : : }
11519 : : }
11520 : : }
11521 : : }
11522 : : }
11523 : : }
11524 : : break;
11525 : : }
11526 : : default:;
11527 : : }
11528 : : }
11529 : : }
11530 : : }
11531 : 0 : break;
11532 : : }
11533 : : default:;
11534 : : }
11535 : : }
11536 : : break;
11537 : : default:;
11538 : : }
11539 : : }
11540 : : }
11541 : : }
11542 : 4 : break;
11543 : : }
11544 : : default:;
11545 : : }
11546 : : }
11547 : : break;
11548 : : default:;
11549 : : }
11550 : : break;
11551 : : }
11552 : 4 : default:;
11553 : : }
11554 : 4 : {
11555 : 4 : tree _q41_pops[1];
11556 : 4 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
11557 : : {
11558 : 0 : tree _q60 = _q41_pops[0];
11559 : 0 : switch (TREE_CODE (_q60))
11560 : : {
11561 : 0 : case SSA_NAME:
11562 : 0 : if (gimple *_d4 = get_def (valueize, _q60))
11563 : : {
11564 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
11565 : 0 : switch (gimple_assign_rhs_code (_a4))
11566 : : {
11567 : 0 : case PLUS_EXPR:
11568 : 0 : {
11569 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
11570 : 0 : _q70 = do_valueize (valueize, _q70);
11571 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
11572 : 0 : _q71 = do_valueize (valueize, _q71);
11573 : 0 : if (tree_swap_operands_p (_q70, _q71))
11574 : 0 : std::swap (_q70, _q71);
11575 : 0 : {
11576 : 0 : tree _q70_pops[1];
11577 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
11578 : : {
11579 : 0 : tree _q80 = _q70_pops[0];
11580 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
11581 : : {
11582 : 0 : switch (TREE_CODE (_q71))
11583 : : {
11584 : 0 : case INTEGER_CST:
11585 : 0 : {
11586 : 0 : switch (TREE_CODE (_q31))
11587 : : {
11588 : 0 : case SSA_NAME:
11589 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
11590 : : {
11591 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
11592 : 0 : switch (gimple_assign_rhs_code (_a5))
11593 : : {
11594 : 0 : case BIT_XOR_EXPR:
11595 : 0 : {
11596 : 0 : tree _q110 = gimple_assign_rhs1 (_a5);
11597 : 0 : _q110 = do_valueize (valueize, _q110);
11598 : 0 : tree _q111 = gimple_assign_rhs2 (_a5);
11599 : 0 : _q111 = do_valueize (valueize, _q111);
11600 : 0 : if (tree_swap_operands_p (_q110, _q111))
11601 : 0 : std::swap (_q110, _q111);
11602 : 0 : if ((_q110 == _q40 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q40, 0) && types_match (_q110, _q40)))
11603 : : {
11604 : 0 : switch (TREE_CODE (_q111))
11605 : : {
11606 : 0 : case INTEGER_CST:
11607 : 0 : {
11608 : 0 : if (integer_zerop (_q21))
11609 : : {
11610 : 0 : {
11611 : 0 : tree _p1_pops[1];
11612 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11613 : : {
11614 : 0 : tree _q150 = _p1_pops[0];
11615 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
11616 : : {
11617 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
11618 : : {
11619 : 0 : {
11620 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q71, _q41, _q111 };
11621 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11622 : : )
11623 : : {
11624 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
11625 : : )
11626 : : {
11627 : 0 : {
11628 : 0 : res_ops[0] = captures[0];
11629 : 0 : res_ops[1] = captures[1];
11630 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
11631 : 0 : return true;
11632 : : }
11633 : : }
11634 : : }
11635 : : }
11636 : : }
11637 : : }
11638 : : }
11639 : : }
11640 : : }
11641 : : break;
11642 : : }
11643 : : default:;
11644 : : }
11645 : : }
11646 : 0 : switch (TREE_CODE (_q110))
11647 : : {
11648 : 0 : case INTEGER_CST:
11649 : 0 : {
11650 : 0 : if ((_q111 == _q40 && ! TREE_SIDE_EFFECTS (_q111)) || (operand_equal_p (_q111, _q40, 0) && types_match (_q111, _q40)))
11651 : : {
11652 : 0 : if (integer_zerop (_q21))
11653 : : {
11654 : 0 : {
11655 : 0 : tree _p1_pops[1];
11656 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11657 : : {
11658 : 0 : tree _q150 = _p1_pops[0];
11659 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
11660 : : {
11661 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
11662 : : {
11663 : 0 : {
11664 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q71, _q41, _q110 };
11665 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11666 : : )
11667 : : {
11668 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
11669 : : )
11670 : : {
11671 : 0 : {
11672 : 0 : res_ops[0] = captures[0];
11673 : 0 : res_ops[1] = captures[1];
11674 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
11675 : 0 : return true;
11676 : : }
11677 : : }
11678 : : }
11679 : : }
11680 : : }
11681 : : }
11682 : : }
11683 : : }
11684 : : }
11685 : : }
11686 : : break;
11687 : : }
11688 : : default:;
11689 : : }
11690 : 0 : break;
11691 : : }
11692 : : default:;
11693 : : }
11694 : : }
11695 : : break;
11696 : : default:;
11697 : : }
11698 : : break;
11699 : : }
11700 : : default:;
11701 : : }
11702 : : }
11703 : : }
11704 : : }
11705 : 0 : break;
11706 : : }
11707 : : default:;
11708 : : }
11709 : : }
11710 : : break;
11711 : : default:;
11712 : : }
11713 : : }
11714 : : }
11715 : 4 : switch (TREE_CODE (_q40))
11716 : : {
11717 : 0 : case INTEGER_CST:
11718 : 0 : {
11719 : 0 : switch (TREE_CODE (_q31))
11720 : : {
11721 : 0 : case SSA_NAME:
11722 : 0 : if (gimple *_d4 = get_def (valueize, _q31))
11723 : : {
11724 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
11725 : 0 : switch (gimple_assign_rhs_code (_a4))
11726 : : {
11727 : 0 : case BIT_XOR_EXPR:
11728 : 0 : {
11729 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
11730 : 0 : _q70 = do_valueize (valueize, _q70);
11731 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
11732 : 0 : _q71 = do_valueize (valueize, _q71);
11733 : 0 : if (tree_swap_operands_p (_q70, _q71))
11734 : 0 : std::swap (_q70, _q71);
11735 : 0 : if ((_q70 == _q41 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q41, 0) && types_match (_q70, _q41)))
11736 : : {
11737 : 0 : {
11738 : 0 : tree _q71_pops[1];
11739 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
11740 : : {
11741 : 0 : tree _q90 = _q71_pops[0];
11742 : 0 : switch (TREE_CODE (_q90))
11743 : : {
11744 : 0 : case SSA_NAME:
11745 : 0 : if (gimple *_d5 = get_def (valueize, _q90))
11746 : : {
11747 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
11748 : 0 : switch (gimple_assign_rhs_code (_a5))
11749 : : {
11750 : 0 : case PLUS_EXPR:
11751 : 0 : {
11752 : 0 : tree _q100 = gimple_assign_rhs1 (_a5);
11753 : 0 : _q100 = do_valueize (valueize, _q100);
11754 : 0 : tree _q101 = gimple_assign_rhs2 (_a5);
11755 : 0 : _q101 = do_valueize (valueize, _q101);
11756 : 0 : if (tree_swap_operands_p (_q100, _q101))
11757 : 0 : std::swap (_q100, _q101);
11758 : 0 : {
11759 : 0 : tree _q100_pops[1];
11760 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
11761 : : {
11762 : 0 : tree _q110 = _q100_pops[0];
11763 : 0 : if ((_q110 == _q41 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q41, 0) && types_match (_q110, _q41)))
11764 : : {
11765 : 0 : switch (TREE_CODE (_q101))
11766 : : {
11767 : 0 : case INTEGER_CST:
11768 : 0 : {
11769 : 0 : if (integer_zerop (_q21))
11770 : : {
11771 : 0 : {
11772 : 0 : tree _p1_pops[1];
11773 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11774 : : {
11775 : 0 : tree _q150 = _p1_pops[0];
11776 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
11777 : : {
11778 : 0 : if ((_p2 == _q71 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q71, 0) && types_match (_p2, _q71)))
11779 : : {
11780 : 0 : {
11781 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q41, _q101, _q71, _q40 };
11782 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11783 : : )
11784 : : {
11785 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
11786 : : )
11787 : : {
11788 : 0 : {
11789 : 0 : res_ops[0] = captures[0];
11790 : 0 : res_ops[1] = captures[1];
11791 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
11792 : 0 : return true;
11793 : : }
11794 : : }
11795 : : }
11796 : : }
11797 : : }
11798 : : }
11799 : : }
11800 : : }
11801 : : }
11802 : : break;
11803 : : }
11804 : : default:;
11805 : : }
11806 : : }
11807 : : }
11808 : : }
11809 : 0 : break;
11810 : : }
11811 : : default:;
11812 : : }
11813 : : }
11814 : : break;
11815 : : default:;
11816 : : }
11817 : : }
11818 : : }
11819 : : }
11820 : 0 : {
11821 : 0 : tree _q70_pops[1];
11822 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
11823 : : {
11824 : 0 : tree _q80 = _q70_pops[0];
11825 : 0 : switch (TREE_CODE (_q80))
11826 : : {
11827 : 0 : case SSA_NAME:
11828 : 0 : if (gimple *_d5 = get_def (valueize, _q80))
11829 : : {
11830 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
11831 : 0 : switch (gimple_assign_rhs_code (_a5))
11832 : : {
11833 : 0 : case PLUS_EXPR:
11834 : 0 : {
11835 : 0 : tree _q90 = gimple_assign_rhs1 (_a5);
11836 : 0 : _q90 = do_valueize (valueize, _q90);
11837 : 0 : tree _q91 = gimple_assign_rhs2 (_a5);
11838 : 0 : _q91 = do_valueize (valueize, _q91);
11839 : 0 : if (tree_swap_operands_p (_q90, _q91))
11840 : 0 : std::swap (_q90, _q91);
11841 : 0 : {
11842 : 0 : tree _q90_pops[1];
11843 : 0 : if (gimple_nop_convert (_q90, _q90_pops, valueize))
11844 : : {
11845 : 0 : tree _q100 = _q90_pops[0];
11846 : 0 : if ((_q100 == _q41 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q41, 0) && types_match (_q100, _q41)))
11847 : : {
11848 : 0 : switch (TREE_CODE (_q91))
11849 : : {
11850 : 0 : case INTEGER_CST:
11851 : 0 : {
11852 : 0 : if ((_q71 == _q41 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q41, 0) && types_match (_q71, _q41)))
11853 : : {
11854 : 0 : if (integer_zerop (_q21))
11855 : : {
11856 : 0 : {
11857 : 0 : tree _p1_pops[1];
11858 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11859 : : {
11860 : 0 : tree _q150 = _p1_pops[0];
11861 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
11862 : : {
11863 : 0 : if ((_p2 == _q70 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q70, 0) && types_match (_p2, _q70)))
11864 : : {
11865 : 0 : {
11866 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q41, _q91, _q70, _q40 };
11867 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11868 : : )
11869 : : {
11870 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
11871 : : )
11872 : : {
11873 : 0 : {
11874 : 0 : res_ops[0] = captures[0];
11875 : 0 : res_ops[1] = captures[1];
11876 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
11877 : 0 : return true;
11878 : : }
11879 : : }
11880 : : }
11881 : : }
11882 : : }
11883 : : }
11884 : : }
11885 : : }
11886 : : }
11887 : : }
11888 : : break;
11889 : : }
11890 : : default:;
11891 : : }
11892 : : }
11893 : : }
11894 : : }
11895 : 0 : break;
11896 : : }
11897 : : default:;
11898 : : }
11899 : : }
11900 : : break;
11901 : : default:;
11902 : : }
11903 : : }
11904 : : }
11905 : 0 : break;
11906 : : }
11907 : : default:;
11908 : : }
11909 : : }
11910 : : break;
11911 : : default:;
11912 : : }
11913 : : break;
11914 : : }
11915 : 4 : default:;
11916 : : }
11917 : 4 : switch (TREE_CODE (_q41))
11918 : : {
11919 : 0 : case INTEGER_CST:
11920 : 0 : {
11921 : 0 : switch (TREE_CODE (_q31))
11922 : : {
11923 : 0 : case SSA_NAME:
11924 : 0 : if (gimple *_d4 = get_def (valueize, _q31))
11925 : : {
11926 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
11927 : 0 : switch (gimple_assign_rhs_code (_a4))
11928 : : {
11929 : 0 : case BIT_XOR_EXPR:
11930 : 0 : {
11931 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
11932 : 0 : _q70 = do_valueize (valueize, _q70);
11933 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
11934 : 0 : _q71 = do_valueize (valueize, _q71);
11935 : 0 : if (tree_swap_operands_p (_q70, _q71))
11936 : 0 : std::swap (_q70, _q71);
11937 : 0 : {
11938 : 0 : tree _q70_pops[1];
11939 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
11940 : : {
11941 : 0 : tree _q80 = _q70_pops[0];
11942 : 0 : switch (TREE_CODE (_q80))
11943 : : {
11944 : 0 : case SSA_NAME:
11945 : 0 : if (gimple *_d5 = get_def (valueize, _q80))
11946 : : {
11947 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
11948 : 0 : switch (gimple_assign_rhs_code (_a5))
11949 : : {
11950 : 0 : case PLUS_EXPR:
11951 : 0 : {
11952 : 0 : tree _q90 = gimple_assign_rhs1 (_a5);
11953 : 0 : _q90 = do_valueize (valueize, _q90);
11954 : 0 : tree _q91 = gimple_assign_rhs2 (_a5);
11955 : 0 : _q91 = do_valueize (valueize, _q91);
11956 : 0 : if (tree_swap_operands_p (_q90, _q91))
11957 : 0 : std::swap (_q90, _q91);
11958 : 0 : {
11959 : 0 : tree _q90_pops[1];
11960 : 0 : if (gimple_nop_convert (_q90, _q90_pops, valueize))
11961 : : {
11962 : 0 : tree _q100 = _q90_pops[0];
11963 : 0 : if ((_q100 == _q40 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q40, 0) && types_match (_q100, _q40)))
11964 : : {
11965 : 0 : switch (TREE_CODE (_q91))
11966 : : {
11967 : 0 : case INTEGER_CST:
11968 : 0 : {
11969 : 0 : if ((_q71 == _q40 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q40, 0) && types_match (_q71, _q40)))
11970 : : {
11971 : 0 : if (integer_zerop (_q21))
11972 : : {
11973 : 0 : {
11974 : 0 : tree _p1_pops[1];
11975 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
11976 : : {
11977 : 0 : tree _q150 = _p1_pops[0];
11978 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
11979 : : {
11980 : 0 : if ((_p2 == _q70 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q70, 0) && types_match (_p2, _q70)))
11981 : : {
11982 : 0 : {
11983 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _q40, _q91, _q70, _q41 };
11984 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
11985 : : )
11986 : : {
11987 : 0 : if (wi::bit_and (wi::to_wide (captures[1]), wi::to_wide (captures[3])) == 0
11988 : : )
11989 : : {
11990 : 0 : {
11991 : 0 : res_ops[0] = captures[0];
11992 : 0 : res_ops[1] = captures[1];
11993 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 72, __FILE__, __LINE__, false);
11994 : 0 : return true;
11995 : : }
11996 : : }
11997 : : }
11998 : : }
11999 : : }
12000 : : }
12001 : : }
12002 : : }
12003 : : }
12004 : : }
12005 : : break;
12006 : : }
12007 : : default:;
12008 : : }
12009 : : }
12010 : : }
12011 : : }
12012 : 0 : break;
12013 : : }
12014 : : default:;
12015 : : }
12016 : : }
12017 : : break;
12018 : : default:;
12019 : : }
12020 : : }
12021 : : }
12022 : 0 : break;
12023 : : }
12024 : : default:;
12025 : : }
12026 : : }
12027 : : break;
12028 : : default:;
12029 : : }
12030 : : break;
12031 : : }
12032 : : default:;
12033 : : }
12034 : 3365690 : break;
12035 : : }
12036 : 2 : case BIT_NOT_EXPR:
12037 : 2 : {
12038 : 2 : tree _q40 = gimple_assign_rhs1 (_a3);
12039 : 2 : _q40 = do_valueize (valueize, _q40);
12040 : 2 : switch (TREE_CODE (_q40))
12041 : : {
12042 : 2 : case SSA_NAME:
12043 : 2 : if (gimple *_d4 = get_def (valueize, _q40))
12044 : : {
12045 : 2 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
12046 : 2 : switch (gimple_assign_rhs_code (_a4))
12047 : : {
12048 : 2 : case BIT_XOR_EXPR:
12049 : 2 : {
12050 : 2 : tree _q50 = gimple_assign_rhs1 (_a4);
12051 : 2 : _q50 = do_valueize (valueize, _q50);
12052 : 2 : tree _q51 = gimple_assign_rhs2 (_a4);
12053 : 2 : _q51 = do_valueize (valueize, _q51);
12054 : 2 : if (tree_swap_operands_p (_q50, _q51))
12055 : 0 : std::swap (_q50, _q51);
12056 : 2 : switch (TREE_CODE (_q31))
12057 : : {
12058 : 2 : case SSA_NAME:
12059 : 2 : if (gimple *_d5 = get_def (valueize, _q31))
12060 : : {
12061 : 2 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
12062 : 2 : switch (gimple_assign_rhs_code (_a5))
12063 : : {
12064 : 2 : case BIT_XOR_EXPR:
12065 : 2 : {
12066 : 2 : tree _q80 = gimple_assign_rhs1 (_a5);
12067 : 2 : _q80 = do_valueize (valueize, _q80);
12068 : 2 : tree _q81 = gimple_assign_rhs2 (_a5);
12069 : 2 : _q81 = do_valueize (valueize, _q81);
12070 : 2 : if (tree_swap_operands_p (_q80, _q81))
12071 : 0 : std::swap (_q80, _q81);
12072 : 2 : if ((_q80 == _q50 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q50, 0) && types_match (_q80, _q50)))
12073 : : {
12074 : 2 : {
12075 : 2 : tree _q81_pops[1];
12076 : 2 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
12077 : : {
12078 : 2 : tree _q100 = _q81_pops[0];
12079 : 2 : switch (TREE_CODE (_q100))
12080 : : {
12081 : 2 : case SSA_NAME:
12082 : 2 : if (gimple *_d6 = get_def (valueize, _q100))
12083 : : {
12084 : 2 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
12085 : 2 : switch (gimple_assign_rhs_code (_a6))
12086 : : {
12087 : 2 : case PLUS_EXPR:
12088 : 2 : {
12089 : 2 : tree _q110 = gimple_assign_rhs1 (_a6);
12090 : 2 : _q110 = do_valueize (valueize, _q110);
12091 : 2 : tree _q111 = gimple_assign_rhs2 (_a6);
12092 : 2 : _q111 = do_valueize (valueize, _q111);
12093 : 2 : if (tree_swap_operands_p (_q110, _q111))
12094 : 0 : std::swap (_q110, _q111);
12095 : 2 : {
12096 : 2 : tree _q110_pops[1];
12097 : 2 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
12098 : : {
12099 : 2 : tree _q120 = _q110_pops[0];
12100 : 2 : if ((_q120 == _q50 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q50, 0) && types_match (_q120, _q50)))
12101 : : {
12102 : 2 : {
12103 : 2 : tree _q111_pops[1];
12104 : 2 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
12105 : : {
12106 : 2 : tree _q140 = _q111_pops[0];
12107 : 2 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
12108 : : {
12109 : 2 : if (integer_zerop (_q21))
12110 : : {
12111 : 2 : {
12112 : 2 : tree _p1_pops[1];
12113 : 2 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
12114 : : {
12115 : 2 : tree _q170 = _p1_pops[0];
12116 : 2 : if ((_q170 == _q50 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q50, 0) && types_match (_q170, _q50)))
12117 : : {
12118 : 2 : if ((_p2 == _q81 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q81, 0) && types_match (_p2, _q81)))
12119 : : {
12120 : 2 : {
12121 : 2 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
12122 : 2 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
12123 : : )
12124 : : {
12125 : 2 : {
12126 : 2 : res_ops[0] = captures[0];
12127 : 2 : res_ops[1] = captures[1];
12128 : 2 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
12129 : 2 : return true;
12130 : : }
12131 : : }
12132 : : }
12133 : : }
12134 : : }
12135 : : }
12136 : : }
12137 : : }
12138 : : }
12139 : : }
12140 : : }
12141 : : }
12142 : : }
12143 : : }
12144 : 0 : break;
12145 : : }
12146 : : default:;
12147 : : }
12148 : : }
12149 : : break;
12150 : : default:;
12151 : : }
12152 : : }
12153 : : }
12154 : : }
12155 : 0 : if ((_q80 == _q51 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q51, 0) && types_match (_q80, _q51)))
12156 : : {
12157 : 0 : {
12158 : 0 : tree _q81_pops[1];
12159 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
12160 : : {
12161 : 0 : tree _q100 = _q81_pops[0];
12162 : 0 : switch (TREE_CODE (_q100))
12163 : : {
12164 : 0 : case SSA_NAME:
12165 : 0 : if (gimple *_d6 = get_def (valueize, _q100))
12166 : : {
12167 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
12168 : 0 : switch (gimple_assign_rhs_code (_a6))
12169 : : {
12170 : 0 : case PLUS_EXPR:
12171 : 0 : {
12172 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
12173 : 0 : _q110 = do_valueize (valueize, _q110);
12174 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
12175 : 0 : _q111 = do_valueize (valueize, _q111);
12176 : 0 : if (tree_swap_operands_p (_q110, _q111))
12177 : 0 : std::swap (_q110, _q111);
12178 : 0 : {
12179 : 0 : tree _q110_pops[1];
12180 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
12181 : : {
12182 : 0 : tree _q120 = _q110_pops[0];
12183 : 0 : if ((_q120 == _q51 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q51, 0) && types_match (_q120, _q51)))
12184 : : {
12185 : 0 : {
12186 : 0 : tree _q111_pops[1];
12187 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
12188 : : {
12189 : 0 : tree _q140 = _q111_pops[0];
12190 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
12191 : : {
12192 : 0 : if (integer_zerop (_q21))
12193 : : {
12194 : 0 : {
12195 : 0 : tree _p1_pops[1];
12196 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
12197 : : {
12198 : 0 : tree _q170 = _p1_pops[0];
12199 : 0 : if ((_q170 == _q51 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q51, 0) && types_match (_q170, _q51)))
12200 : : {
12201 : 0 : if ((_p2 == _q81 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q81, 0) && types_match (_p2, _q81)))
12202 : : {
12203 : 0 : {
12204 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
12205 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
12206 : : )
12207 : : {
12208 : 0 : {
12209 : 0 : res_ops[0] = captures[0];
12210 : 0 : res_ops[1] = captures[1];
12211 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
12212 : 0 : return true;
12213 : : }
12214 : : }
12215 : : }
12216 : : }
12217 : : }
12218 : : }
12219 : : }
12220 : : }
12221 : : }
12222 : : }
12223 : : }
12224 : : }
12225 : : }
12226 : : }
12227 : 0 : break;
12228 : : }
12229 : : default:;
12230 : : }
12231 : : }
12232 : : break;
12233 : : default:;
12234 : : }
12235 : : }
12236 : : }
12237 : : }
12238 : 0 : {
12239 : 0 : tree _q80_pops[1];
12240 : 0 : if (gimple_nop_convert (_q80, _q80_pops, valueize))
12241 : : {
12242 : 0 : tree _q90 = _q80_pops[0];
12243 : 0 : switch (TREE_CODE (_q90))
12244 : : {
12245 : 0 : case SSA_NAME:
12246 : 0 : if (gimple *_d6 = get_def (valueize, _q90))
12247 : : {
12248 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
12249 : 0 : switch (gimple_assign_rhs_code (_a6))
12250 : : {
12251 : 0 : case PLUS_EXPR:
12252 : 0 : {
12253 : 0 : tree _q100 = gimple_assign_rhs1 (_a6);
12254 : 0 : _q100 = do_valueize (valueize, _q100);
12255 : 0 : tree _q101 = gimple_assign_rhs2 (_a6);
12256 : 0 : _q101 = do_valueize (valueize, _q101);
12257 : 0 : if (tree_swap_operands_p (_q100, _q101))
12258 : 0 : std::swap (_q100, _q101);
12259 : 0 : {
12260 : 0 : tree _q100_pops[1];
12261 : 0 : if (gimple_nop_convert (_q100, _q100_pops, valueize))
12262 : : {
12263 : 0 : tree _q110 = _q100_pops[0];
12264 : 0 : if ((_q110 == _q50 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q50, 0) && types_match (_q110, _q50)))
12265 : : {
12266 : 0 : {
12267 : 0 : tree _q101_pops[1];
12268 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
12269 : : {
12270 : 0 : tree _q130 = _q101_pops[0];
12271 : 0 : if ((_q130 == _q51 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q51, 0) && types_match (_q130, _q51)))
12272 : : {
12273 : 0 : if ((_q81 == _q50 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q50, 0) && types_match (_q81, _q50)))
12274 : : {
12275 : 0 : if (integer_zerop (_q21))
12276 : : {
12277 : 0 : {
12278 : 0 : tree _p1_pops[1];
12279 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
12280 : : {
12281 : 0 : tree _q170 = _p1_pops[0];
12282 : 0 : if ((_q170 == _q50 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q50, 0) && types_match (_q170, _q50)))
12283 : : {
12284 : 0 : if ((_p2 == _q80 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q80, 0) && types_match (_p2, _q80)))
12285 : : {
12286 : 0 : {
12287 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q80 };
12288 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
12289 : : )
12290 : : {
12291 : 0 : {
12292 : 0 : res_ops[0] = captures[0];
12293 : 0 : res_ops[1] = captures[1];
12294 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
12295 : 0 : return true;
12296 : : }
12297 : : }
12298 : : }
12299 : : }
12300 : : }
12301 : : }
12302 : : }
12303 : : }
12304 : : }
12305 : : }
12306 : : }
12307 : : }
12308 : : }
12309 : 0 : if ((_q110 == _q51 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q51, 0) && types_match (_q110, _q51)))
12310 : : {
12311 : 0 : {
12312 : 0 : tree _q101_pops[1];
12313 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
12314 : : {
12315 : 0 : tree _q130 = _q101_pops[0];
12316 : 0 : if ((_q130 == _q50 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q50, 0) && types_match (_q130, _q50)))
12317 : : {
12318 : 0 : if ((_q81 == _q51 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q51, 0) && types_match (_q81, _q51)))
12319 : : {
12320 : 0 : if (integer_zerop (_q21))
12321 : : {
12322 : 0 : {
12323 : 0 : tree _p1_pops[1];
12324 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
12325 : : {
12326 : 0 : tree _q170 = _p1_pops[0];
12327 : 0 : if ((_q170 == _q51 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q51, 0) && types_match (_q170, _q51)))
12328 : : {
12329 : 0 : if ((_p2 == _q80 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q80, 0) && types_match (_p2, _q80)))
12330 : : {
12331 : 0 : {
12332 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q80 };
12333 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
12334 : : )
12335 : : {
12336 : 0 : {
12337 : 0 : res_ops[0] = captures[0];
12338 : 0 : res_ops[1] = captures[1];
12339 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 71, __FILE__, __LINE__, false);
12340 : 0 : return true;
12341 : : }
12342 : : }
12343 : : }
12344 : : }
12345 : : }
12346 : : }
12347 : : }
12348 : : }
12349 : : }
12350 : : }
12351 : : }
12352 : : }
12353 : : }
12354 : : }
12355 : : }
12356 : 0 : break;
12357 : : }
12358 : : default:;
12359 : : }
12360 : : }
12361 : : break;
12362 : : default:;
12363 : : }
12364 : : }
12365 : : }
12366 : 0 : break;
12367 : : }
12368 : : default:;
12369 : : }
12370 : : }
12371 : : break;
12372 : : default:;
12373 : : }
12374 : 3365690 : break;
12375 : : }
12376 : : default:;
12377 : : }
12378 : : }
12379 : : break;
12380 : : default:;
12381 : : }
12382 : : break;
12383 : : }
12384 : : default:;
12385 : : }
12386 : : }
12387 : : break;
12388 : : default:;
12389 : : }
12390 : 3365690 : break;
12391 : : }
12392 : : default:;
12393 : : }
12394 : : }
12395 : : break;
12396 : : default:;
12397 : : }
12398 : : }
12399 : : }
12400 : : break;
12401 : : }
12402 : 9261 : case GE_EXPR:
12403 : 9261 : {
12404 : 9261 : tree _q20 = TREE_OPERAND (_p0, 0);
12405 : 9261 : if ((TREE_CODE (_q20) == SSA_NAME
12406 : 9261 : || is_gimple_min_invariant (_q20)))
12407 : : {
12408 : 9261 : _q20 = do_valueize (valueize, _q20);
12409 : 9261 : tree _q21 = TREE_OPERAND (_p0, 1);
12410 : 9261 : if ((TREE_CODE (_q21) == SSA_NAME
12411 : 9261 : || is_gimple_min_invariant (_q21)))
12412 : : {
12413 : 9261 : _q21 = do_valueize (valueize, _q21);
12414 : 9261 : switch (TREE_CODE (_q20))
12415 : : {
12416 : 9251 : case SSA_NAME:
12417 : 9251 : if (gimple *_d2 = get_def (valueize, _q20))
12418 : : {
12419 : 9251 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
12420 : 9280 : switch (gimple_assign_rhs_code (_a2))
12421 : : {
12422 : 1 : case BIT_AND_EXPR:
12423 : 1 : {
12424 : 1 : tree _q30 = gimple_assign_rhs1 (_a2);
12425 : 1 : _q30 = do_valueize (valueize, _q30);
12426 : 1 : tree _q31 = gimple_assign_rhs2 (_a2);
12427 : 1 : _q31 = do_valueize (valueize, _q31);
12428 : 1 : if (tree_swap_operands_p (_q30, _q31))
12429 : 0 : std::swap (_q30, _q31);
12430 : 1 : switch (TREE_CODE (_q30))
12431 : : {
12432 : 1 : case SSA_NAME:
12433 : 1 : if (gimple *_d3 = get_def (valueize, _q30))
12434 : : {
12435 : 1 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
12436 : 1 : switch (gimple_assign_rhs_code (_a3))
12437 : : {
12438 : 0 : case BIT_XOR_EXPR:
12439 : 0 : {
12440 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
12441 : 0 : _q40 = do_valueize (valueize, _q40);
12442 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
12443 : 0 : _q41 = do_valueize (valueize, _q41);
12444 : 0 : if (tree_swap_operands_p (_q40, _q41))
12445 : 0 : std::swap (_q40, _q41);
12446 : 0 : {
12447 : 0 : tree _q41_pops[1];
12448 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
12449 : : {
12450 : 0 : tree _q60 = _q41_pops[0];
12451 : 0 : switch (TREE_CODE (_q60))
12452 : : {
12453 : 0 : case SSA_NAME:
12454 : 0 : if (gimple *_d4 = get_def (valueize, _q60))
12455 : : {
12456 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
12457 : 0 : switch (gimple_assign_rhs_code (_a4))
12458 : : {
12459 : 0 : case PLUS_EXPR:
12460 : 0 : {
12461 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
12462 : 0 : _q70 = do_valueize (valueize, _q70);
12463 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
12464 : 0 : _q71 = do_valueize (valueize, _q71);
12465 : 0 : if (tree_swap_operands_p (_q70, _q71))
12466 : 0 : std::swap (_q70, _q71);
12467 : 0 : {
12468 : 0 : tree _q70_pops[1];
12469 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
12470 : : {
12471 : 0 : tree _q80 = _q70_pops[0];
12472 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
12473 : : {
12474 : 0 : {
12475 : 0 : tree _q71_pops[1];
12476 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
12477 : : {
12478 : 0 : tree _q100 = _q71_pops[0];
12479 : 0 : switch (TREE_CODE (_q31))
12480 : : {
12481 : 0 : case SSA_NAME:
12482 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
12483 : : {
12484 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
12485 : 0 : switch (gimple_assign_rhs_code (_a5))
12486 : : {
12487 : 0 : case BIT_NOT_EXPR:
12488 : 0 : {
12489 : 0 : tree _q120 = gimple_assign_rhs1 (_a5);
12490 : 0 : _q120 = do_valueize (valueize, _q120);
12491 : 0 : switch (TREE_CODE (_q120))
12492 : : {
12493 : 0 : case SSA_NAME:
12494 : 0 : if (gimple *_d6 = get_def (valueize, _q120))
12495 : : {
12496 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
12497 : 0 : switch (gimple_assign_rhs_code (_a6))
12498 : : {
12499 : 0 : case BIT_XOR_EXPR:
12500 : 0 : {
12501 : 0 : tree _q130 = gimple_assign_rhs1 (_a6);
12502 : 0 : _q130 = do_valueize (valueize, _q130);
12503 : 0 : tree _q131 = gimple_assign_rhs2 (_a6);
12504 : 0 : _q131 = do_valueize (valueize, _q131);
12505 : 0 : if (tree_swap_operands_p (_q130, _q131))
12506 : 0 : std::swap (_q130, _q131);
12507 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
12508 : : {
12509 : 0 : if ((_q131 == _q100 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q100, 0) && types_match (_q131, _q100)))
12510 : : {
12511 : 0 : if (integer_zerop (_q21))
12512 : : {
12513 : 0 : if ((_p1 == _q41 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q41, 0) && types_match (_p1, _q41)))
12514 : : {
12515 : 0 : switch (TREE_CODE (_p2))
12516 : : {
12517 : 0 : case SSA_NAME:
12518 : 0 : if (gimple *_d7 = get_def (valueize, _p2))
12519 : : {
12520 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
12521 : 0 : switch (gimple_assign_rhs_code (_a7))
12522 : : {
12523 : 0 : case BIT_XOR_EXPR:
12524 : 0 : {
12525 : 0 : tree _q180 = gimple_assign_rhs1 (_a7);
12526 : 0 : _q180 = do_valueize (valueize, _q180);
12527 : 0 : tree _q181 = gimple_assign_rhs2 (_a7);
12528 : 0 : _q181 = do_valueize (valueize, _q181);
12529 : 0 : if (tree_swap_operands_p (_q180, _q181))
12530 : 0 : std::swap (_q180, _q181);
12531 : 0 : switch (TREE_CODE (_q180))
12532 : : {
12533 : 0 : case SSA_NAME:
12534 : 0 : if (gimple *_d8 = get_def (valueize, _q180))
12535 : : {
12536 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
12537 : 0 : switch (gimple_assign_rhs_code (_a8))
12538 : : {
12539 : 0 : case NEGATE_EXPR:
12540 : 0 : {
12541 : 0 : tree _q190 = gimple_assign_rhs1 (_a8);
12542 : 0 : _q190 = do_valueize (valueize, _q190);
12543 : 0 : switch (TREE_CODE (_q190))
12544 : : {
12545 : 0 : case SSA_NAME:
12546 : 0 : if (gimple *_d9 = get_def (valueize, _q190))
12547 : : {
12548 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
12549 : 0 : switch (gimple_assign_rhs_code (_a9))
12550 : : {
12551 : 0 : CASE_CONVERT:
12552 : 0 : {
12553 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
12554 : 0 : _q200 = do_valueize (valueize, _q200);
12555 : 0 : switch (TREE_CODE (_q200))
12556 : : {
12557 : 0 : case SSA_NAME:
12558 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
12559 : : {
12560 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
12561 : 0 : switch (gimple_assign_rhs_code (_a10))
12562 : : {
12563 : 0 : case LT_EXPR:
12564 : 0 : {
12565 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
12566 : 0 : _q210 = do_valueize (valueize, _q210);
12567 : 0 : tree _q211 = gimple_assign_rhs2 (_a10);
12568 : 0 : _q211 = do_valueize (valueize, _q211);
12569 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
12570 : : {
12571 : 0 : if (integer_zerop (_q211))
12572 : : {
12573 : 0 : if (gimple_max_value (_q181, valueize))
12574 : : {
12575 : 0 : {
12576 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
12577 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
12578 : : )
12579 : : {
12580 : 0 : {
12581 : 0 : res_ops[0] = captures[0];
12582 : 0 : res_ops[1] = captures[1];
12583 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
12584 : 0 : return true;
12585 : : }
12586 : : }
12587 : : }
12588 : : }
12589 : : }
12590 : : }
12591 : : break;
12592 : : }
12593 : : default:;
12594 : : }
12595 : : }
12596 : : break;
12597 : : default:;
12598 : : }
12599 : : break;
12600 : : }
12601 : : default:;
12602 : : }
12603 : : }
12604 : : break;
12605 : : default:;
12606 : : }
12607 : : break;
12608 : : }
12609 : : default:;
12610 : : }
12611 : : }
12612 : : break;
12613 : 0 : default:;
12614 : : }
12615 : 0 : if (gimple_max_value (_q180, valueize))
12616 : : {
12617 : 0 : switch (TREE_CODE (_q181))
12618 : : {
12619 : 0 : case SSA_NAME:
12620 : 0 : if (gimple *_d8 = get_def (valueize, _q181))
12621 : : {
12622 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
12623 : 0 : switch (gimple_assign_rhs_code (_a8))
12624 : : {
12625 : 0 : case NEGATE_EXPR:
12626 : 0 : {
12627 : 0 : tree _q200 = gimple_assign_rhs1 (_a8);
12628 : 0 : _q200 = do_valueize (valueize, _q200);
12629 : 0 : switch (TREE_CODE (_q200))
12630 : : {
12631 : 0 : case SSA_NAME:
12632 : 0 : if (gimple *_d9 = get_def (valueize, _q200))
12633 : : {
12634 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
12635 : 0 : switch (gimple_assign_rhs_code (_a9))
12636 : : {
12637 : 0 : CASE_CONVERT:
12638 : 0 : {
12639 : 0 : tree _q210 = gimple_assign_rhs1 (_a9);
12640 : 0 : _q210 = do_valueize (valueize, _q210);
12641 : 0 : switch (TREE_CODE (_q210))
12642 : : {
12643 : 0 : case SSA_NAME:
12644 : 0 : if (gimple *_d10 = get_def (valueize, _q210))
12645 : : {
12646 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
12647 : 0 : switch (gimple_assign_rhs_code (_a10))
12648 : : {
12649 : 0 : case LT_EXPR:
12650 : 0 : {
12651 : 0 : tree _q220 = gimple_assign_rhs1 (_a10);
12652 : 0 : _q220 = do_valueize (valueize, _q220);
12653 : 0 : tree _q221 = gimple_assign_rhs2 (_a10);
12654 : 0 : _q221 = do_valueize (valueize, _q221);
12655 : 0 : if ((_q220 == _q40 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q40, 0) && types_match (_q220, _q40)))
12656 : : {
12657 : 0 : if (integer_zerop (_q221))
12658 : : {
12659 : 0 : {
12660 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
12661 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
12662 : : )
12663 : : {
12664 : 0 : {
12665 : 0 : res_ops[0] = captures[0];
12666 : 0 : res_ops[1] = captures[1];
12667 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
12668 : 0 : return true;
12669 : : }
12670 : : }
12671 : : }
12672 : : }
12673 : : }
12674 : : break;
12675 : : }
12676 : : default:;
12677 : : }
12678 : : }
12679 : : break;
12680 : : default:;
12681 : : }
12682 : : break;
12683 : : }
12684 : : default:;
12685 : : }
12686 : : }
12687 : : break;
12688 : : default:;
12689 : : }
12690 : : break;
12691 : : }
12692 : : default:;
12693 : : }
12694 : : }
12695 : : break;
12696 : : default:;
12697 : : }
12698 : : }
12699 : 0 : break;
12700 : : }
12701 : : default:;
12702 : : }
12703 : : }
12704 : : break;
12705 : : default:;
12706 : : }
12707 : : }
12708 : : }
12709 : : }
12710 : : }
12711 : 0 : if ((_q130 == _q100 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q100, 0) && types_match (_q130, _q100)))
12712 : : {
12713 : 0 : if ((_q131 == _q40 && ! TREE_SIDE_EFFECTS (_q131)) || (operand_equal_p (_q131, _q40, 0) && types_match (_q131, _q40)))
12714 : : {
12715 : 0 : if (integer_zerop (_q21))
12716 : : {
12717 : 0 : if ((_p1 == _q41 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q41, 0) && types_match (_p1, _q41)))
12718 : : {
12719 : 0 : switch (TREE_CODE (_p2))
12720 : : {
12721 : 0 : case SSA_NAME:
12722 : 0 : if (gimple *_d7 = get_def (valueize, _p2))
12723 : : {
12724 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
12725 : 0 : switch (gimple_assign_rhs_code (_a7))
12726 : : {
12727 : 0 : case BIT_XOR_EXPR:
12728 : 0 : {
12729 : 0 : tree _q180 = gimple_assign_rhs1 (_a7);
12730 : 0 : _q180 = do_valueize (valueize, _q180);
12731 : 0 : tree _q181 = gimple_assign_rhs2 (_a7);
12732 : 0 : _q181 = do_valueize (valueize, _q181);
12733 : 0 : if (tree_swap_operands_p (_q180, _q181))
12734 : 0 : std::swap (_q180, _q181);
12735 : 0 : switch (TREE_CODE (_q180))
12736 : : {
12737 : 0 : case SSA_NAME:
12738 : 0 : if (gimple *_d8 = get_def (valueize, _q180))
12739 : : {
12740 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
12741 : 0 : switch (gimple_assign_rhs_code (_a8))
12742 : : {
12743 : 0 : case NEGATE_EXPR:
12744 : 0 : {
12745 : 0 : tree _q190 = gimple_assign_rhs1 (_a8);
12746 : 0 : _q190 = do_valueize (valueize, _q190);
12747 : 0 : switch (TREE_CODE (_q190))
12748 : : {
12749 : 0 : case SSA_NAME:
12750 : 0 : if (gimple *_d9 = get_def (valueize, _q190))
12751 : : {
12752 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
12753 : 0 : switch (gimple_assign_rhs_code (_a9))
12754 : : {
12755 : 0 : CASE_CONVERT:
12756 : 0 : {
12757 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
12758 : 0 : _q200 = do_valueize (valueize, _q200);
12759 : 0 : switch (TREE_CODE (_q200))
12760 : : {
12761 : 0 : case SSA_NAME:
12762 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
12763 : : {
12764 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
12765 : 0 : switch (gimple_assign_rhs_code (_a10))
12766 : : {
12767 : 0 : case LT_EXPR:
12768 : 0 : {
12769 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
12770 : 0 : _q210 = do_valueize (valueize, _q210);
12771 : 0 : tree _q211 = gimple_assign_rhs2 (_a10);
12772 : 0 : _q211 = do_valueize (valueize, _q211);
12773 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
12774 : : {
12775 : 0 : if (integer_zerop (_q211))
12776 : : {
12777 : 0 : if (gimple_max_value (_q181, valueize))
12778 : : {
12779 : 0 : {
12780 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
12781 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
12782 : : )
12783 : : {
12784 : 0 : {
12785 : 0 : res_ops[0] = captures[0];
12786 : 0 : res_ops[1] = captures[1];
12787 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
12788 : 0 : return true;
12789 : : }
12790 : : }
12791 : : }
12792 : : }
12793 : : }
12794 : : }
12795 : : break;
12796 : : }
12797 : : default:;
12798 : : }
12799 : : }
12800 : : break;
12801 : : default:;
12802 : : }
12803 : : break;
12804 : : }
12805 : : default:;
12806 : : }
12807 : : }
12808 : : break;
12809 : : default:;
12810 : : }
12811 : : break;
12812 : : }
12813 : : default:;
12814 : : }
12815 : : }
12816 : : break;
12817 : 0 : default:;
12818 : : }
12819 : 0 : if (gimple_max_value (_q180, valueize))
12820 : : {
12821 : 0 : switch (TREE_CODE (_q181))
12822 : : {
12823 : 0 : case SSA_NAME:
12824 : 0 : if (gimple *_d8 = get_def (valueize, _q181))
12825 : : {
12826 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
12827 : 0 : switch (gimple_assign_rhs_code (_a8))
12828 : : {
12829 : 0 : case NEGATE_EXPR:
12830 : 0 : {
12831 : 0 : tree _q200 = gimple_assign_rhs1 (_a8);
12832 : 0 : _q200 = do_valueize (valueize, _q200);
12833 : 0 : switch (TREE_CODE (_q200))
12834 : : {
12835 : 0 : case SSA_NAME:
12836 : 0 : if (gimple *_d9 = get_def (valueize, _q200))
12837 : : {
12838 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
12839 : 0 : switch (gimple_assign_rhs_code (_a9))
12840 : : {
12841 : 0 : CASE_CONVERT:
12842 : 0 : {
12843 : 0 : tree _q210 = gimple_assign_rhs1 (_a9);
12844 : 0 : _q210 = do_valueize (valueize, _q210);
12845 : 0 : switch (TREE_CODE (_q210))
12846 : : {
12847 : 0 : case SSA_NAME:
12848 : 0 : if (gimple *_d10 = get_def (valueize, _q210))
12849 : : {
12850 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
12851 : 0 : switch (gimple_assign_rhs_code (_a10))
12852 : : {
12853 : 0 : case LT_EXPR:
12854 : 0 : {
12855 : 0 : tree _q220 = gimple_assign_rhs1 (_a10);
12856 : 0 : _q220 = do_valueize (valueize, _q220);
12857 : 0 : tree _q221 = gimple_assign_rhs2 (_a10);
12858 : 0 : _q221 = do_valueize (valueize, _q221);
12859 : 0 : if ((_q220 == _q40 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q40, 0) && types_match (_q220, _q40)))
12860 : : {
12861 : 0 : if (integer_zerop (_q221))
12862 : : {
12863 : 0 : {
12864 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
12865 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
12866 : : )
12867 : : {
12868 : 0 : {
12869 : 0 : res_ops[0] = captures[0];
12870 : 0 : res_ops[1] = captures[1];
12871 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
12872 : 0 : return true;
12873 : : }
12874 : : }
12875 : : }
12876 : : }
12877 : : }
12878 : : break;
12879 : : }
12880 : : default:;
12881 : : }
12882 : : }
12883 : : break;
12884 : : default:;
12885 : : }
12886 : : break;
12887 : : }
12888 : : default:;
12889 : : }
12890 : : }
12891 : : break;
12892 : : default:;
12893 : : }
12894 : : break;
12895 : : }
12896 : : default:;
12897 : : }
12898 : : }
12899 : : break;
12900 : : default:;
12901 : : }
12902 : : }
12903 : 0 : break;
12904 : : }
12905 : : default:;
12906 : : }
12907 : : }
12908 : : break;
12909 : : default:;
12910 : : }
12911 : : }
12912 : : }
12913 : : }
12914 : : }
12915 : 0 : break;
12916 : : }
12917 : : default:;
12918 : : }
12919 : : }
12920 : : break;
12921 : : default:;
12922 : : }
12923 : : break;
12924 : : }
12925 : : default:;
12926 : : }
12927 : : }
12928 : : break;
12929 : : default:;
12930 : : }
12931 : : }
12932 : : }
12933 : : }
12934 : : }
12935 : : }
12936 : 0 : break;
12937 : : }
12938 : : default:;
12939 : : }
12940 : : }
12941 : : break;
12942 : : default:;
12943 : : }
12944 : : }
12945 : : }
12946 : 0 : break;
12947 : : }
12948 : 0 : case BIT_NOT_EXPR:
12949 : 0 : {
12950 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
12951 : 0 : _q40 = do_valueize (valueize, _q40);
12952 : 0 : switch (TREE_CODE (_q40))
12953 : : {
12954 : 0 : case SSA_NAME:
12955 : 0 : if (gimple *_d4 = get_def (valueize, _q40))
12956 : : {
12957 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
12958 : 0 : switch (gimple_assign_rhs_code (_a4))
12959 : : {
12960 : 0 : case BIT_XOR_EXPR:
12961 : 0 : {
12962 : 0 : tree _q50 = gimple_assign_rhs1 (_a4);
12963 : 0 : _q50 = do_valueize (valueize, _q50);
12964 : 0 : tree _q51 = gimple_assign_rhs2 (_a4);
12965 : 0 : _q51 = do_valueize (valueize, _q51);
12966 : 0 : if (tree_swap_operands_p (_q50, _q51))
12967 : 0 : std::swap (_q50, _q51);
12968 : 0 : switch (TREE_CODE (_q31))
12969 : : {
12970 : 0 : case SSA_NAME:
12971 : 0 : if (gimple *_d5 = get_def (valueize, _q31))
12972 : : {
12973 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
12974 : 0 : switch (gimple_assign_rhs_code (_a5))
12975 : : {
12976 : 0 : case BIT_XOR_EXPR:
12977 : 0 : {
12978 : 0 : tree _q80 = gimple_assign_rhs1 (_a5);
12979 : 0 : _q80 = do_valueize (valueize, _q80);
12980 : 0 : tree _q81 = gimple_assign_rhs2 (_a5);
12981 : 0 : _q81 = do_valueize (valueize, _q81);
12982 : 0 : if (tree_swap_operands_p (_q80, _q81))
12983 : 0 : std::swap (_q80, _q81);
12984 : 0 : if ((_q80 == _q50 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q50, 0) && types_match (_q80, _q50)))
12985 : : {
12986 : 0 : {
12987 : 0 : tree _q81_pops[1];
12988 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
12989 : : {
12990 : 0 : tree _q100 = _q81_pops[0];
12991 : 0 : switch (TREE_CODE (_q100))
12992 : : {
12993 : 0 : case SSA_NAME:
12994 : 0 : if (gimple *_d6 = get_def (valueize, _q100))
12995 : : {
12996 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
12997 : 0 : switch (gimple_assign_rhs_code (_a6))
12998 : : {
12999 : 0 : case PLUS_EXPR:
13000 : 0 : {
13001 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
13002 : 0 : _q110 = do_valueize (valueize, _q110);
13003 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
13004 : 0 : _q111 = do_valueize (valueize, _q111);
13005 : 0 : if (tree_swap_operands_p (_q110, _q111))
13006 : 0 : std::swap (_q110, _q111);
13007 : 0 : {
13008 : 0 : tree _q110_pops[1];
13009 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
13010 : : {
13011 : 0 : tree _q120 = _q110_pops[0];
13012 : 0 : if ((_q120 == _q50 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q50, 0) && types_match (_q120, _q50)))
13013 : : {
13014 : 0 : {
13015 : 0 : tree _q111_pops[1];
13016 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
13017 : : {
13018 : 0 : tree _q140 = _q111_pops[0];
13019 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
13020 : : {
13021 : 0 : if (integer_zerop (_q21))
13022 : : {
13023 : 0 : if ((_p1 == _q81 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q81, 0) && types_match (_p1, _q81)))
13024 : : {
13025 : 0 : switch (TREE_CODE (_p2))
13026 : : {
13027 : 0 : case SSA_NAME:
13028 : 0 : if (gimple *_d7 = get_def (valueize, _p2))
13029 : : {
13030 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
13031 : 0 : switch (gimple_assign_rhs_code (_a7))
13032 : : {
13033 : 0 : case BIT_XOR_EXPR:
13034 : 0 : {
13035 : 0 : tree _q180 = gimple_assign_rhs1 (_a7);
13036 : 0 : _q180 = do_valueize (valueize, _q180);
13037 : 0 : tree _q181 = gimple_assign_rhs2 (_a7);
13038 : 0 : _q181 = do_valueize (valueize, _q181);
13039 : 0 : if (tree_swap_operands_p (_q180, _q181))
13040 : 0 : std::swap (_q180, _q181);
13041 : 0 : switch (TREE_CODE (_q180))
13042 : : {
13043 : 0 : case SSA_NAME:
13044 : 0 : if (gimple *_d8 = get_def (valueize, _q180))
13045 : : {
13046 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
13047 : 0 : switch (gimple_assign_rhs_code (_a8))
13048 : : {
13049 : 0 : case NEGATE_EXPR:
13050 : 0 : {
13051 : 0 : tree _q190 = gimple_assign_rhs1 (_a8);
13052 : 0 : _q190 = do_valueize (valueize, _q190);
13053 : 0 : switch (TREE_CODE (_q190))
13054 : : {
13055 : 0 : case SSA_NAME:
13056 : 0 : if (gimple *_d9 = get_def (valueize, _q190))
13057 : : {
13058 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
13059 : 0 : switch (gimple_assign_rhs_code (_a9))
13060 : : {
13061 : 0 : CASE_CONVERT:
13062 : 0 : {
13063 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
13064 : 0 : _q200 = do_valueize (valueize, _q200);
13065 : 0 : switch (TREE_CODE (_q200))
13066 : : {
13067 : 0 : case SSA_NAME:
13068 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
13069 : : {
13070 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
13071 : 0 : switch (gimple_assign_rhs_code (_a10))
13072 : : {
13073 : 0 : case LT_EXPR:
13074 : 0 : {
13075 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
13076 : 0 : _q210 = do_valueize (valueize, _q210);
13077 : 0 : tree _q211 = gimple_assign_rhs2 (_a10);
13078 : 0 : _q211 = do_valueize (valueize, _q211);
13079 : 0 : if ((_q210 == _q50 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q50, 0) && types_match (_q210, _q50)))
13080 : : {
13081 : 0 : if (integer_zerop (_q211))
13082 : : {
13083 : 0 : if (gimple_max_value (_q181, valueize))
13084 : : {
13085 : 0 : {
13086 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
13087 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13088 : : )
13089 : : {
13090 : 0 : {
13091 : 0 : res_ops[0] = captures[0];
13092 : 0 : res_ops[1] = captures[1];
13093 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
13094 : 0 : return true;
13095 : : }
13096 : : }
13097 : : }
13098 : : }
13099 : : }
13100 : : }
13101 : : break;
13102 : : }
13103 : : default:;
13104 : : }
13105 : : }
13106 : : break;
13107 : : default:;
13108 : : }
13109 : : break;
13110 : : }
13111 : : default:;
13112 : : }
13113 : : }
13114 : : break;
13115 : : default:;
13116 : : }
13117 : : break;
13118 : : }
13119 : : default:;
13120 : : }
13121 : : }
13122 : : break;
13123 : 0 : default:;
13124 : : }
13125 : 0 : if (gimple_max_value (_q180, valueize))
13126 : : {
13127 : 0 : switch (TREE_CODE (_q181))
13128 : : {
13129 : 0 : case SSA_NAME:
13130 : 0 : if (gimple *_d8 = get_def (valueize, _q181))
13131 : : {
13132 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
13133 : 0 : switch (gimple_assign_rhs_code (_a8))
13134 : : {
13135 : 0 : case NEGATE_EXPR:
13136 : 0 : {
13137 : 0 : tree _q200 = gimple_assign_rhs1 (_a8);
13138 : 0 : _q200 = do_valueize (valueize, _q200);
13139 : 0 : switch (TREE_CODE (_q200))
13140 : : {
13141 : 0 : case SSA_NAME:
13142 : 0 : if (gimple *_d9 = get_def (valueize, _q200))
13143 : : {
13144 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
13145 : 0 : switch (gimple_assign_rhs_code (_a9))
13146 : : {
13147 : 0 : CASE_CONVERT:
13148 : 0 : {
13149 : 0 : tree _q210 = gimple_assign_rhs1 (_a9);
13150 : 0 : _q210 = do_valueize (valueize, _q210);
13151 : 0 : switch (TREE_CODE (_q210))
13152 : : {
13153 : 0 : case SSA_NAME:
13154 : 0 : if (gimple *_d10 = get_def (valueize, _q210))
13155 : : {
13156 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
13157 : 0 : switch (gimple_assign_rhs_code (_a10))
13158 : : {
13159 : 0 : case LT_EXPR:
13160 : 0 : {
13161 : 0 : tree _q220 = gimple_assign_rhs1 (_a10);
13162 : 0 : _q220 = do_valueize (valueize, _q220);
13163 : 0 : tree _q221 = gimple_assign_rhs2 (_a10);
13164 : 0 : _q221 = do_valueize (valueize, _q221);
13165 : 0 : if ((_q220 == _q50 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q50, 0) && types_match (_q220, _q50)))
13166 : : {
13167 : 0 : if (integer_zerop (_q221))
13168 : : {
13169 : 0 : {
13170 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q81 };
13171 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13172 : : )
13173 : : {
13174 : 0 : {
13175 : 0 : res_ops[0] = captures[0];
13176 : 0 : res_ops[1] = captures[1];
13177 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
13178 : 0 : return true;
13179 : : }
13180 : : }
13181 : : }
13182 : : }
13183 : : }
13184 : : break;
13185 : : }
13186 : : default:;
13187 : : }
13188 : : }
13189 : : break;
13190 : : default:;
13191 : : }
13192 : : break;
13193 : : }
13194 : : default:;
13195 : : }
13196 : : }
13197 : : break;
13198 : : default:;
13199 : : }
13200 : : break;
13201 : : }
13202 : : default:;
13203 : : }
13204 : : }
13205 : : break;
13206 : : default:;
13207 : : }
13208 : : }
13209 : 0 : break;
13210 : : }
13211 : : default:;
13212 : : }
13213 : : }
13214 : : break;
13215 : : default:;
13216 : : }
13217 : : }
13218 : : }
13219 : : }
13220 : : }
13221 : : }
13222 : : }
13223 : : }
13224 : : }
13225 : 0 : break;
13226 : : }
13227 : : default:;
13228 : : }
13229 : : }
13230 : : break;
13231 : : default:;
13232 : : }
13233 : : }
13234 : : }
13235 : : }
13236 : 0 : if ((_q80 == _q51 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q51, 0) && types_match (_q80, _q51)))
13237 : : {
13238 : 0 : {
13239 : 0 : tree _q81_pops[1];
13240 : 0 : if (gimple_nop_convert (_q81, _q81_pops, valueize))
13241 : : {
13242 : 0 : tree _q100 = _q81_pops[0];
13243 : 0 : switch (TREE_CODE (_q100))
13244 : : {
13245 : 0 : case SSA_NAME:
13246 : 0 : if (gimple *_d6 = get_def (valueize, _q100))
13247 : : {
13248 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
13249 : 0 : switch (gimple_assign_rhs_code (_a6))
13250 : : {
13251 : 0 : case PLUS_EXPR:
13252 : 0 : {
13253 : 0 : tree _q110 = gimple_assign_rhs1 (_a6);
13254 : 0 : _q110 = do_valueize (valueize, _q110);
13255 : 0 : tree _q111 = gimple_assign_rhs2 (_a6);
13256 : 0 : _q111 = do_valueize (valueize, _q111);
13257 : 0 : if (tree_swap_operands_p (_q110, _q111))
13258 : 0 : std::swap (_q110, _q111);
13259 : 0 : {
13260 : 0 : tree _q110_pops[1];
13261 : 0 : if (gimple_nop_convert (_q110, _q110_pops, valueize))
13262 : : {
13263 : 0 : tree _q120 = _q110_pops[0];
13264 : 0 : if ((_q120 == _q51 && ! TREE_SIDE_EFFECTS (_q120)) || (operand_equal_p (_q120, _q51, 0) && types_match (_q120, _q51)))
13265 : : {
13266 : 0 : {
13267 : 0 : tree _q111_pops[1];
13268 : 0 : if (gimple_nop_convert (_q111, _q111_pops, valueize))
13269 : : {
13270 : 0 : tree _q140 = _q111_pops[0];
13271 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
13272 : : {
13273 : 0 : if (integer_zerop (_q21))
13274 : : {
13275 : 0 : if ((_p1 == _q81 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q81, 0) && types_match (_p1, _q81)))
13276 : : {
13277 : 0 : switch (TREE_CODE (_p2))
13278 : : {
13279 : 0 : case SSA_NAME:
13280 : 0 : if (gimple *_d7 = get_def (valueize, _p2))
13281 : : {
13282 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
13283 : 0 : switch (gimple_assign_rhs_code (_a7))
13284 : : {
13285 : 0 : case BIT_XOR_EXPR:
13286 : 0 : {
13287 : 0 : tree _q180 = gimple_assign_rhs1 (_a7);
13288 : 0 : _q180 = do_valueize (valueize, _q180);
13289 : 0 : tree _q181 = gimple_assign_rhs2 (_a7);
13290 : 0 : _q181 = do_valueize (valueize, _q181);
13291 : 0 : if (tree_swap_operands_p (_q180, _q181))
13292 : 0 : std::swap (_q180, _q181);
13293 : 0 : switch (TREE_CODE (_q180))
13294 : : {
13295 : 0 : case SSA_NAME:
13296 : 0 : if (gimple *_d8 = get_def (valueize, _q180))
13297 : : {
13298 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
13299 : 0 : switch (gimple_assign_rhs_code (_a8))
13300 : : {
13301 : 0 : case NEGATE_EXPR:
13302 : 0 : {
13303 : 0 : tree _q190 = gimple_assign_rhs1 (_a8);
13304 : 0 : _q190 = do_valueize (valueize, _q190);
13305 : 0 : switch (TREE_CODE (_q190))
13306 : : {
13307 : 0 : case SSA_NAME:
13308 : 0 : if (gimple *_d9 = get_def (valueize, _q190))
13309 : : {
13310 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
13311 : 0 : switch (gimple_assign_rhs_code (_a9))
13312 : : {
13313 : 0 : CASE_CONVERT:
13314 : 0 : {
13315 : 0 : tree _q200 = gimple_assign_rhs1 (_a9);
13316 : 0 : _q200 = do_valueize (valueize, _q200);
13317 : 0 : switch (TREE_CODE (_q200))
13318 : : {
13319 : 0 : case SSA_NAME:
13320 : 0 : if (gimple *_d10 = get_def (valueize, _q200))
13321 : : {
13322 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
13323 : 0 : switch (gimple_assign_rhs_code (_a10))
13324 : : {
13325 : 0 : case LT_EXPR:
13326 : 0 : {
13327 : 0 : tree _q210 = gimple_assign_rhs1 (_a10);
13328 : 0 : _q210 = do_valueize (valueize, _q210);
13329 : 0 : tree _q211 = gimple_assign_rhs2 (_a10);
13330 : 0 : _q211 = do_valueize (valueize, _q211);
13331 : 0 : if ((_q210 == _q51 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q51, 0) && types_match (_q210, _q51)))
13332 : : {
13333 : 0 : if (integer_zerop (_q211))
13334 : : {
13335 : 0 : if (gimple_max_value (_q181, valueize))
13336 : : {
13337 : 0 : {
13338 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
13339 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13340 : : )
13341 : : {
13342 : 0 : {
13343 : 0 : res_ops[0] = captures[0];
13344 : 0 : res_ops[1] = captures[1];
13345 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
13346 : 0 : return true;
13347 : : }
13348 : : }
13349 : : }
13350 : : }
13351 : : }
13352 : : }
13353 : : break;
13354 : : }
13355 : : default:;
13356 : : }
13357 : : }
13358 : : break;
13359 : : default:;
13360 : : }
13361 : : break;
13362 : : }
13363 : : default:;
13364 : : }
13365 : : }
13366 : : break;
13367 : : default:;
13368 : : }
13369 : : break;
13370 : : }
13371 : : default:;
13372 : : }
13373 : : }
13374 : : break;
13375 : 0 : default:;
13376 : : }
13377 : 0 : if (gimple_max_value (_q180, valueize))
13378 : : {
13379 : 0 : switch (TREE_CODE (_q181))
13380 : : {
13381 : 0 : case SSA_NAME:
13382 : 0 : if (gimple *_d8 = get_def (valueize, _q181))
13383 : : {
13384 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
13385 : 0 : switch (gimple_assign_rhs_code (_a8))
13386 : : {
13387 : 0 : case NEGATE_EXPR:
13388 : 0 : {
13389 : 0 : tree _q200 = gimple_assign_rhs1 (_a8);
13390 : 0 : _q200 = do_valueize (valueize, _q200);
13391 : 0 : switch (TREE_CODE (_q200))
13392 : : {
13393 : 0 : case SSA_NAME:
13394 : 0 : if (gimple *_d9 = get_def (valueize, _q200))
13395 : : {
13396 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
13397 : 0 : switch (gimple_assign_rhs_code (_a9))
13398 : : {
13399 : 0 : CASE_CONVERT:
13400 : 0 : {
13401 : 0 : tree _q210 = gimple_assign_rhs1 (_a9);
13402 : 0 : _q210 = do_valueize (valueize, _q210);
13403 : 0 : switch (TREE_CODE (_q210))
13404 : : {
13405 : 0 : case SSA_NAME:
13406 : 0 : if (gimple *_d10 = get_def (valueize, _q210))
13407 : : {
13408 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
13409 : 0 : switch (gimple_assign_rhs_code (_a10))
13410 : : {
13411 : 0 : case LT_EXPR:
13412 : 0 : {
13413 : 0 : tree _q220 = gimple_assign_rhs1 (_a10);
13414 : 0 : _q220 = do_valueize (valueize, _q220);
13415 : 0 : tree _q221 = gimple_assign_rhs2 (_a10);
13416 : 0 : _q221 = do_valueize (valueize, _q221);
13417 : 0 : if ((_q220 == _q51 && ! TREE_SIDE_EFFECTS (_q220)) || (operand_equal_p (_q220, _q51, 0) && types_match (_q220, _q51)))
13418 : : {
13419 : 0 : if (integer_zerop (_q221))
13420 : : {
13421 : 0 : {
13422 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q81 };
13423 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13424 : : )
13425 : : {
13426 : 0 : {
13427 : 0 : res_ops[0] = captures[0];
13428 : 0 : res_ops[1] = captures[1];
13429 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 73, __FILE__, __LINE__, false);
13430 : 0 : return true;
13431 : : }
13432 : : }
13433 : : }
13434 : : }
13435 : : }
13436 : : break;
13437 : : }
13438 : : default:;
13439 : : }
13440 : : }
13441 : : break;
13442 : : default:;
13443 : : }
13444 : : break;
13445 : : }
13446 : : default:;
13447 : : }
13448 : : }
13449 : : break;
13450 : : default:;
13451 : : }
13452 : : break;
13453 : : }
13454 : : default:;
13455 : : }
13456 : : }
13457 : : break;
13458 : : default:;
13459 : : }
13460 : : }
13461 : 0 : break;
13462 : : }
13463 : : default:;
13464 : : }
13465 : : }
13466 : : break;
13467 : : default:;
13468 : : }
13469 : : }
13470 : : }
13471 : : }
13472 : : }
13473 : : }
13474 : : }
13475 : : }
13476 : : }
13477 : 0 : break;
13478 : : }
13479 : : default:;
13480 : : }
13481 : : }
13482 : : break;
13483 : : default:;
13484 : : }
13485 : : }
13486 : : }
13487 : : }
13488 : 3365690 : break;
13489 : : }
13490 : : default:;
13491 : : }
13492 : : }
13493 : : break;
13494 : : default:;
13495 : : }
13496 : 3365690 : break;
13497 : : }
13498 : : default:;
13499 : : }
13500 : : }
13501 : : break;
13502 : : default:;
13503 : : }
13504 : : break;
13505 : : }
13506 : : default:;
13507 : : }
13508 : : }
13509 : : break;
13510 : : default:;
13511 : : }
13512 : 3365690 : break;
13513 : : }
13514 : : default:;
13515 : : }
13516 : : }
13517 : : break;
13518 : : default:;
13519 : : }
13520 : : }
13521 : : }
13522 : : break;
13523 : : }
13524 : 0 : case BIT_AND_EXPR:
13525 : 0 : {
13526 : 0 : tree _q20 = TREE_OPERAND (_p0, 0);
13527 : 0 : if ((TREE_CODE (_q20) == SSA_NAME
13528 : 0 : || is_gimple_min_invariant (_q20)))
13529 : : {
13530 : 0 : _q20 = do_valueize (valueize, _q20);
13531 : 0 : tree _q21 = TREE_OPERAND (_p0, 1);
13532 : 0 : if ((TREE_CODE (_q21) == SSA_NAME
13533 : 0 : || is_gimple_min_invariant (_q21)))
13534 : : {
13535 : 0 : _q21 = do_valueize (valueize, _q21);
13536 : 0 : if (tree_swap_operands_p (_q20, _q21))
13537 : 0 : std::swap (_q20, _q21);
13538 : 0 : switch (TREE_CODE (_q20))
13539 : : {
13540 : 0 : case SSA_NAME:
13541 : 0 : if (gimple *_d2 = get_def (valueize, _q20))
13542 : : {
13543 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
13544 : 0 : switch (gimple_assign_rhs_code (_a2))
13545 : : {
13546 : 0 : case LT_EXPR:
13547 : 0 : {
13548 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
13549 : 0 : _q30 = do_valueize (valueize, _q30);
13550 : 0 : tree _q31 = gimple_assign_rhs2 (_a2);
13551 : 0 : _q31 = do_valueize (valueize, _q31);
13552 : 0 : switch (TREE_CODE (_q30))
13553 : : {
13554 : 0 : case SSA_NAME:
13555 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
13556 : : {
13557 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
13558 : 0 : switch (gimple_assign_rhs_code (_a3))
13559 : : {
13560 : 0 : case BIT_XOR_EXPR:
13561 : 0 : {
13562 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
13563 : 0 : _q40 = do_valueize (valueize, _q40);
13564 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
13565 : 0 : _q41 = do_valueize (valueize, _q41);
13566 : 0 : if (tree_swap_operands_p (_q40, _q41))
13567 : 0 : std::swap (_q40, _q41);
13568 : 0 : {
13569 : 0 : tree _q41_pops[1];
13570 : 0 : if (gimple_nop_convert (_q41, _q41_pops, valueize))
13571 : : {
13572 : 0 : tree _q60 = _q41_pops[0];
13573 : 0 : switch (TREE_CODE (_q60))
13574 : : {
13575 : 0 : case SSA_NAME:
13576 : 0 : if (gimple *_d4 = get_def (valueize, _q60))
13577 : : {
13578 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
13579 : 0 : switch (gimple_assign_rhs_code (_a4))
13580 : : {
13581 : 0 : case PLUS_EXPR:
13582 : 0 : {
13583 : 0 : tree _q70 = gimple_assign_rhs1 (_a4);
13584 : 0 : _q70 = do_valueize (valueize, _q70);
13585 : 0 : tree _q71 = gimple_assign_rhs2 (_a4);
13586 : 0 : _q71 = do_valueize (valueize, _q71);
13587 : 0 : if (tree_swap_operands_p (_q70, _q71))
13588 : 0 : std::swap (_q70, _q71);
13589 : 0 : {
13590 : 0 : tree _q70_pops[1];
13591 : 0 : if (gimple_nop_convert (_q70, _q70_pops, valueize))
13592 : : {
13593 : 0 : tree _q80 = _q70_pops[0];
13594 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
13595 : : {
13596 : 0 : {
13597 : 0 : tree _q71_pops[1];
13598 : 0 : if (gimple_nop_convert (_q71, _q71_pops, valueize))
13599 : : {
13600 : 0 : tree _q100 = _q71_pops[0];
13601 : 0 : if (integer_zerop (_q31))
13602 : : {
13603 : 0 : switch (TREE_CODE (_q21))
13604 : : {
13605 : 0 : case SSA_NAME:
13606 : 0 : if (gimple *_d5 = get_def (valueize, _q21))
13607 : : {
13608 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
13609 : 0 : switch (gimple_assign_rhs_code (_a5))
13610 : : {
13611 : 0 : case GE_EXPR:
13612 : 0 : {
13613 : 0 : tree _q130 = gimple_assign_rhs1 (_a5);
13614 : 0 : _q130 = do_valueize (valueize, _q130);
13615 : 0 : tree _q131 = gimple_assign_rhs2 (_a5);
13616 : 0 : _q131 = do_valueize (valueize, _q131);
13617 : 0 : switch (TREE_CODE (_q130))
13618 : : {
13619 : 0 : case SSA_NAME:
13620 : 0 : if (gimple *_d6 = get_def (valueize, _q130))
13621 : : {
13622 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
13623 : 0 : switch (gimple_assign_rhs_code (_a6))
13624 : : {
13625 : 0 : case BIT_XOR_EXPR:
13626 : 0 : {
13627 : 0 : tree _q140 = gimple_assign_rhs1 (_a6);
13628 : 0 : _q140 = do_valueize (valueize, _q140);
13629 : 0 : tree _q141 = gimple_assign_rhs2 (_a6);
13630 : 0 : _q141 = do_valueize (valueize, _q141);
13631 : 0 : if (tree_swap_operands_p (_q140, _q141))
13632 : 0 : std::swap (_q140, _q141);
13633 : 0 : if ((_q140 == _q40 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q40, 0) && types_match (_q140, _q40)))
13634 : : {
13635 : 0 : if ((_q141 == _q100 && ! TREE_SIDE_EFFECTS (_q141)) || (operand_equal_p (_q141, _q100, 0) && types_match (_q141, _q100)))
13636 : : {
13637 : 0 : if (integer_zerop (_q131))
13638 : : {
13639 : 0 : {
13640 : 0 : tree _p1_pops[1];
13641 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
13642 : : {
13643 : 0 : tree _q180 = _p1_pops[0];
13644 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
13645 : : {
13646 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
13647 : : {
13648 : 0 : {
13649 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
13650 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13651 : : )
13652 : : {
13653 : 0 : {
13654 : 0 : res_ops[0] = captures[0];
13655 : 0 : res_ops[1] = captures[1];
13656 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
13657 : 0 : return true;
13658 : : }
13659 : : }
13660 : : }
13661 : : }
13662 : : }
13663 : : }
13664 : : }
13665 : : }
13666 : : }
13667 : : }
13668 : 0 : if ((_q140 == _q100 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q100, 0) && types_match (_q140, _q100)))
13669 : : {
13670 : 0 : if ((_q141 == _q40 && ! TREE_SIDE_EFFECTS (_q141)) || (operand_equal_p (_q141, _q40, 0) && types_match (_q141, _q40)))
13671 : : {
13672 : 0 : if (integer_zerop (_q131))
13673 : : {
13674 : 0 : {
13675 : 0 : tree _p1_pops[1];
13676 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
13677 : : {
13678 : 0 : tree _q180 = _p1_pops[0];
13679 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
13680 : : {
13681 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
13682 : : {
13683 : 0 : {
13684 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
13685 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13686 : : )
13687 : : {
13688 : 0 : {
13689 : 0 : res_ops[0] = captures[0];
13690 : 0 : res_ops[1] = captures[1];
13691 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
13692 : 0 : return true;
13693 : : }
13694 : : }
13695 : : }
13696 : : }
13697 : : }
13698 : : }
13699 : : }
13700 : : }
13701 : : }
13702 : : }
13703 : 0 : break;
13704 : : }
13705 : : default:;
13706 : : }
13707 : : }
13708 : : break;
13709 : : default:;
13710 : : }
13711 : : break;
13712 : : }
13713 : 0 : case BIT_NOT_EXPR:
13714 : 0 : {
13715 : 0 : tree _q130 = gimple_assign_rhs1 (_a5);
13716 : 0 : _q130 = do_valueize (valueize, _q130);
13717 : 0 : switch (TREE_CODE (_q130))
13718 : : {
13719 : 0 : case SSA_NAME:
13720 : 0 : if (gimple *_d6 = get_def (valueize, _q130))
13721 : : {
13722 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
13723 : 0 : switch (gimple_assign_rhs_code (_a6))
13724 : : {
13725 : 0 : case LT_EXPR:
13726 : 0 : {
13727 : 0 : tree _q140 = gimple_assign_rhs1 (_a6);
13728 : 0 : _q140 = do_valueize (valueize, _q140);
13729 : 0 : tree _q141 = gimple_assign_rhs2 (_a6);
13730 : 0 : _q141 = do_valueize (valueize, _q141);
13731 : 0 : switch (TREE_CODE (_q140))
13732 : : {
13733 : 0 : case SSA_NAME:
13734 : 0 : if (gimple *_d7 = get_def (valueize, _q140))
13735 : : {
13736 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
13737 : 0 : switch (gimple_assign_rhs_code (_a7))
13738 : : {
13739 : 0 : case BIT_XOR_EXPR:
13740 : 0 : {
13741 : 0 : tree _q150 = gimple_assign_rhs1 (_a7);
13742 : 0 : _q150 = do_valueize (valueize, _q150);
13743 : 0 : tree _q151 = gimple_assign_rhs2 (_a7);
13744 : 0 : _q151 = do_valueize (valueize, _q151);
13745 : 0 : if (tree_swap_operands_p (_q150, _q151))
13746 : 0 : std::swap (_q150, _q151);
13747 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
13748 : : {
13749 : 0 : if ((_q151 == _q100 && ! TREE_SIDE_EFFECTS (_q151)) || (operand_equal_p (_q151, _q100, 0) && types_match (_q151, _q100)))
13750 : : {
13751 : 0 : if (integer_zerop (_q141))
13752 : : {
13753 : 0 : {
13754 : 0 : tree _p1_pops[1];
13755 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
13756 : : {
13757 : 0 : tree _q190 = _p1_pops[0];
13758 : 0 : if ((_q190 == _q40 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q40, 0) && types_match (_q190, _q40)))
13759 : : {
13760 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
13761 : : {
13762 : 0 : {
13763 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
13764 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13765 : : )
13766 : : {
13767 : 0 : {
13768 : 0 : res_ops[0] = captures[0];
13769 : 0 : res_ops[1] = captures[1];
13770 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
13771 : 0 : return true;
13772 : : }
13773 : : }
13774 : : }
13775 : : }
13776 : : }
13777 : : }
13778 : : }
13779 : : }
13780 : : }
13781 : : }
13782 : 0 : if ((_q150 == _q100 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q100, 0) && types_match (_q150, _q100)))
13783 : : {
13784 : 0 : if ((_q151 == _q40 && ! TREE_SIDE_EFFECTS (_q151)) || (operand_equal_p (_q151, _q40, 0) && types_match (_q151, _q40)))
13785 : : {
13786 : 0 : if (integer_zerop (_q141))
13787 : : {
13788 : 0 : {
13789 : 0 : tree _p1_pops[1];
13790 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
13791 : : {
13792 : 0 : tree _q190 = _p1_pops[0];
13793 : 0 : if ((_q190 == _q40 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q40, 0) && types_match (_q190, _q40)))
13794 : : {
13795 : 0 : if ((_p2 == _q41 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q41, 0) && types_match (_p2, _q41)))
13796 : : {
13797 : 0 : {
13798 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q100, _q41 };
13799 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13800 : : )
13801 : : {
13802 : 0 : {
13803 : 0 : res_ops[0] = captures[0];
13804 : 0 : res_ops[1] = captures[1];
13805 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
13806 : 0 : return true;
13807 : : }
13808 : : }
13809 : : }
13810 : : }
13811 : : }
13812 : : }
13813 : : }
13814 : : }
13815 : : }
13816 : : }
13817 : 0 : break;
13818 : : }
13819 : : default:;
13820 : : }
13821 : : }
13822 : : break;
13823 : : default:;
13824 : : }
13825 : : break;
13826 : : }
13827 : : default:;
13828 : : }
13829 : : }
13830 : : break;
13831 : : default:;
13832 : : }
13833 : : break;
13834 : : }
13835 : : default:;
13836 : : }
13837 : : }
13838 : : break;
13839 : : default:;
13840 : : }
13841 : : }
13842 : : }
13843 : : }
13844 : : }
13845 : : }
13846 : : }
13847 : 0 : break;
13848 : : }
13849 : : default:;
13850 : : }
13851 : : }
13852 : : break;
13853 : : default:;
13854 : : }
13855 : : }
13856 : : }
13857 : 0 : break;
13858 : : }
13859 : : default:;
13860 : : }
13861 : : }
13862 : : break;
13863 : : default:;
13864 : : }
13865 : : break;
13866 : : }
13867 : 0 : case GE_EXPR:
13868 : 0 : {
13869 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
13870 : 0 : _q30 = do_valueize (valueize, _q30);
13871 : 0 : tree _q31 = gimple_assign_rhs2 (_a2);
13872 : 0 : _q31 = do_valueize (valueize, _q31);
13873 : 0 : switch (TREE_CODE (_q30))
13874 : : {
13875 : 0 : case SSA_NAME:
13876 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
13877 : : {
13878 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
13879 : 0 : switch (gimple_assign_rhs_code (_a3))
13880 : : {
13881 : 0 : case BIT_XOR_EXPR:
13882 : 0 : {
13883 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
13884 : 0 : _q40 = do_valueize (valueize, _q40);
13885 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
13886 : 0 : _q41 = do_valueize (valueize, _q41);
13887 : 0 : if (tree_swap_operands_p (_q40, _q41))
13888 : 0 : std::swap (_q40, _q41);
13889 : 0 : if (integer_zerop (_q31))
13890 : : {
13891 : 0 : switch (TREE_CODE (_q21))
13892 : : {
13893 : 0 : case SSA_NAME:
13894 : 0 : if (gimple *_d4 = get_def (valueize, _q21))
13895 : : {
13896 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
13897 : 0 : switch (gimple_assign_rhs_code (_a4))
13898 : : {
13899 : 0 : case LT_EXPR:
13900 : 0 : {
13901 : 0 : tree _q80 = gimple_assign_rhs1 (_a4);
13902 : 0 : _q80 = do_valueize (valueize, _q80);
13903 : 0 : tree _q81 = gimple_assign_rhs2 (_a4);
13904 : 0 : _q81 = do_valueize (valueize, _q81);
13905 : 0 : switch (TREE_CODE (_q80))
13906 : : {
13907 : 0 : case SSA_NAME:
13908 : 0 : if (gimple *_d5 = get_def (valueize, _q80))
13909 : : {
13910 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
13911 : 0 : switch (gimple_assign_rhs_code (_a5))
13912 : : {
13913 : 0 : case BIT_XOR_EXPR:
13914 : 0 : {
13915 : 0 : tree _q90 = gimple_assign_rhs1 (_a5);
13916 : 0 : _q90 = do_valueize (valueize, _q90);
13917 : 0 : tree _q91 = gimple_assign_rhs2 (_a5);
13918 : 0 : _q91 = do_valueize (valueize, _q91);
13919 : 0 : if (tree_swap_operands_p (_q90, _q91))
13920 : 0 : std::swap (_q90, _q91);
13921 : 0 : if ((_q90 == _q40 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q40, 0) && types_match (_q90, _q40)))
13922 : : {
13923 : 0 : {
13924 : 0 : tree _q91_pops[1];
13925 : 0 : if (gimple_nop_convert (_q91, _q91_pops, valueize))
13926 : : {
13927 : 0 : tree _q110 = _q91_pops[0];
13928 : 0 : switch (TREE_CODE (_q110))
13929 : : {
13930 : 0 : case SSA_NAME:
13931 : 0 : if (gimple *_d6 = get_def (valueize, _q110))
13932 : : {
13933 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
13934 : 0 : switch (gimple_assign_rhs_code (_a6))
13935 : : {
13936 : 0 : case PLUS_EXPR:
13937 : 0 : {
13938 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
13939 : 0 : _q120 = do_valueize (valueize, _q120);
13940 : 0 : tree _q121 = gimple_assign_rhs2 (_a6);
13941 : 0 : _q121 = do_valueize (valueize, _q121);
13942 : 0 : if (tree_swap_operands_p (_q120, _q121))
13943 : 0 : std::swap (_q120, _q121);
13944 : 0 : {
13945 : 0 : tree _q120_pops[1];
13946 : 0 : if (gimple_nop_convert (_q120, _q120_pops, valueize))
13947 : : {
13948 : 0 : tree _q130 = _q120_pops[0];
13949 : 0 : if ((_q130 == _q40 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q40, 0) && types_match (_q130, _q40)))
13950 : : {
13951 : 0 : {
13952 : 0 : tree _q121_pops[1];
13953 : 0 : if (gimple_nop_convert (_q121, _q121_pops, valueize))
13954 : : {
13955 : 0 : tree _q150 = _q121_pops[0];
13956 : 0 : if ((_q150 == _q41 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q41, 0) && types_match (_q150, _q41)))
13957 : : {
13958 : 0 : if (integer_zerop (_q81))
13959 : : {
13960 : 0 : {
13961 : 0 : tree _p1_pops[1];
13962 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
13963 : : {
13964 : 0 : tree _q180 = _p1_pops[0];
13965 : 0 : if ((_q180 == _q40 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q40, 0) && types_match (_q180, _q40)))
13966 : : {
13967 : 0 : if ((_p2 == _q91 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q91, 0) && types_match (_p2, _q91)))
13968 : : {
13969 : 0 : {
13970 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q41, _q91 };
13971 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
13972 : : )
13973 : : {
13974 : 0 : {
13975 : 0 : res_ops[0] = captures[0];
13976 : 0 : res_ops[1] = captures[1];
13977 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
13978 : 0 : return true;
13979 : : }
13980 : : }
13981 : : }
13982 : : }
13983 : : }
13984 : : }
13985 : : }
13986 : : }
13987 : : }
13988 : : }
13989 : : }
13990 : : }
13991 : : }
13992 : : }
13993 : 0 : break;
13994 : : }
13995 : : default:;
13996 : : }
13997 : : }
13998 : : break;
13999 : : default:;
14000 : : }
14001 : : }
14002 : : }
14003 : : }
14004 : 0 : if ((_q90 == _q41 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q41, 0) && types_match (_q90, _q41)))
14005 : : {
14006 : 0 : {
14007 : 0 : tree _q91_pops[1];
14008 : 0 : if (gimple_nop_convert (_q91, _q91_pops, valueize))
14009 : : {
14010 : 0 : tree _q110 = _q91_pops[0];
14011 : 0 : switch (TREE_CODE (_q110))
14012 : : {
14013 : 0 : case SSA_NAME:
14014 : 0 : if (gimple *_d6 = get_def (valueize, _q110))
14015 : : {
14016 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
14017 : 0 : switch (gimple_assign_rhs_code (_a6))
14018 : : {
14019 : 0 : case PLUS_EXPR:
14020 : 0 : {
14021 : 0 : tree _q120 = gimple_assign_rhs1 (_a6);
14022 : 0 : _q120 = do_valueize (valueize, _q120);
14023 : 0 : tree _q121 = gimple_assign_rhs2 (_a6);
14024 : 0 : _q121 = do_valueize (valueize, _q121);
14025 : 0 : if (tree_swap_operands_p (_q120, _q121))
14026 : 0 : std::swap (_q120, _q121);
14027 : 0 : {
14028 : 0 : tree _q120_pops[1];
14029 : 0 : if (gimple_nop_convert (_q120, _q120_pops, valueize))
14030 : : {
14031 : 0 : tree _q130 = _q120_pops[0];
14032 : 0 : if ((_q130 == _q41 && ! TREE_SIDE_EFFECTS (_q130)) || (operand_equal_p (_q130, _q41, 0) && types_match (_q130, _q41)))
14033 : : {
14034 : 0 : {
14035 : 0 : tree _q121_pops[1];
14036 : 0 : if (gimple_nop_convert (_q121, _q121_pops, valueize))
14037 : : {
14038 : 0 : tree _q150 = _q121_pops[0];
14039 : 0 : if ((_q150 == _q40 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q40, 0) && types_match (_q150, _q40)))
14040 : : {
14041 : 0 : if (integer_zerop (_q81))
14042 : : {
14043 : 0 : {
14044 : 0 : tree _p1_pops[1];
14045 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
14046 : : {
14047 : 0 : tree _q180 = _p1_pops[0];
14048 : 0 : if ((_q180 == _q41 && ! TREE_SIDE_EFFECTS (_q180)) || (operand_equal_p (_q180, _q41, 0) && types_match (_q180, _q41)))
14049 : : {
14050 : 0 : if ((_p2 == _q91 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q91, 0) && types_match (_p2, _q91)))
14051 : : {
14052 : 0 : {
14053 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q41, _q40, _q91 };
14054 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
14055 : : )
14056 : : {
14057 : 0 : {
14058 : 0 : res_ops[0] = captures[0];
14059 : 0 : res_ops[1] = captures[1];
14060 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 74, __FILE__, __LINE__, false);
14061 : 0 : return true;
14062 : : }
14063 : : }
14064 : : }
14065 : : }
14066 : : }
14067 : : }
14068 : : }
14069 : : }
14070 : : }
14071 : : }
14072 : : }
14073 : : }
14074 : : }
14075 : : }
14076 : 0 : break;
14077 : : }
14078 : : default:;
14079 : : }
14080 : : }
14081 : : break;
14082 : : default:;
14083 : : }
14084 : : }
14085 : : }
14086 : : }
14087 : 3365690 : break;
14088 : : }
14089 : : default:;
14090 : : }
14091 : : }
14092 : : break;
14093 : : default:;
14094 : : }
14095 : : break;
14096 : : }
14097 : : default:;
14098 : : }
14099 : : }
14100 : : break;
14101 : : default:;
14102 : : }
14103 : : }
14104 : 3365690 : break;
14105 : : }
14106 : : default:;
14107 : : }
14108 : : }
14109 : : break;
14110 : : default:;
14111 : : }
14112 : : break;
14113 : : }
14114 : 0 : case BIT_NOT_EXPR:
14115 : 0 : {
14116 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
14117 : 0 : _q30 = do_valueize (valueize, _q30);
14118 : 0 : switch (TREE_CODE (_q30))
14119 : : {
14120 : 0 : case SSA_NAME:
14121 : 0 : if (gimple *_d3 = get_def (valueize, _q30))
14122 : : {
14123 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
14124 : 0 : switch (gimple_assign_rhs_code (_a3))
14125 : : {
14126 : 0 : case LT_EXPR:
14127 : 0 : {
14128 : 0 : tree _q40 = gimple_assign_rhs1 (_a3);
14129 : 0 : _q40 = do_valueize (valueize, _q40);
14130 : 0 : tree _q41 = gimple_assign_rhs2 (_a3);
14131 : 0 : _q41 = do_valueize (valueize, _q41);
14132 : 0 : switch (TREE_CODE (_q40))
14133 : : {
14134 : 0 : case SSA_NAME:
14135 : 0 : if (gimple *_d4 = get_def (valueize, _q40))
14136 : : {
14137 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
14138 : 0 : switch (gimple_assign_rhs_code (_a4))
14139 : : {
14140 : 0 : case BIT_XOR_EXPR:
14141 : 0 : {
14142 : 0 : tree _q50 = gimple_assign_rhs1 (_a4);
14143 : 0 : _q50 = do_valueize (valueize, _q50);
14144 : 0 : tree _q51 = gimple_assign_rhs2 (_a4);
14145 : 0 : _q51 = do_valueize (valueize, _q51);
14146 : 0 : if (tree_swap_operands_p (_q50, _q51))
14147 : 0 : std::swap (_q50, _q51);
14148 : 0 : if (integer_zerop (_q41))
14149 : : {
14150 : 0 : switch (TREE_CODE (_q21))
14151 : : {
14152 : 0 : case SSA_NAME:
14153 : 0 : if (gimple *_d5 = get_def (valueize, _q21))
14154 : : {
14155 : 0 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
14156 : 0 : switch (gimple_assign_rhs_code (_a5))
14157 : : {
14158 : 0 : case LT_EXPR:
14159 : 0 : {
14160 : 0 : tree _q90 = gimple_assign_rhs1 (_a5);
14161 : 0 : _q90 = do_valueize (valueize, _q90);
14162 : 0 : tree _q91 = gimple_assign_rhs2 (_a5);
14163 : 0 : _q91 = do_valueize (valueize, _q91);
14164 : 0 : switch (TREE_CODE (_q90))
14165 : : {
14166 : 0 : case SSA_NAME:
14167 : 0 : if (gimple *_d6 = get_def (valueize, _q90))
14168 : : {
14169 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
14170 : 0 : switch (gimple_assign_rhs_code (_a6))
14171 : : {
14172 : 0 : case BIT_XOR_EXPR:
14173 : 0 : {
14174 : 0 : tree _q100 = gimple_assign_rhs1 (_a6);
14175 : 0 : _q100 = do_valueize (valueize, _q100);
14176 : 0 : tree _q101 = gimple_assign_rhs2 (_a6);
14177 : 0 : _q101 = do_valueize (valueize, _q101);
14178 : 0 : if (tree_swap_operands_p (_q100, _q101))
14179 : 0 : std::swap (_q100, _q101);
14180 : 0 : if ((_q100 == _q50 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q50, 0) && types_match (_q100, _q50)))
14181 : : {
14182 : 0 : {
14183 : 0 : tree _q101_pops[1];
14184 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
14185 : : {
14186 : 0 : tree _q120 = _q101_pops[0];
14187 : 0 : switch (TREE_CODE (_q120))
14188 : : {
14189 : 0 : case SSA_NAME:
14190 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
14191 : : {
14192 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
14193 : 0 : switch (gimple_assign_rhs_code (_a7))
14194 : : {
14195 : 0 : case PLUS_EXPR:
14196 : 0 : {
14197 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
14198 : 0 : _q130 = do_valueize (valueize, _q130);
14199 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
14200 : 0 : _q131 = do_valueize (valueize, _q131);
14201 : 0 : if (tree_swap_operands_p (_q130, _q131))
14202 : 0 : std::swap (_q130, _q131);
14203 : 0 : {
14204 : 0 : tree _q130_pops[1];
14205 : 0 : if (gimple_nop_convert (_q130, _q130_pops, valueize))
14206 : : {
14207 : 0 : tree _q140 = _q130_pops[0];
14208 : 0 : if ((_q140 == _q50 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q50, 0) && types_match (_q140, _q50)))
14209 : : {
14210 : 0 : {
14211 : 0 : tree _q131_pops[1];
14212 : 0 : if (gimple_nop_convert (_q131, _q131_pops, valueize))
14213 : : {
14214 : 0 : tree _q160 = _q131_pops[0];
14215 : 0 : if ((_q160 == _q51 && ! TREE_SIDE_EFFECTS (_q160)) || (operand_equal_p (_q160, _q51, 0) && types_match (_q160, _q51)))
14216 : : {
14217 : 0 : if (integer_zerop (_q91))
14218 : : {
14219 : 0 : {
14220 : 0 : tree _p1_pops[1];
14221 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
14222 : : {
14223 : 0 : tree _q190 = _p1_pops[0];
14224 : 0 : if ((_q190 == _q50 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q50, 0) && types_match (_q190, _q50)))
14225 : : {
14226 : 0 : if ((_p2 == _q101 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q101, 0) && types_match (_p2, _q101)))
14227 : : {
14228 : 0 : {
14229 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q50, _q51, _q101 };
14230 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
14231 : : )
14232 : : {
14233 : 0 : {
14234 : 0 : res_ops[0] = captures[0];
14235 : 0 : res_ops[1] = captures[1];
14236 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
14237 : 0 : return true;
14238 : : }
14239 : : }
14240 : : }
14241 : : }
14242 : : }
14243 : : }
14244 : : }
14245 : : }
14246 : : }
14247 : : }
14248 : : }
14249 : : }
14250 : : }
14251 : : }
14252 : 0 : break;
14253 : : }
14254 : : default:;
14255 : : }
14256 : : }
14257 : : break;
14258 : : default:;
14259 : : }
14260 : : }
14261 : : }
14262 : : }
14263 : 0 : if ((_q100 == _q51 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q51, 0) && types_match (_q100, _q51)))
14264 : : {
14265 : 0 : {
14266 : 0 : tree _q101_pops[1];
14267 : 0 : if (gimple_nop_convert (_q101, _q101_pops, valueize))
14268 : : {
14269 : 0 : tree _q120 = _q101_pops[0];
14270 : 0 : switch (TREE_CODE (_q120))
14271 : : {
14272 : 0 : case SSA_NAME:
14273 : 0 : if (gimple *_d7 = get_def (valueize, _q120))
14274 : : {
14275 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
14276 : 0 : switch (gimple_assign_rhs_code (_a7))
14277 : : {
14278 : 0 : case PLUS_EXPR:
14279 : 0 : {
14280 : 0 : tree _q130 = gimple_assign_rhs1 (_a7);
14281 : 0 : _q130 = do_valueize (valueize, _q130);
14282 : 0 : tree _q131 = gimple_assign_rhs2 (_a7);
14283 : 0 : _q131 = do_valueize (valueize, _q131);
14284 : 0 : if (tree_swap_operands_p (_q130, _q131))
14285 : 0 : std::swap (_q130, _q131);
14286 : 0 : {
14287 : 0 : tree _q130_pops[1];
14288 : 0 : if (gimple_nop_convert (_q130, _q130_pops, valueize))
14289 : : {
14290 : 0 : tree _q140 = _q130_pops[0];
14291 : 0 : if ((_q140 == _q51 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q51, 0) && types_match (_q140, _q51)))
14292 : : {
14293 : 0 : {
14294 : 0 : tree _q131_pops[1];
14295 : 0 : if (gimple_nop_convert (_q131, _q131_pops, valueize))
14296 : : {
14297 : 0 : tree _q160 = _q131_pops[0];
14298 : 0 : if ((_q160 == _q50 && ! TREE_SIDE_EFFECTS (_q160)) || (operand_equal_p (_q160, _q50, 0) && types_match (_q160, _q50)))
14299 : : {
14300 : 0 : if (integer_zerop (_q91))
14301 : : {
14302 : 0 : {
14303 : 0 : tree _p1_pops[1];
14304 : 0 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
14305 : : {
14306 : 0 : tree _q190 = _p1_pops[0];
14307 : 0 : if ((_q190 == _q51 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q51, 0) && types_match (_q190, _q51)))
14308 : : {
14309 : 0 : if ((_p2 == _q101 && ! TREE_SIDE_EFFECTS (_p2)) || (operand_equal_p (_p2, _q101, 0) && types_match (_p2, _q101)))
14310 : : {
14311 : 0 : {
14312 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q51, _q50, _q101 };
14313 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
14314 : : )
14315 : : {
14316 : 0 : {
14317 : 0 : res_ops[0] = captures[0];
14318 : 0 : res_ops[1] = captures[1];
14319 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 75, __FILE__, __LINE__, false);
14320 : 0 : return true;
14321 : : }
14322 : : }
14323 : : }
14324 : : }
14325 : : }
14326 : : }
14327 : : }
14328 : : }
14329 : : }
14330 : : }
14331 : : }
14332 : : }
14333 : : }
14334 : : }
14335 : 0 : break;
14336 : : }
14337 : : default:;
14338 : : }
14339 : : }
14340 : : break;
14341 : : default:;
14342 : : }
14343 : : }
14344 : : }
14345 : : }
14346 : 3365690 : break;
14347 : : }
14348 : : default:;
14349 : : }
14350 : : }
14351 : : break;
14352 : : default:;
14353 : : }
14354 : : break;
14355 : : }
14356 : : default:;
14357 : : }
14358 : : }
14359 : : break;
14360 : : default:;
14361 : : }
14362 : : }
14363 : 3365690 : break;
14364 : : }
14365 : : default:;
14366 : : }
14367 : : }
14368 : : break;
14369 : : default:;
14370 : : }
14371 : : break;
14372 : : }
14373 : : default:;
14374 : : }
14375 : : }
14376 : : break;
14377 : : default:;
14378 : : }
14379 : : break;
14380 : : }
14381 : : default:;
14382 : : }
14383 : : }
14384 : : break;
14385 : : default:;
14386 : : }
14387 : : }
14388 : : }
14389 : 3365690 : break;
14390 : : }
14391 : 241265 : case NE_EXPR:
14392 : 241265 : {
14393 : 241265 : tree _q20 = TREE_OPERAND (_p0, 0);
14394 : 241265 : if ((TREE_CODE (_q20) == SSA_NAME
14395 : 241265 : || is_gimple_min_invariant (_q20)))
14396 : : {
14397 : 241265 : _q20 = do_valueize (valueize, _q20);
14398 : 241265 : tree _q21 = TREE_OPERAND (_p0, 1);
14399 : 241265 : if ((TREE_CODE (_q21) == SSA_NAME
14400 : 241265 : || is_gimple_min_invariant (_q21)))
14401 : : {
14402 : 241265 : _q21 = do_valueize (valueize, _q21);
14403 : 241265 : if (tree_swap_operands_p (_q20, _q21))
14404 : 0 : std::swap (_q20, _q21);
14405 : 241265 : switch (TREE_CODE (_q20))
14406 : : {
14407 : 240669 : case SSA_NAME:
14408 : 240669 : if (gimple *_d2 = get_def (valueize, _q20))
14409 : : {
14410 : 240669 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
14411 : 316467 : switch (gimple_assign_rhs_code (_a2))
14412 : : {
14413 : 33744 : case IMAGPART_EXPR:
14414 : 33744 : {
14415 : 33744 : tree _q30 = TREE_OPERAND (gimple_assign_rhs1 (_a2), 0);
14416 : 33744 : if ((TREE_CODE (_q30) == SSA_NAME
14417 : 33744 : || is_gimple_min_invariant (_q30)))
14418 : : {
14419 : 33744 : _q30 = do_valueize (valueize, _q30);
14420 : 33744 : switch (TREE_CODE (_q30))
14421 : : {
14422 : 33744 : case SSA_NAME:
14423 : 33744 : if (gimple *_d3 = get_def (valueize, _q30))
14424 : : {
14425 : 33744 : if (gcall *_c3 = dyn_cast <gcall *> (_d3))
14426 : 33720 : switch (gimple_call_combined_fn (_c3))
14427 : : {
14428 : 9220 : case CFN_ADD_OVERFLOW:
14429 : 9220 : if (gimple_call_num_args (_c3) == 2)
14430 : : {
14431 : 9220 : tree _q40 = gimple_call_arg (_c3, 0);
14432 : 9220 : _q40 = do_valueize (valueize, _q40);
14433 : 9220 : tree _q41 = gimple_call_arg (_c3, 1);
14434 : 9220 : _q41 = do_valueize (valueize, _q41);
14435 : 9220 : if (tree_swap_operands_p (_q40, _q41))
14436 : 0 : std::swap (_q40, _q41);
14437 : 9220 : if (integer_zerop (_q21))
14438 : : {
14439 : 9220 : {
14440 : 9220 : tree _p1_pops[1];
14441 : 9220 : if (gimple_signed_integer_sat_val (_p1, _p1_pops, valueize))
14442 : : {
14443 : 0 : tree _q80 = _p1_pops[0];
14444 : 0 : if ((_q80 == _q40 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q40, 0) && types_match (_q80, _q40)))
14445 : : {
14446 : 0 : switch (TREE_CODE (_p2))
14447 : : {
14448 : 0 : case SSA_NAME:
14449 : 0 : if (gimple *_d4 = get_def (valueize, _p2))
14450 : : {
14451 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
14452 : 0 : switch (gimple_assign_rhs_code (_a4))
14453 : : {
14454 : 0 : case REALPART_EXPR:
14455 : 0 : {
14456 : 0 : tree _q100 = TREE_OPERAND (gimple_assign_rhs1 (_a4), 0);
14457 : 0 : if ((TREE_CODE (_q100) == SSA_NAME
14458 : 0 : || is_gimple_min_invariant (_q100)))
14459 : : {
14460 : 0 : _q100 = do_valueize (valueize, _q100);
14461 : 0 : if ((_q100 == _q30 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q30, 0) && types_match (_q100, _q30)))
14462 : : {
14463 : 0 : {
14464 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q40, _q41, _q30 };
14465 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
14466 : : )
14467 : : {
14468 : 0 : {
14469 : 0 : res_ops[0] = captures[0];
14470 : 0 : res_ops[1] = captures[1];
14471 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 76, __FILE__, __LINE__, false);
14472 : 0 : return true;
14473 : : }
14474 : : }
14475 : : }
14476 : : }
14477 : : }
14478 : : break;
14479 : : }
14480 : : default:;
14481 : : }
14482 : : }
14483 : : break;
14484 : : default:;
14485 : : }
14486 : : }
14487 : 0 : if ((_q80 == _q41 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q41, 0) && types_match (_q80, _q41)))
14488 : : {
14489 : 0 : switch (TREE_CODE (_p2))
14490 : : {
14491 : 0 : case SSA_NAME:
14492 : 0 : if (gimple *_d4 = get_def (valueize, _p2))
14493 : : {
14494 : 9220 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
14495 : 0 : switch (gimple_assign_rhs_code (_a4))
14496 : : {
14497 : 0 : case REALPART_EXPR:
14498 : 0 : {
14499 : 0 : tree _q100 = TREE_OPERAND (gimple_assign_rhs1 (_a4), 0);
14500 : 0 : if ((TREE_CODE (_q100) == SSA_NAME
14501 : 0 : || is_gimple_min_invariant (_q100)))
14502 : : {
14503 : 0 : _q100 = do_valueize (valueize, _q100);
14504 : 0 : if ((_q100 == _q30 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q30, 0) && types_match (_q100, _q30)))
14505 : : {
14506 : 0 : {
14507 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q41, _q40, _q30 };
14508 : 0 : if (INTEGRAL_TYPE_P (type) && !TYPE_UNSIGNED (type)
14509 : : )
14510 : : {
14511 : 0 : {
14512 : 0 : res_ops[0] = captures[0];
14513 : 0 : res_ops[1] = captures[1];
14514 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 76, __FILE__, __LINE__, false);
14515 : 0 : return true;
14516 : : }
14517 : : }
14518 : : }
14519 : : }
14520 : : }
14521 : : break;
14522 : : }
14523 : : default:;
14524 : : }
14525 : : }
14526 : : break;
14527 : : default:;
14528 : : }
14529 : : }
14530 : : }
14531 : : }
14532 : : }
14533 : : }
14534 : : break;
14535 : : default:;
14536 : : }
14537 : : }
14538 : : break;
14539 : : default:;
14540 : : }
14541 : : }
14542 : : break;
14543 : : }
14544 : : default:;
14545 : : }
14546 : : }
14547 : : break;
14548 : : default:;
14549 : : }
14550 : : }
14551 : : }
14552 : 3365690 : break;
14553 : : }
14554 : : default:;
14555 : : }
14556 : : }
14557 : : }
14558 : : }
14559 : : break;
14560 : : default:;
14561 : : }
14562 : : return false;
14563 : : }
14564 : :
14565 : : bool
14566 : 0 : gimple_simplify_ROUND_MOD_EXPR (gimple_match_op *res_op, gimple_seq *seq,
14567 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
14568 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
14569 : : {
14570 : 0 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
14571 : 0 : if (integer_zerop (_p0))
14572 : : {
14573 : 0 : {
14574 : 0 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
14575 : 0 : if (gimple_simplify_339 (res_op, seq, valueize, type, captures, ROUND_MOD_EXPR))
14576 : 0 : return true;
14577 : : }
14578 : : }
14579 : 0 : if (integer_onep (_p1))
14580 : : {
14581 : 0 : {
14582 : 0 : tree captures[1] ATTRIBUTE_UNUSED = { _p0 };
14583 : 0 : if (gimple_simplify_340 (res_op, seq, valueize, type, captures, ROUND_MOD_EXPR))
14584 : 0 : return true;
14585 : : }
14586 : : }
14587 : 0 : if (integer_minus_onep (_p1))
14588 : : {
14589 : 0 : {
14590 : 0 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
14591 : 0 : if (gimple_simplify_341 (res_op, seq, valueize, type, captures, ROUND_MOD_EXPR))
14592 : 0 : return true;
14593 : : }
14594 : : }
14595 : 0 : if ((_p1 == _p0 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _p0, 0) && types_match (_p1, _p0)))
14596 : : {
14597 : 0 : {
14598 : 0 : tree captures[1] ATTRIBUTE_UNUSED = { _p0 };
14599 : 0 : if (gimple_simplify_342 (res_op, seq, valueize, type, captures, ROUND_MOD_EXPR))
14600 : 0 : return true;
14601 : : }
14602 : : }
14603 : 0 : switch (TREE_CODE (_p0))
14604 : : {
14605 : 0 : case SSA_NAME:
14606 : 0 : if (gimple *_d1 = get_def (valueize, _p0))
14607 : : {
14608 : 0 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
14609 : 0 : switch (gimple_assign_rhs_code (_a1))
14610 : : {
14611 : 0 : case ROUND_MOD_EXPR:
14612 : 0 : {
14613 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
14614 : 0 : _q20 = do_valueize (valueize, _q20);
14615 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
14616 : 0 : _q21 = do_valueize (valueize, _q21);
14617 : 0 : if ((_p1 == _q21 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _q21, 0) && types_match (_p1, _q21)))
14618 : : {
14619 : 0 : {
14620 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _p0, _q20, _q21 };
14621 : 0 : if (gimple_simplify_343 (res_op, seq, valueize, type, captures, ROUND_MOD_EXPR))
14622 : 0 : return true;
14623 : : }
14624 : : }
14625 : : break;
14626 : : }
14627 : 0 : case MULT_EXPR:
14628 : 0 : {
14629 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
14630 : 0 : _q20 = do_valueize (valueize, _q20);
14631 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
14632 : 0 : _q21 = do_valueize (valueize, _q21);
14633 : 0 : if (tree_swap_operands_p (_q20, _q21))
14634 : 0 : std::swap (_q20, _q21);
14635 : 0 : switch (TREE_CODE (_q21))
14636 : : {
14637 : 0 : case INTEGER_CST:
14638 : 0 : {
14639 : 0 : switch (TREE_CODE (_p1))
14640 : : {
14641 : 0 : case INTEGER_CST:
14642 : 0 : {
14643 : 0 : {
14644 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q20, _q21, _p1 };
14645 : 0 : if (gimple_simplify_344 (res_op, seq, valueize, type, captures, ROUND_MOD_EXPR))
14646 : 0 : return true;
14647 : : }
14648 : 0 : break;
14649 : : }
14650 : : default:;
14651 : : }
14652 : : break;
14653 : : }
14654 : : default:;
14655 : : }
14656 : 0 : break;
14657 : : }
14658 : 0 : case VEC_COND_EXPR:
14659 : 0 : {
14660 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
14661 : 0 : _q20 = do_valueize (valueize, _q20);
14662 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
14663 : 0 : _q21 = do_valueize (valueize, _q21);
14664 : 0 : tree _q22 = gimple_assign_rhs3 (_a1);
14665 : 0 : _q22 = do_valueize (valueize, _q22);
14666 : 0 : switch (TREE_CODE (_p1))
14667 : : {
14668 : 0 : case SSA_NAME:
14669 : 0 : if (gimple *_d2 = get_def (valueize, _p1))
14670 : : {
14671 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
14672 : 0 : switch (gimple_assign_rhs_code (_a2))
14673 : : {
14674 : 0 : case VEC_COND_EXPR:
14675 : 0 : {
14676 : 0 : tree _q60 = gimple_assign_rhs1 (_a2);
14677 : 0 : _q60 = do_valueize (valueize, _q60);
14678 : 0 : tree _q61 = gimple_assign_rhs2 (_a2);
14679 : 0 : _q61 = do_valueize (valueize, _q61);
14680 : 0 : tree _q62 = gimple_assign_rhs3 (_a2);
14681 : 0 : _q62 = do_valueize (valueize, _q62);
14682 : 0 : if ((_q60 == _q20 && ! TREE_SIDE_EFFECTS (_q60)) || (operand_equal_p (_q60, _q20, 0) && types_match (_q60, _q20)))
14683 : : {
14684 : 0 : {
14685 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _q22, _p1, _q61, _q62 };
14686 : 0 : if (VECTOR_TYPE_P (type)
14687 : 0 : && (TREE_CODE_CLASS (ROUND_MOD_EXPR) != tcc_comparison
14688 : : || types_match (type, TREE_TYPE (captures[2]))
14689 : : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[1]))
14690 : : || (optimize_vectors_before_lowering_p ()
14691 : : && !expand_vec_cond_expr_p (TREE_TYPE (captures[2]), TREE_TYPE (captures[1]))))
14692 : : )
14693 : : {
14694 : 0 : gimple_seq *lseq = seq;
14695 : 0 : if (lseq
14696 : 0 : && (!single_use (captures[0])
14697 : 0 : || !single_use (captures[4])))
14698 : 0 : lseq = NULL;
14699 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2364;
14700 : 0 : {
14701 : 0 : res_op->set_op (VEC_COND_EXPR, type, 3);
14702 : 0 : res_op->ops[0] = captures[1];
14703 : 0 : {
14704 : 0 : tree _o1[2], _r1;
14705 : 0 : _o1[0] = captures[2];
14706 : 0 : _o1[1] = captures[5];
14707 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), ROUND_MOD_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
14708 : 0 : tem_op.resimplify (NULL, valueize);
14709 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
14710 : 0 : if (!_r1) goto next_after_fail2364;
14711 : 0 : res_op->ops[1] = _r1;
14712 : : }
14713 : 0 : {
14714 : 0 : tree _o1[2], _r1;
14715 : 0 : _o1[0] = captures[3];
14716 : 0 : _o1[1] = captures[6];
14717 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), ROUND_MOD_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
14718 : 0 : tem_op.resimplify (NULL, valueize);
14719 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
14720 : 0 : if (!_r1) goto next_after_fail2364;
14721 : 0 : res_op->ops[2] = _r1;
14722 : : }
14723 : 0 : res_op->resimplify (lseq, valueize);
14724 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1019, __FILE__, __LINE__, true);
14725 : 0 : return true;
14726 : : }
14727 : 0 : next_after_fail2364:;
14728 : : }
14729 : : }
14730 : : }
14731 : : break;
14732 : : }
14733 : : default:;
14734 : : }
14735 : : }
14736 : : break;
14737 : 0 : default:;
14738 : : }
14739 : 0 : {
14740 : 0 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _q22, _p1 };
14741 : 0 : if (VECTOR_TYPE_P (type)
14742 : 0 : && (TREE_CODE_CLASS (ROUND_MOD_EXPR) != tcc_comparison
14743 : : || types_match (type, TREE_TYPE (captures[2]))
14744 : : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[1]))
14745 : : || (optimize_vectors_before_lowering_p ()
14746 : : && !expand_vec_cond_expr_p (TREE_TYPE (captures[2]), TREE_TYPE (captures[1]))))
14747 : : )
14748 : : {
14749 : 0 : gimple_seq *lseq = seq;
14750 : 0 : if (lseq
14751 : 0 : && (!single_use (captures[0])))
14752 : 0 : lseq = NULL;
14753 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2365;
14754 : 0 : {
14755 : 0 : res_op->set_op (VEC_COND_EXPR, type, 3);
14756 : 0 : res_op->ops[0] = captures[1];
14757 : 0 : {
14758 : 0 : tree _o1[2], _r1;
14759 : 0 : _o1[0] = captures[2];
14760 : 0 : _o1[1] = captures[4];
14761 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), ROUND_MOD_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
14762 : 0 : tem_op.resimplify (NULL, valueize);
14763 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
14764 : 0 : if (!_r1) goto next_after_fail2365;
14765 : 0 : res_op->ops[1] = _r1;
14766 : : }
14767 : 0 : {
14768 : 0 : tree _o1[2], _r1;
14769 : 0 : _o1[0] = captures[3];
14770 : 0 : _o1[1] = captures[4];
14771 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), ROUND_MOD_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
14772 : 0 : tem_op.resimplify (NULL, valueize);
14773 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
14774 : 0 : if (!_r1) goto next_after_fail2365;
14775 : 0 : res_op->ops[2] = _r1;
14776 : : }
14777 : 0 : res_op->resimplify (lseq, valueize);
14778 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1020, __FILE__, __LINE__, true);
14779 : 0 : return true;
14780 : : }
14781 : 0 : next_after_fail2365:;
14782 : : }
14783 : : }
14784 : 0 : break;
14785 : : }
14786 : : default:;
14787 : : }
14788 : : }
14789 : : break;
14790 : 0 : default:;
14791 : : }
14792 : 0 : switch (TREE_CODE (_p1))
14793 : : {
14794 : 0 : case SSA_NAME:
14795 : 0 : if (gimple *_d1 = get_def (valueize, _p1))
14796 : : {
14797 : 0 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
14798 : 0 : switch (gimple_assign_rhs_code (_a1))
14799 : : {
14800 : 0 : case VEC_COND_EXPR:
14801 : 0 : {
14802 : 0 : tree _q30 = gimple_assign_rhs1 (_a1);
14803 : 0 : _q30 = do_valueize (valueize, _q30);
14804 : 0 : tree _q31 = gimple_assign_rhs2 (_a1);
14805 : 0 : _q31 = do_valueize (valueize, _q31);
14806 : 0 : tree _q32 = gimple_assign_rhs3 (_a1);
14807 : 0 : _q32 = do_valueize (valueize, _q32);
14808 : 0 : {
14809 : 0 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _p1, _q30, _q31, _q32 };
14810 : 0 : if (VECTOR_TYPE_P (type)
14811 : 0 : && (TREE_CODE_CLASS (ROUND_MOD_EXPR) != tcc_comparison
14812 : : || types_match (type, TREE_TYPE (captures[3]))
14813 : : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[2]))
14814 : : || (optimize_vectors_before_lowering_p ()
14815 : : && !expand_vec_cond_expr_p (TREE_TYPE (captures[3]), TREE_TYPE (captures[2]))))
14816 : : )
14817 : : {
14818 : 0 : gimple_seq *lseq = seq;
14819 : 0 : if (lseq
14820 : 0 : && (!single_use (captures[1])))
14821 : 0 : lseq = NULL;
14822 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2366;
14823 : 0 : {
14824 : 0 : res_op->set_op (VEC_COND_EXPR, type, 3);
14825 : 0 : res_op->ops[0] = captures[2];
14826 : 0 : {
14827 : 0 : tree _o1[2], _r1;
14828 : 0 : _o1[0] = captures[0];
14829 : 0 : _o1[1] = captures[3];
14830 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), ROUND_MOD_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
14831 : 0 : tem_op.resimplify (NULL, valueize);
14832 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
14833 : 0 : if (!_r1) goto next_after_fail2366;
14834 : 0 : res_op->ops[1] = _r1;
14835 : : }
14836 : 0 : {
14837 : 0 : tree _o1[2], _r1;
14838 : 0 : _o1[0] = captures[0];
14839 : 0 : _o1[1] = captures[4];
14840 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), ROUND_MOD_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
14841 : 0 : tem_op.resimplify (NULL, valueize);
14842 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
14843 : 0 : if (!_r1) goto next_after_fail2366;
14844 : 0 : res_op->ops[2] = _r1;
14845 : : }
14846 : 0 : res_op->resimplify (lseq, valueize);
14847 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1021, __FILE__, __LINE__, true);
14848 : 0 : return true;
14849 : : }
14850 : 0 : next_after_fail2366:;
14851 : : }
14852 : : }
14853 : 0 : break;
14854 : : }
14855 : : default:;
14856 : : }
14857 : : }
14858 : : break;
14859 : : default:;
14860 : : }
14861 : : return false;
14862 : : }
14863 : :
14864 : : bool
14865 : 3261220 : gimple_simplify_RSHIFT_EXPR (gimple_match_op *res_op, gimple_seq *seq,
14866 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
14867 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
14868 : : {
14869 : 3261220 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
14870 : 3261220 : switch (TREE_CODE (_p1))
14871 : : {
14872 : 310994 : case SSA_NAME:
14873 : 310994 : if (gimple *_d1 = get_def (valueize, _p1))
14874 : : {
14875 : 217708 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
14876 : 197092 : switch (gimple_assign_rhs_code (_a1))
14877 : : {
14878 : 244 : case TRUNC_MOD_EXPR:
14879 : 244 : {
14880 : 244 : tree _q30 = gimple_assign_rhs1 (_a1);
14881 : 244 : _q30 = do_valueize (valueize, _q30);
14882 : 244 : tree _q31 = gimple_assign_rhs2 (_a1);
14883 : 244 : _q31 = do_valueize (valueize, _q31);
14884 : 244 : {
14885 : 244 : tree _q31_pops[1];
14886 : 244 : if (gimple_power_of_two_cand (_q31, _q31_pops, valueize))
14887 : : {
14888 : 226 : tree _q50 = _q31_pops[0];
14889 : 226 : {
14890 : 226 : tree captures[4] ATTRIBUTE_UNUSED = { _p0, _q30, _q31, _q50 };
14891 : 226 : if (gimple_simplify_395 (res_op, seq, valueize, type, captures, RSHIFT_EXPR, TRUNC_MOD_EXPR))
14892 : 108 : return true;
14893 : : }
14894 : : }
14895 : : }
14896 : 136 : break;
14897 : : }
14898 : 0 : case FLOOR_MOD_EXPR:
14899 : 0 : {
14900 : 0 : tree _q30 = gimple_assign_rhs1 (_a1);
14901 : 0 : _q30 = do_valueize (valueize, _q30);
14902 : 0 : tree _q31 = gimple_assign_rhs2 (_a1);
14903 : 0 : _q31 = do_valueize (valueize, _q31);
14904 : 0 : {
14905 : 0 : tree _q31_pops[1];
14906 : 0 : if (gimple_power_of_two_cand (_q31, _q31_pops, valueize))
14907 : : {
14908 : 0 : tree _q50 = _q31_pops[0];
14909 : 0 : {
14910 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _p0, _q30, _q31, _q50 };
14911 : 0 : if (gimple_simplify_395 (res_op, seq, valueize, type, captures, RSHIFT_EXPR, FLOOR_MOD_EXPR))
14912 : 0 : return true;
14913 : : }
14914 : : }
14915 : : }
14916 : 0 : break;
14917 : : }
14918 : : default:;
14919 : : }
14920 : : }
14921 : : break;
14922 : 3261112 : default:;
14923 : : }
14924 : 3261112 : switch (TREE_CODE (_p0))
14925 : : {
14926 : 3145924 : case SSA_NAME:
14927 : 3145924 : if (gimple *_d1 = get_def (valueize, _p0))
14928 : : {
14929 : 1933603 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
14930 : 1729433 : switch (gimple_assign_rhs_code (_a1))
14931 : : {
14932 : 368064 : case PLUS_EXPR:
14933 : 368064 : {
14934 : 368064 : tree _q20 = gimple_assign_rhs1 (_a1);
14935 : 368064 : _q20 = do_valueize (valueize, _q20);
14936 : 368064 : tree _q21 = gimple_assign_rhs2 (_a1);
14937 : 368064 : _q21 = do_valueize (valueize, _q21);
14938 : 368064 : if (tree_swap_operands_p (_q20, _q21))
14939 : 11489 : std::swap (_q20, _q21);
14940 : 368064 : switch (TREE_CODE (_q21))
14941 : : {
14942 : 196672 : case INTEGER_CST:
14943 : 196672 : {
14944 : 196672 : switch (TREE_CODE (_p1))
14945 : : {
14946 : 194786 : case INTEGER_CST:
14947 : 194786 : {
14948 : 194786 : {
14949 : 194786 : tree captures[4] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _p1 };
14950 : 194786 : {
14951 : 194786 : wide_int c = wi::to_wide (captures[2]);
14952 : 194786 : wide_int n = wi::to_wide (captures[3]);
14953 : 194786 : bool shift = RSHIFT_EXPR == RSHIFT_EXPR;
14954 : 194786 : int_range_max vr0, vr1, vr3;
14955 : 194786 : if (INTEGRAL_TYPE_P (type)
14956 : 389572 : && get_range_query (cfun)->range_of_expr (vr0, captures[1])
14957 : : )
14958 : : {
14959 : 194786 : if ((shift ? wi::ctz (
14960 : : c
14961 : 194786 : ) >= n.to_shwi ()
14962 : : : wi::multiple_of_p (
14963 : : c
14964 : : , n, TYPE_SIGN (type)))
14965 : 32028 : && get_range_query (cfun)->range_of_expr (vr1, captures[2])
14966 : 16014 : && range_op_handler (PLUS_EXPR).overflow_free_p (vr0, vr1)
14967 : 14672 : && get_range_query (cfun)->range_of_expr (vr3, captures[0])
14968 : 7336 : && !vr3.undefined_p ()
14969 : 202122 : && (TYPE_UNSIGNED (type)
14970 : 6499 : || (vr0.nonnegative_p () && vr3.nonnegative_p ())
14971 : 6194 : || (vr0.nonpositive_p () && vr3.nonpositive_p ()))
14972 : : )
14973 : : {
14974 : 1144 : gimple_seq *lseq = seq;
14975 : 1144 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2379;
14976 : 1144 : {
14977 : 1144 : res_op->set_op (PLUS_EXPR, type, 2);
14978 : 1144 : {
14979 : 1144 : tree _o1[2], _r1;
14980 : 1144 : _o1[0] = captures[1];
14981 : 1144 : _o1[1] = captures[3];
14982 : 1144 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
14983 : 1144 : tem_op.resimplify (lseq, valueize);
14984 : 1144 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
14985 : 1144 : if (!_r1) goto next_after_fail2379;
14986 : 415 : res_op->ops[0] = _r1;
14987 : : }
14988 : 415 : res_op->ops[1] = wide_int_to_tree (type,
14989 : 830 : (shift ? wi::rshift (
14990 : : c
14991 : 415 : , n, TYPE_SIGN (type))
14992 : : : wi::div_trunc (
14993 : : c
14994 : : , n, TYPE_SIGN (type)))
14995 : : );
14996 : 415 : res_op->resimplify (lseq, valueize);
14997 : 415 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1112, __FILE__, __LINE__, true);
14998 : 415 : return true;
14999 : : }
15000 : 194246 : next_after_fail2379:;
15001 : : }
15002 : : else
15003 : : {
15004 : 193627 : if (!vr0.undefined_p () && TYPE_UNSIGNED (type) && c.sign_mask () < 0
15005 : 54769 : &&
15006 : 54769 : (shift ? wi::ctz (
15007 : 248411 : -c
15008 : 54769 : ) >= n.to_shwi ()
15009 : : : wi::multiple_of_p (
15010 : : -c
15011 : : , n, TYPE_SIGN (type)))
15012 : 397729 : && wi::geu_p (vr0.lower_bound (), -c)
15013 : : )
15014 : : {
15015 : 200 : gimple_seq *lseq = seq;
15016 : 200 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2380;
15017 : 200 : {
15018 : 200 : res_op->set_op (PLUS_EXPR, type, 2);
15019 : 200 : {
15020 : 200 : tree _o1[2], _r1;
15021 : 200 : _o1[0] = captures[1];
15022 : 200 : _o1[1] = captures[3];
15023 : 200 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
15024 : 200 : tem_op.resimplify (lseq, valueize);
15025 : 200 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
15026 : 200 : if (!_r1) goto next_after_fail2380;
15027 : 125 : res_op->ops[0] = _r1;
15028 : : }
15029 : 125 : res_op->ops[1] = wide_int_to_tree (type, -
15030 : 125 : (shift ? wi::rshift (
15031 : 125 : -c
15032 : 125 : , n, TYPE_SIGN (type))
15033 : : : wi::div_trunc (
15034 : : -c
15035 : 125 : , n, TYPE_SIGN (type)))
15036 : : );
15037 : 125 : res_op->resimplify (lseq, valueize);
15038 : 125 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1113, __FILE__, __LINE__, true);
15039 : 125 : return true;
15040 : : }
15041 : 194246 : next_after_fail2380:;
15042 : : }
15043 : : }
15044 : : }
15045 : 194786 : }
15046 : : }
15047 : 194246 : break;
15048 : : }
15049 : : default:;
15050 : : }
15051 : : break;
15052 : : }
15053 : : default:;
15054 : : }
15055 : 3260572 : break;
15056 : : }
15057 : : default:;
15058 : : }
15059 : : }
15060 : : break;
15061 : 3260572 : default:;
15062 : : }
15063 : 3260572 : if (uniform_integer_cst_p (_p1))
15064 : : {
15065 : 2940565 : {
15066 : 2940565 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
15067 : 2940565 : if (gimple_simplify_396 (res_op, seq, valueize, type, captures, RSHIFT_EXPR))
15068 : 75 : return true;
15069 : : }
15070 : : }
15071 : 3260497 : switch (TREE_CODE (_p0))
15072 : : {
15073 : 3145317 : case SSA_NAME:
15074 : 3145317 : if (gimple *_d1 = get_def (valueize, _p0))
15075 : : {
15076 : 1933011 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
15077 : 1728789 : switch (gimple_assign_rhs_code (_a1))
15078 : : {
15079 : 2464 : case NEGATE_EXPR:
15080 : 2464 : {
15081 : 2464 : tree _q20 = gimple_assign_rhs1 (_a1);
15082 : 2464 : _q20 = do_valueize (valueize, _q20);
15083 : 2464 : switch (TREE_CODE (_p1))
15084 : : {
15085 : 2365 : case INTEGER_CST:
15086 : 2365 : {
15087 : 2365 : {
15088 : 2365 : tree captures[3] ATTRIBUTE_UNUSED = { _p0, _q20, _p1 };
15089 : 2365 : if (!TYPE_UNSIGNED (type)
15090 : 2365 : && TYPE_OVERFLOW_UNDEFINED (type)
15091 : : )
15092 : : {
15093 : 765 : {
15094 : 765 : tree stype = TREE_TYPE (captures[2]);
15095 : 765 : tree bt = truth_type_for (type);
15096 : 765 : tree zeros = build_zero_cst (type);
15097 : 765 : tree INTEGER_CST = NULL_TREE;
15098 : 765 : if (INTEGRAL_TYPE_P (type)
15099 : : && canonicalize_math_after_vectorization_p ()
15100 : 1001 : && wi::eq_p (wi::to_wide (captures[2]), TYPE_PRECISION (type) - 1)
15101 : : )
15102 : : {
15103 : 84 : gimple_seq *lseq = seq;
15104 : 84 : if (lseq
15105 : 42 : && (!single_use (captures[0])))
15106 : 42 : lseq = NULL;
15107 : 84 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2381;
15108 : 84 : {
15109 : 84 : res_op->set_op (NEGATE_EXPR, type, 1);
15110 : 84 : {
15111 : 84 : tree _o1[1], _r1;
15112 : 84 : {
15113 : 84 : tree _o2[2], _r2;
15114 : 84 : _o2[0] = captures[1];
15115 : 84 : _o2[1] = zeros;
15116 : 84 : gimple_match_op tem_op (res_op->cond.any_else (), GT_EXPR, boolean_type_node, _o2[0], _o2[1]);
15117 : 84 : tem_op.resimplify (lseq, valueize);
15118 : 84 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
15119 : 84 : if (!_r2) goto next_after_fail2381;
15120 : 42 : _o1[0] = _r2;
15121 : : }
15122 : 42 : if (type != TREE_TYPE (_o1[0])
15123 : 42 : && !useless_type_conversion_p (type, TREE_TYPE (_o1[0])))
15124 : : {
15125 : 42 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, type, _o1[0]);
15126 : 42 : tem_op.resimplify (lseq, valueize);
15127 : 42 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
15128 : 42 : if (!_r1) goto next_after_fail2381;
15129 : : }
15130 : : else
15131 : : _r1 = _o1[0];
15132 : 42 : res_op->ops[0] = _r1;
15133 : : }
15134 : 42 : res_op->resimplify (lseq, valueize);
15135 : 42 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1134, __FILE__, __LINE__, true);
15136 : 42 : return true;
15137 : : }
15138 : 2321 : next_after_fail2381:;
15139 : : }
15140 : : else
15141 : : {
15142 : 116 : if (VECTOR_INTEGER_TYPE_P (type)
15143 : 116 : && TYPE_MODE (bt) == TYPE_MODE (type)
15144 : 116 : && expand_vec_cmp_expr_p (type, bt, GT_EXPR)
15145 : 116 : && (INTEGER_CST = uniform_integer_cst_p (captures[2])) != NULL
15146 : 797 : && wi::eq_p (wi::to_wide (INTEGER_CST), element_precision (type) - 1)
15147 : : )
15148 : : {
15149 : 7 : gimple_seq *lseq = seq;
15150 : 7 : if (lseq
15151 : 2 : && (!single_use (captures[0])))
15152 : 5 : lseq = NULL;
15153 : 7 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2382;
15154 : 7 : {
15155 : 7 : res_op->set_op (VIEW_CONVERT_EXPR, type, 1);
15156 : 7 : {
15157 : 7 : tree _o1[2], _r1;
15158 : 7 : _o1[0] = captures[1];
15159 : 7 : _o1[1] = zeros;
15160 : 7 : gimple_match_op tem_op (res_op->cond.any_else (), GT_EXPR, bt, _o1[0], _o1[1]);
15161 : 7 : tem_op.resimplify (lseq, valueize);
15162 : 7 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
15163 : 7 : if (!_r1) goto next_after_fail2382;
15164 : 2 : res_op->ops[0] = _r1;
15165 : : }
15166 : 2 : res_op->resimplify (lseq, valueize);
15167 : 2 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1135, __FILE__, __LINE__, true);
15168 : 2 : return true;
15169 : : }
15170 : 2321 : next_after_fail2382:;
15171 : : }
15172 : : }
15173 : : }
15174 : : }
15175 : : }
15176 : 2321 : break;
15177 : : }
15178 : 0 : case VECTOR_CST:
15179 : 0 : {
15180 : 0 : {
15181 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _p0, _q20, _p1 };
15182 : 0 : if (!TYPE_UNSIGNED (type)
15183 : 0 : && TYPE_OVERFLOW_UNDEFINED (type)
15184 : : )
15185 : : {
15186 : 0 : {
15187 : 0 : tree stype = TREE_TYPE (captures[2]);
15188 : 0 : tree bt = truth_type_for (type);
15189 : 0 : tree zeros = build_zero_cst (type);
15190 : 0 : tree VECTOR_CST = NULL_TREE;
15191 : 0 : if (INTEGRAL_TYPE_P (type)
15192 : : && canonicalize_math_after_vectorization_p ()
15193 : 0 : && wi::eq_p (wi::to_wide (captures[2]), TYPE_PRECISION (type) - 1)
15194 : : )
15195 : : {
15196 : 0 : gimple_seq *lseq = seq;
15197 : 0 : if (lseq
15198 : 0 : && (!single_use (captures[0])))
15199 : 0 : lseq = NULL;
15200 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2383;
15201 : 0 : {
15202 : 0 : res_op->set_op (NEGATE_EXPR, type, 1);
15203 : 0 : {
15204 : 0 : tree _o1[1], _r1;
15205 : 0 : {
15206 : 0 : tree _o2[2], _r2;
15207 : 0 : _o2[0] = captures[1];
15208 : 0 : _o2[1] = zeros;
15209 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), GT_EXPR, boolean_type_node, _o2[0], _o2[1]);
15210 : 0 : tem_op.resimplify (lseq, valueize);
15211 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
15212 : 0 : if (!_r2) goto next_after_fail2383;
15213 : 0 : _o1[0] = _r2;
15214 : : }
15215 : 0 : if (type != TREE_TYPE (_o1[0])
15216 : 0 : && !useless_type_conversion_p (type, TREE_TYPE (_o1[0])))
15217 : : {
15218 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, type, _o1[0]);
15219 : 0 : tem_op.resimplify (lseq, valueize);
15220 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
15221 : 0 : if (!_r1) goto next_after_fail2383;
15222 : : }
15223 : : else
15224 : : _r1 = _o1[0];
15225 : 0 : res_op->ops[0] = _r1;
15226 : : }
15227 : 0 : res_op->resimplify (lseq, valueize);
15228 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1134, __FILE__, __LINE__, true);
15229 : 0 : return true;
15230 : : }
15231 : 0 : next_after_fail2383:;
15232 : : }
15233 : : else
15234 : : {
15235 : 0 : if (VECTOR_INTEGER_TYPE_P (type)
15236 : 0 : && TYPE_MODE (bt) == TYPE_MODE (type)
15237 : 0 : && expand_vec_cmp_expr_p (type, bt, GT_EXPR)
15238 : 0 : && (VECTOR_CST = uniform_integer_cst_p (captures[2])) != NULL
15239 : 0 : && wi::eq_p (wi::to_wide (VECTOR_CST), element_precision (type) - 1)
15240 : : )
15241 : : {
15242 : 0 : gimple_seq *lseq = seq;
15243 : 0 : if (lseq
15244 : 0 : && (!single_use (captures[0])))
15245 : 0 : lseq = NULL;
15246 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2384;
15247 : 0 : {
15248 : 0 : res_op->set_op (VIEW_CONVERT_EXPR, type, 1);
15249 : 0 : {
15250 : 0 : tree _o1[2], _r1;
15251 : 0 : _o1[0] = captures[1];
15252 : 0 : _o1[1] = zeros;
15253 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), GT_EXPR, bt, _o1[0], _o1[1]);
15254 : 0 : tem_op.resimplify (lseq, valueize);
15255 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
15256 : 0 : if (!_r1) goto next_after_fail2384;
15257 : 0 : res_op->ops[0] = _r1;
15258 : : }
15259 : 0 : res_op->resimplify (lseq, valueize);
15260 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1135, __FILE__, __LINE__, true);
15261 : 0 : return true;
15262 : : }
15263 : 0 : next_after_fail2384:;
15264 : : }
15265 : : }
15266 : : }
15267 : : }
15268 : : }
15269 : 0 : break;
15270 : : }
15271 : : default:;
15272 : : }
15273 : : break;
15274 : : }
15275 : 19815 : case LSHIFT_EXPR:
15276 : 19815 : {
15277 : 19815 : tree _q20 = gimple_assign_rhs1 (_a1);
15278 : 19815 : _q20 = do_valueize (valueize, _q20);
15279 : 19815 : tree _q21 = gimple_assign_rhs2 (_a1);
15280 : 19815 : _q21 = do_valueize (valueize, _q21);
15281 : 19815 : switch (TREE_CODE (_q21))
15282 : : {
15283 : 12304 : case INTEGER_CST:
15284 : 12304 : {
15285 : 12304 : if ((_p1 == _q21 && ! TREE_SIDE_EFFECTS (_p1)) || operand_equal_p (_p1, _q21, 0))
15286 : : {
15287 : 3734 : {
15288 : 3734 : tree captures[3] ATTRIBUTE_UNUSED = { _q20, _p1, _q21 };
15289 : 3734 : if (gimple_simplify_407 (res_op, seq, valueize, type, captures))
15290 : 705 : return true;
15291 : : }
15292 : : }
15293 : : break;
15294 : : }
15295 : : default:;
15296 : : }
15297 : : break;
15298 : : }
15299 : : default:;
15300 : : }
15301 : : }
15302 : : break;
15303 : 3259748 : default:;
15304 : : }
15305 : 3259748 : {
15306 : 3259748 : tree _p0_pops[1];
15307 : 3259748 : if (gimple_nop_convert (_p0, _p0_pops, valueize))
15308 : : {
15309 : 134351 : tree _q20 = _p0_pops[0];
15310 : 134351 : switch (TREE_CODE (_q20))
15311 : : {
15312 : 134209 : case SSA_NAME:
15313 : 134209 : if (gimple *_d1 = get_def (valueize, _q20))
15314 : : {
15315 : 129232 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
15316 : 88399 : switch (gimple_assign_rhs_code (_a1))
15317 : : {
15318 : 443 : case LSHIFT_EXPR:
15319 : 443 : {
15320 : 443 : tree _q30 = gimple_assign_rhs1 (_a1);
15321 : 443 : _q30 = do_valueize (valueize, _q30);
15322 : 443 : tree _q31 = gimple_assign_rhs2 (_a1);
15323 : 443 : _q31 = do_valueize (valueize, _q31);
15324 : 443 : switch (TREE_CODE (_q31))
15325 : : {
15326 : 18 : case INTEGER_CST:
15327 : 18 : {
15328 : 18 : if ((_p1 == _q31 && ! TREE_SIDE_EFFECTS (_p1)) || operand_equal_p (_p1, _q31, 0))
15329 : : {
15330 : 13 : {
15331 : 13 : tree captures[3] ATTRIBUTE_UNUSED = { _q30, _p1, _q31 };
15332 : 13 : if (gimple_simplify_407 (res_op, seq, valueize, type, captures))
15333 : 4 : return true;
15334 : : }
15335 : : }
15336 : : break;
15337 : : }
15338 : : default:;
15339 : : }
15340 : : break;
15341 : : }
15342 : : default:;
15343 : : }
15344 : : }
15345 : : break;
15346 : : default:;
15347 : : }
15348 : : }
15349 : : }
15350 : 3259744 : if (integer_all_onesp (_p0))
15351 : : {
15352 : 7576 : {
15353 : 7576 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
15354 : 7576 : if (!TYPE_UNSIGNED (type)
15355 : : )
15356 : : {
15357 : 39 : gimple_seq *lseq = seq;
15358 : 39 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2385;
15359 : 39 : {
15360 : 39 : tree tem;
15361 : 39 : tem = captures[0];
15362 : 39 : res_op->set_value (tem);
15363 : 39 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1136, __FILE__, __LINE__, true);
15364 : 39 : return true;
15365 : : }
15366 : 0 : next_after_fail2385:;
15367 : : }
15368 : : }
15369 : : }
15370 : 3259705 : if ((_p1 == _p0 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _p0, 0) && types_match (_p1, _p0)))
15371 : : {
15372 : 15 : {
15373 : 15 : tree captures[1] ATTRIBUTE_UNUSED = { _p0 };
15374 : 15 : gimple_seq *lseq = seq;
15375 : 15 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2386;
15376 : 15 : {
15377 : 15 : tree tem;
15378 : 15 : tem = build_zero_cst (type);
15379 : 15 : res_op->set_value (tem);
15380 : 15 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1137, __FILE__, __LINE__, true);
15381 : 15 : return true;
15382 : : }
15383 : 0 : next_after_fail2386:;
15384 : : }
15385 : : }
15386 : 3259690 : if (integer_zerop (_p1))
15387 : : {
15388 : 11741 : {
15389 : 11741 : tree captures[1] ATTRIBUTE_UNUSED = { _p0 };
15390 : 11741 : if (gimple_simplify_399 (res_op, seq, valueize, type, captures, RSHIFT_EXPR))
15391 : 11741 : return true;
15392 : : }
15393 : : }
15394 : 3247949 : if (integer_zerop (_p0))
15395 : : {
15396 : 1942 : {
15397 : 1942 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
15398 : 1942 : if (gimple_simplify_400 (res_op, seq, valueize, type, captures, RSHIFT_EXPR))
15399 : 1942 : return true;
15400 : : }
15401 : : }
15402 : 3246007 : switch (TREE_CODE (_p1))
15403 : : {
15404 : 308898 : case SSA_NAME:
15405 : 308898 : if (gimple *_d1 = get_def (valueize, _p1))
15406 : : {
15407 : 216762 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
15408 : 196295 : switch (gimple_assign_rhs_code (_a1))
15409 : : {
15410 : 96 : case CONSTRUCTOR:
15411 : 96 : {
15412 : 96 : {
15413 : 96 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
15414 : 96 : if (gimple_simplify_402 (res_op, seq, valueize, type, captures, RSHIFT_EXPR))
15415 : 0 : return true;
15416 : : }
15417 : 96 : break;
15418 : : }
15419 : : default:;
15420 : : }
15421 : : }
15422 : 308898 : {
15423 : 308898 : {
15424 : 308898 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
15425 : 308898 : if (gimple_simplify_403 (res_op, seq, valueize, type, captures, RSHIFT_EXPR))
15426 : 6 : return true;
15427 : : }
15428 : : }
15429 : 308892 : break;
15430 : 3400 : case VECTOR_CST:
15431 : 3400 : {
15432 : 3400 : {
15433 : 3400 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
15434 : 3400 : if (gimple_simplify_401 (res_op, seq, valueize, type, captures, RSHIFT_EXPR))
15435 : 320 : return true;
15436 : : }
15437 : 3080 : break;
15438 : : }
15439 : 3245681 : default:;
15440 : : }
15441 : 3245681 : switch (TREE_CODE (_p0))
15442 : : {
15443 : 3132489 : case SSA_NAME:
15444 : 3132489 : if (gimple *_d1 = get_def (valueize, _p0))
15445 : : {
15446 : 1923023 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
15447 : 1719203 : switch (gimple_assign_rhs_code (_a1))
15448 : : {
15449 : 18710 : case RSHIFT_EXPR:
15450 : 18710 : {
15451 : 18710 : tree _q20 = gimple_assign_rhs1 (_a1);
15452 : 18710 : _q20 = do_valueize (valueize, _q20);
15453 : 18710 : tree _q21 = gimple_assign_rhs2 (_a1);
15454 : 18710 : _q21 = do_valueize (valueize, _q21);
15455 : 18710 : switch (TREE_CODE (_q21))
15456 : : {
15457 : 15337 : case INTEGER_CST:
15458 : 15337 : {
15459 : 15337 : switch (TREE_CODE (_p1))
15460 : : {
15461 : 14689 : case INTEGER_CST:
15462 : 14689 : {
15463 : 14689 : {
15464 : 14689 : tree captures[3] ATTRIBUTE_UNUSED = { _q20, _q21, _p1 };
15465 : 14689 : if (gimple_simplify_404 (res_op, seq, valueize, type, captures, RSHIFT_EXPR))
15466 : 14689 : return true;
15467 : : }
15468 : 0 : break;
15469 : : }
15470 : : default:;
15471 : : }
15472 : : break;
15473 : : }
15474 : : default:;
15475 : : }
15476 : : break;
15477 : : }
15478 : 231705 : CASE_CONVERT:
15479 : 231705 : {
15480 : 231705 : tree _q20 = gimple_assign_rhs1 (_a1);
15481 : 231705 : _q20 = do_valueize (valueize, _q20);
15482 : 231705 : switch (TREE_CODE (_q20))
15483 : : {
15484 : 231563 : case SSA_NAME:
15485 : 231563 : if (gimple *_d2 = get_def (valueize, _q20))
15486 : : {
15487 : 222607 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
15488 : 171731 : switch (gimple_assign_rhs_code (_a2))
15489 : : {
15490 : 5620 : case BIT_AND_EXPR:
15491 : 5620 : {
15492 : 5620 : tree _q30 = gimple_assign_rhs1 (_a2);
15493 : 5620 : _q30 = do_valueize (valueize, _q30);
15494 : 5620 : tree _q31 = gimple_assign_rhs2 (_a2);
15495 : 5620 : _q31 = do_valueize (valueize, _q31);
15496 : 5620 : if (tree_swap_operands_p (_q30, _q31))
15497 : 63 : std::swap (_q30, _q31);
15498 : 5620 : switch (TREE_CODE (_q31))
15499 : : {
15500 : 4919 : case INTEGER_CST:
15501 : 4919 : {
15502 : 4919 : switch (TREE_CODE (_p1))
15503 : : {
15504 : 1069 : case INTEGER_CST:
15505 : 1069 : {
15506 : 1069 : {
15507 : 1069 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _q20, _q30, _q31, _p1 };
15508 : 1069 : if (gimple_simplify_405 (res_op, seq, valueize, type, captures, BIT_AND_EXPR, RSHIFT_EXPR))
15509 : 7 : return true;
15510 : : }
15511 : 1062 : break;
15512 : : }
15513 : : default:;
15514 : : }
15515 : : break;
15516 : : }
15517 : : default:;
15518 : : }
15519 : 3229925 : break;
15520 : : }
15521 : 430 : case BIT_XOR_EXPR:
15522 : 430 : {
15523 : 430 : tree _q30 = gimple_assign_rhs1 (_a2);
15524 : 430 : _q30 = do_valueize (valueize, _q30);
15525 : 430 : tree _q31 = gimple_assign_rhs2 (_a2);
15526 : 430 : _q31 = do_valueize (valueize, _q31);
15527 : 430 : if (tree_swap_operands_p (_q30, _q31))
15528 : 17 : std::swap (_q30, _q31);
15529 : 430 : switch (TREE_CODE (_q31))
15530 : : {
15531 : 55 : case INTEGER_CST:
15532 : 55 : {
15533 : 55 : switch (TREE_CODE (_p1))
15534 : : {
15535 : 55 : case INTEGER_CST:
15536 : 55 : {
15537 : 55 : {
15538 : 55 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _q20, _q30, _q31, _p1 };
15539 : 55 : if (gimple_simplify_405 (res_op, seq, valueize, type, captures, BIT_XOR_EXPR, RSHIFT_EXPR))
15540 : 0 : return true;
15541 : : }
15542 : 55 : break;
15543 : : }
15544 : : default:;
15545 : : }
15546 : : break;
15547 : : }
15548 : : default:;
15549 : : }
15550 : 3229925 : break;
15551 : : }
15552 : 1029 : case BIT_IOR_EXPR:
15553 : 1029 : {
15554 : 1029 : tree _q30 = gimple_assign_rhs1 (_a2);
15555 : 1029 : _q30 = do_valueize (valueize, _q30);
15556 : 1029 : tree _q31 = gimple_assign_rhs2 (_a2);
15557 : 1029 : _q31 = do_valueize (valueize, _q31);
15558 : 1029 : if (tree_swap_operands_p (_q30, _q31))
15559 : 104 : std::swap (_q30, _q31);
15560 : 1029 : switch (TREE_CODE (_q31))
15561 : : {
15562 : 45 : case INTEGER_CST:
15563 : 45 : {
15564 : 45 : switch (TREE_CODE (_p1))
15565 : : {
15566 : 45 : case INTEGER_CST:
15567 : 45 : {
15568 : 45 : {
15569 : 45 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _q20, _q30, _q31, _p1 };
15570 : 45 : if (gimple_simplify_405 (res_op, seq, valueize, type, captures, BIT_IOR_EXPR, RSHIFT_EXPR))
15571 : 3 : return true;
15572 : : }
15573 : 42 : break;
15574 : : }
15575 : : default:;
15576 : : }
15577 : : break;
15578 : : }
15579 : : default:;
15580 : : }
15581 : 3229925 : break;
15582 : : }
15583 : : default:;
15584 : : }
15585 : 105820 : else if (gcall *_c2 = dyn_cast <gcall *> (_d2))
15586 : 4901 : switch (gimple_call_combined_fn (_c2))
15587 : : {
15588 : 0 : case CFN_BUILT_IN_BSWAP128:
15589 : 0 : if (gimple_call_num_args (_c2) == 1)
15590 : : {
15591 : 0 : tree _q30 = gimple_call_arg (_c2, 0);
15592 : 0 : _q30 = do_valueize (valueize, _q30);
15593 : 0 : switch (TREE_CODE (_p1))
15594 : : {
15595 : 0 : case INTEGER_CST:
15596 : 0 : {
15597 : 0 : {
15598 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q20, _q30, _p1 };
15599 : 0 : if (gimple_simplify_408 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_BSWAP128))
15600 : 0 : return true;
15601 : : }
15602 : 0 : break;
15603 : : }
15604 : : default:;
15605 : : }
15606 : : }
15607 : : break;
15608 : 17 : case CFN_BUILT_IN_BSWAP16:
15609 : 17 : if (gimple_call_num_args (_c2) == 1)
15610 : : {
15611 : 17 : tree _q30 = gimple_call_arg (_c2, 0);
15612 : 17 : _q30 = do_valueize (valueize, _q30);
15613 : 17 : switch (TREE_CODE (_p1))
15614 : : {
15615 : 2 : case INTEGER_CST:
15616 : 2 : {
15617 : 2 : {
15618 : 2 : tree captures[3] ATTRIBUTE_UNUSED = { _q20, _q30, _p1 };
15619 : 2 : if (gimple_simplify_408 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_BSWAP16))
15620 : 1 : return true;
15621 : : }
15622 : 1 : break;
15623 : : }
15624 : : default:;
15625 : : }
15626 : : }
15627 : : break;
15628 : 0 : case CFN_BUILT_IN_BSWAP32:
15629 : 0 : if (gimple_call_num_args (_c2) == 1)
15630 : : {
15631 : 0 : tree _q30 = gimple_call_arg (_c2, 0);
15632 : 0 : _q30 = do_valueize (valueize, _q30);
15633 : 0 : switch (TREE_CODE (_p1))
15634 : : {
15635 : 0 : case INTEGER_CST:
15636 : 0 : {
15637 : 0 : {
15638 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q20, _q30, _p1 };
15639 : 0 : if (gimple_simplify_408 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_BSWAP32))
15640 : 0 : return true;
15641 : : }
15642 : 0 : break;
15643 : : }
15644 : : default:;
15645 : : }
15646 : : }
15647 : : break;
15648 : 0 : case CFN_BUILT_IN_BSWAP64:
15649 : 0 : if (gimple_call_num_args (_c2) == 1)
15650 : : {
15651 : 0 : tree _q30 = gimple_call_arg (_c2, 0);
15652 : 0 : _q30 = do_valueize (valueize, _q30);
15653 : 0 : switch (TREE_CODE (_p1))
15654 : : {
15655 : 0 : case INTEGER_CST:
15656 : 0 : {
15657 : 0 : {
15658 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _q20, _q30, _p1 };
15659 : 0 : if (gimple_simplify_408 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_BSWAP64))
15660 : 0 : return true;
15661 : : }
15662 : 0 : break;
15663 : : }
15664 : : default:;
15665 : : }
15666 : : }
15667 : : break;
15668 : : default:;
15669 : : }
15670 : : }
15671 : : break;
15672 : : default:;
15673 : : }
15674 : : break;
15675 : : }
15676 : 34696 : case BIT_AND_EXPR:
15677 : 34696 : {
15678 : 34696 : tree _q20 = gimple_assign_rhs1 (_a1);
15679 : 34696 : _q20 = do_valueize (valueize, _q20);
15680 : 34696 : tree _q21 = gimple_assign_rhs2 (_a1);
15681 : 34696 : _q21 = do_valueize (valueize, _q21);
15682 : 34696 : if (tree_swap_operands_p (_q20, _q21))
15683 : 1069 : std::swap (_q20, _q21);
15684 : 34696 : switch (TREE_CODE (_q21))
15685 : : {
15686 : 20247 : case INTEGER_CST:
15687 : 20247 : {
15688 : 20247 : switch (TREE_CODE (_p1))
15689 : : {
15690 : 19302 : case INTEGER_CST:
15691 : 19302 : {
15692 : 19302 : {
15693 : 19302 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _p0, _q20, _q21, _p1 };
15694 : 19302 : if (gimple_simplify_406 (res_op, seq, valueize, type, captures, BIT_AND_EXPR, RSHIFT_EXPR))
15695 : 658 : return true;
15696 : : }
15697 : 18644 : break;
15698 : : }
15699 : : default:;
15700 : : }
15701 : : break;
15702 : : }
15703 : : default:;
15704 : : }
15705 : 3229925 : break;
15706 : : }
15707 : 20365 : case BIT_XOR_EXPR:
15708 : 20365 : {
15709 : 20365 : tree _q20 = gimple_assign_rhs1 (_a1);
15710 : 20365 : _q20 = do_valueize (valueize, _q20);
15711 : 20365 : tree _q21 = gimple_assign_rhs2 (_a1);
15712 : 20365 : _q21 = do_valueize (valueize, _q21);
15713 : 20365 : if (tree_swap_operands_p (_q20, _q21))
15714 : 1557 : std::swap (_q20, _q21);
15715 : 20365 : switch (TREE_CODE (_q21))
15716 : : {
15717 : 1422 : case INTEGER_CST:
15718 : 1422 : {
15719 : 1422 : switch (TREE_CODE (_p1))
15720 : : {
15721 : 1334 : case INTEGER_CST:
15722 : 1334 : {
15723 : 1334 : {
15724 : 1334 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _p0, _q20, _q21, _p1 };
15725 : 1334 : if (gimple_simplify_406 (res_op, seq, valueize, type, captures, BIT_XOR_EXPR, RSHIFT_EXPR))
15726 : 86 : return true;
15727 : : }
15728 : 1248 : break;
15729 : : }
15730 : : default:;
15731 : : }
15732 : : break;
15733 : : }
15734 : : default:;
15735 : : }
15736 : 3229925 : break;
15737 : : }
15738 : 134682 : case BIT_IOR_EXPR:
15739 : 134682 : {
15740 : 134682 : tree _q20 = gimple_assign_rhs1 (_a1);
15741 : 134682 : _q20 = do_valueize (valueize, _q20);
15742 : 134682 : tree _q21 = gimple_assign_rhs2 (_a1);
15743 : 134682 : _q21 = do_valueize (valueize, _q21);
15744 : 134682 : if (tree_swap_operands_p (_q20, _q21))
15745 : 9022 : std::swap (_q20, _q21);
15746 : 134682 : switch (TREE_CODE (_q21))
15747 : : {
15748 : 2229 : case INTEGER_CST:
15749 : 2229 : {
15750 : 2229 : switch (TREE_CODE (_p1))
15751 : : {
15752 : 985 : case INTEGER_CST:
15753 : 985 : {
15754 : 985 : {
15755 : 985 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _p0, _q20, _q21, _p1 };
15756 : 985 : if (gimple_simplify_406 (res_op, seq, valueize, type, captures, BIT_IOR_EXPR, RSHIFT_EXPR))
15757 : 69 : return true;
15758 : : }
15759 : 916 : break;
15760 : : }
15761 : : default:;
15762 : : }
15763 : : break;
15764 : : }
15765 : : default:;
15766 : : }
15767 : 3229925 : break;
15768 : : }
15769 : 276 : case VEC_COND_EXPR:
15770 : 276 : {
15771 : 276 : tree _q20 = gimple_assign_rhs1 (_a1);
15772 : 276 : _q20 = do_valueize (valueize, _q20);
15773 : 276 : tree _q21 = gimple_assign_rhs2 (_a1);
15774 : 276 : _q21 = do_valueize (valueize, _q21);
15775 : 276 : tree _q22 = gimple_assign_rhs3 (_a1);
15776 : 276 : _q22 = do_valueize (valueize, _q22);
15777 : 276 : switch (TREE_CODE (_p1))
15778 : : {
15779 : 24 : case SSA_NAME:
15780 : 24 : if (gimple *_d2 = get_def (valueize, _p1))
15781 : : {
15782 : 24 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
15783 : 24 : switch (gimple_assign_rhs_code (_a2))
15784 : : {
15785 : 0 : case VEC_COND_EXPR:
15786 : 0 : {
15787 : 0 : tree _q60 = gimple_assign_rhs1 (_a2);
15788 : 0 : _q60 = do_valueize (valueize, _q60);
15789 : 0 : tree _q61 = gimple_assign_rhs2 (_a2);
15790 : 0 : _q61 = do_valueize (valueize, _q61);
15791 : 0 : tree _q62 = gimple_assign_rhs3 (_a2);
15792 : 0 : _q62 = do_valueize (valueize, _q62);
15793 : 0 : if ((_q60 == _q20 && ! TREE_SIDE_EFFECTS (_q60)) || (operand_equal_p (_q60, _q20, 0) && types_match (_q60, _q20)))
15794 : : {
15795 : 0 : {
15796 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _q22, _p1, _q61, _q62 };
15797 : 0 : if (VECTOR_TYPE_P (type)
15798 : 0 : && (TREE_CODE_CLASS (RSHIFT_EXPR) != tcc_comparison
15799 : : || types_match (type, TREE_TYPE (captures[2]))
15800 : : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[1]))
15801 : : || (optimize_vectors_before_lowering_p ()
15802 : : && !expand_vec_cond_expr_p (TREE_TYPE (captures[2]), TREE_TYPE (captures[1]))))
15803 : : )
15804 : : {
15805 : 0 : gimple_seq *lseq = seq;
15806 : 0 : if (lseq
15807 : 0 : && (!single_use (captures[0])
15808 : 0 : || !single_use (captures[4])))
15809 : 0 : lseq = NULL;
15810 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2387;
15811 : 0 : {
15812 : 0 : res_op->set_op (VEC_COND_EXPR, type, 3);
15813 : 0 : res_op->ops[0] = captures[1];
15814 : 0 : {
15815 : 0 : tree _o1[2], _r1;
15816 : 0 : _o1[0] = captures[2];
15817 : 0 : _o1[1] = captures[5];
15818 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
15819 : 0 : tem_op.resimplify (NULL, valueize);
15820 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
15821 : 0 : if (!_r1) goto next_after_fail2387;
15822 : 0 : res_op->ops[1] = _r1;
15823 : : }
15824 : 0 : {
15825 : 0 : tree _o1[2], _r1;
15826 : 0 : _o1[0] = captures[3];
15827 : 0 : _o1[1] = captures[6];
15828 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
15829 : 0 : tem_op.resimplify (NULL, valueize);
15830 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
15831 : 0 : if (!_r1) goto next_after_fail2387;
15832 : 0 : res_op->ops[2] = _r1;
15833 : : }
15834 : 0 : res_op->resimplify (lseq, valueize);
15835 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1019, __FILE__, __LINE__, true);
15836 : 0 : return true;
15837 : : }
15838 : 0 : next_after_fail2387:;
15839 : : }
15840 : : }
15841 : : }
15842 : : break;
15843 : : }
15844 : : default:;
15845 : : }
15846 : : }
15847 : : break;
15848 : 276 : default:;
15849 : : }
15850 : 276 : {
15851 : 276 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _q22, _p1 };
15852 : 276 : if (VECTOR_TYPE_P (type)
15853 : 276 : && (TREE_CODE_CLASS (RSHIFT_EXPR) != tcc_comparison
15854 : : || types_match (type, TREE_TYPE (captures[2]))
15855 : : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[1]))
15856 : : || (optimize_vectors_before_lowering_p ()
15857 : : && !expand_vec_cond_expr_p (TREE_TYPE (captures[2]), TREE_TYPE (captures[1]))))
15858 : : )
15859 : : {
15860 : 276 : gimple_seq *lseq = seq;
15861 : 276 : if (lseq
15862 : 15 : && (!single_use (captures[0])))
15863 : 261 : lseq = NULL;
15864 : 276 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2388;
15865 : 276 : {
15866 : 276 : res_op->set_op (VEC_COND_EXPR, type, 3);
15867 : 276 : res_op->ops[0] = captures[1];
15868 : 276 : {
15869 : 276 : tree _o1[2], _r1;
15870 : 276 : _o1[0] = captures[2];
15871 : 276 : _o1[1] = captures[4];
15872 : 276 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
15873 : 276 : tem_op.resimplify (NULL, valueize);
15874 : 276 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
15875 : 276 : if (!_r1) goto next_after_fail2388;
15876 : 252 : res_op->ops[1] = _r1;
15877 : : }
15878 : 252 : {
15879 : 252 : tree _o1[2], _r1;
15880 : 252 : _o1[0] = captures[3];
15881 : 252 : _o1[1] = captures[4];
15882 : 252 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
15883 : 252 : tem_op.resimplify (NULL, valueize);
15884 : 252 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
15885 : 252 : if (!_r1) goto next_after_fail2388;
15886 : 243 : res_op->ops[2] = _r1;
15887 : : }
15888 : 243 : res_op->resimplify (lseq, valueize);
15889 : 243 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1020, __FILE__, __LINE__, true);
15890 : 243 : return true;
15891 : : }
15892 : 33 : next_after_fail2388:;
15893 : : }
15894 : : }
15895 : 33 : break;
15896 : : }
15897 : : default:;
15898 : : }
15899 : 517686 : else if (gcall *_c1 = dyn_cast <gcall *> (_d1))
15900 : 22985 : switch (gimple_call_combined_fn (_c1))
15901 : : {
15902 : 0 : case CFN_BUILT_IN_BSWAP128:
15903 : 0 : if (gimple_call_num_args (_c1) == 1)
15904 : : {
15905 : 0 : tree _q20 = gimple_call_arg (_c1, 0);
15906 : 0 : _q20 = do_valueize (valueize, _q20);
15907 : 0 : switch (TREE_CODE (_p1))
15908 : : {
15909 : 0 : case INTEGER_CST:
15910 : 0 : {
15911 : 0 : {
15912 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _p0, _q20, _p1 };
15913 : 0 : if (gimple_simplify_408 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_BSWAP128))
15914 : 0 : return true;
15915 : : }
15916 : 0 : break;
15917 : : }
15918 : : default:;
15919 : : }
15920 : : }
15921 : : break;
15922 : 0 : case CFN_BUILT_IN_BSWAP16:
15923 : 0 : if (gimple_call_num_args (_c1) == 1)
15924 : : {
15925 : 0 : tree _q20 = gimple_call_arg (_c1, 0);
15926 : 0 : _q20 = do_valueize (valueize, _q20);
15927 : 0 : switch (TREE_CODE (_p1))
15928 : : {
15929 : 0 : case INTEGER_CST:
15930 : 0 : {
15931 : 0 : {
15932 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _p0, _q20, _p1 };
15933 : 0 : if (gimple_simplify_408 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_BSWAP16))
15934 : 0 : return true;
15935 : : }
15936 : 0 : break;
15937 : : }
15938 : : default:;
15939 : : }
15940 : : }
15941 : : break;
15942 : 79 : case CFN_BUILT_IN_BSWAP32:
15943 : 79 : if (gimple_call_num_args (_c1) == 1)
15944 : : {
15945 : 79 : tree _q20 = gimple_call_arg (_c1, 0);
15946 : 79 : _q20 = do_valueize (valueize, _q20);
15947 : 79 : switch (TREE_CODE (_p1))
15948 : : {
15949 : 64 : case INTEGER_CST:
15950 : 64 : {
15951 : 64 : {
15952 : 64 : tree captures[3] ATTRIBUTE_UNUSED = { _p0, _q20, _p1 };
15953 : 64 : if (gimple_simplify_408 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_BSWAP32))
15954 : 0 : return true;
15955 : : }
15956 : 64 : break;
15957 : : }
15958 : : default:;
15959 : : }
15960 : : }
15961 : : break;
15962 : 15 : case CFN_BUILT_IN_BSWAP64:
15963 : 15 : if (gimple_call_num_args (_c1) == 1)
15964 : : {
15965 : 15 : tree _q20 = gimple_call_arg (_c1, 0);
15966 : 15 : _q20 = do_valueize (valueize, _q20);
15967 : 15 : switch (TREE_CODE (_p1))
15968 : : {
15969 : 0 : case INTEGER_CST:
15970 : 0 : {
15971 : 0 : {
15972 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _p0, _q20, _p1 };
15973 : 0 : if (gimple_simplify_408 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_BSWAP64))
15974 : 0 : return true;
15975 : : }
15976 : 0 : break;
15977 : : }
15978 : : default:;
15979 : : }
15980 : : }
15981 : : break;
15982 : : default:;
15983 : : }
15984 : : }
15985 : : break;
15986 : 3229925 : default:;
15987 : : }
15988 : 3229925 : switch (TREE_CODE (_p1))
15989 : : {
15990 : 308892 : case SSA_NAME:
15991 : 308892 : if (gimple *_d1 = get_def (valueize, _p1))
15992 : : {
15993 : 216756 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
15994 : 196295 : switch (gimple_assign_rhs_code (_a1))
15995 : : {
15996 : 159 : case VEC_COND_EXPR:
15997 : 159 : {
15998 : 159 : tree _q30 = gimple_assign_rhs1 (_a1);
15999 : 159 : _q30 = do_valueize (valueize, _q30);
16000 : 159 : tree _q31 = gimple_assign_rhs2 (_a1);
16001 : 159 : _q31 = do_valueize (valueize, _q31);
16002 : 159 : tree _q32 = gimple_assign_rhs3 (_a1);
16003 : 159 : _q32 = do_valueize (valueize, _q32);
16004 : 159 : {
16005 : 159 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _p1, _q30, _q31, _q32 };
16006 : 159 : if (VECTOR_TYPE_P (type)
16007 : 159 : && (TREE_CODE_CLASS (RSHIFT_EXPR) != tcc_comparison
16008 : : || types_match (type, TREE_TYPE (captures[3]))
16009 : : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[2]))
16010 : : || (optimize_vectors_before_lowering_p ()
16011 : : && !expand_vec_cond_expr_p (TREE_TYPE (captures[3]), TREE_TYPE (captures[2]))))
16012 : : )
16013 : : {
16014 : 159 : gimple_seq *lseq = seq;
16015 : 159 : if (lseq
16016 : 69 : && (!single_use (captures[1])))
16017 : 90 : lseq = NULL;
16018 : 159 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2389;
16019 : 159 : {
16020 : 159 : res_op->set_op (VEC_COND_EXPR, type, 3);
16021 : 159 : res_op->ops[0] = captures[2];
16022 : 159 : {
16023 : 159 : tree _o1[2], _r1;
16024 : 159 : _o1[0] = captures[0];
16025 : 159 : _o1[1] = captures[3];
16026 : 159 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
16027 : 159 : tem_op.resimplify (NULL, valueize);
16028 : 159 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
16029 : 159 : if (!_r1) goto next_after_fail2389;
16030 : 0 : res_op->ops[1] = _r1;
16031 : : }
16032 : 0 : {
16033 : 0 : tree _o1[2], _r1;
16034 : 0 : _o1[0] = captures[0];
16035 : 0 : _o1[1] = captures[4];
16036 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
16037 : 0 : tem_op.resimplify (NULL, valueize);
16038 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
16039 : 0 : if (!_r1) goto next_after_fail2389;
16040 : 0 : res_op->ops[2] = _r1;
16041 : : }
16042 : 0 : res_op->resimplify (lseq, valueize);
16043 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1021, __FILE__, __LINE__, true);
16044 : 0 : return true;
16045 : : }
16046 : 159 : next_after_fail2389:;
16047 : : }
16048 : : }
16049 : 159 : break;
16050 : : }
16051 : : default:;
16052 : : }
16053 : : }
16054 : : break;
16055 : 3229925 : default:;
16056 : : }
16057 : 3229925 : switch (TREE_CODE (_p0))
16058 : : {
16059 : 3116733 : case SSA_NAME:
16060 : 3116733 : if (gimple *_d1 = get_def (valueize, _p0))
16061 : : {
16062 : 1907267 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
16063 : 1703447 : switch (gimple_assign_rhs_code (_a1))
16064 : : {
16065 : 139475 : case MULT_EXPR:
16066 : 139475 : {
16067 : 139475 : tree _q20 = gimple_assign_rhs1 (_a1);
16068 : 139475 : _q20 = do_valueize (valueize, _q20);
16069 : 139475 : tree _q21 = gimple_assign_rhs2 (_a1);
16070 : 139475 : _q21 = do_valueize (valueize, _q21);
16071 : 139475 : if (tree_swap_operands_p (_q20, _q21))
16072 : 5035 : std::swap (_q20, _q21);
16073 : 139475 : switch (TREE_CODE (_q20))
16074 : : {
16075 : 139475 : case SSA_NAME:
16076 : 139475 : if (gimple *_d2 = get_def (valueize, _q20))
16077 : : {
16078 : 133273 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
16079 : 128027 : switch (gimple_assign_rhs_code (_a2))
16080 : : {
16081 : 56083 : case BIT_AND_EXPR:
16082 : 56083 : {
16083 : 56083 : tree _q30 = gimple_assign_rhs1 (_a2);
16084 : 56083 : _q30 = do_valueize (valueize, _q30);
16085 : 56083 : tree _q31 = gimple_assign_rhs2 (_a2);
16086 : 56083 : _q31 = do_valueize (valueize, _q31);
16087 : 56083 : if (tree_swap_operands_p (_q30, _q31))
16088 : 131 : std::swap (_q30, _q31);
16089 : 56083 : switch (TREE_CODE (_q30))
16090 : : {
16091 : 56083 : case SSA_NAME:
16092 : 56083 : if (gimple *_d3 = get_def (valueize, _q30))
16093 : : {
16094 : 55826 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
16095 : 83858 : switch (gimple_assign_rhs_code (_a3))
16096 : : {
16097 : 6764 : case PLUS_EXPR:
16098 : 6764 : {
16099 : 6764 : tree _q40 = gimple_assign_rhs1 (_a3);
16100 : 6764 : _q40 = do_valueize (valueize, _q40);
16101 : 6764 : tree _q41 = gimple_assign_rhs2 (_a3);
16102 : 6764 : _q41 = do_valueize (valueize, _q41);
16103 : 6764 : if (tree_swap_operands_p (_q40, _q41))
16104 : 415 : std::swap (_q40, _q41);
16105 : 6764 : switch (TREE_CODE (_q40))
16106 : : {
16107 : 6764 : case SSA_NAME:
16108 : 6764 : if (gimple *_d4 = get_def (valueize, _q40))
16109 : : {
16110 : 6756 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
16111 : 9643 : switch (gimple_assign_rhs_code (_a4))
16112 : : {
16113 : 1103 : case RSHIFT_EXPR:
16114 : 1103 : {
16115 : 1103 : tree _q50 = gimple_assign_rhs1 (_a4);
16116 : 1103 : _q50 = do_valueize (valueize, _q50);
16117 : 1103 : tree _q51 = gimple_assign_rhs2 (_a4);
16118 : 1103 : _q51 = do_valueize (valueize, _q51);
16119 : 1103 : switch (TREE_CODE (_q51))
16120 : : {
16121 : 1103 : case INTEGER_CST:
16122 : 1103 : {
16123 : 1103 : if ((_q41 == _q50 && ! TREE_SIDE_EFFECTS (_q41)) || (operand_equal_p (_q41, _q50, 0) && types_match (_q41, _q50)))
16124 : : {
16125 : 259 : switch (TREE_CODE (_q41))
16126 : : {
16127 : 259 : case SSA_NAME:
16128 : 259 : if (gimple *_d5 = get_def (valueize, _q41))
16129 : : {
16130 : 216 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
16131 : 220 : switch (gimple_assign_rhs_code (_a5))
16132 : : {
16133 : 212 : case PLUS_EXPR:
16134 : 212 : {
16135 : 212 : tree _q90 = gimple_assign_rhs1 (_a5);
16136 : 212 : _q90 = do_valueize (valueize, _q90);
16137 : 212 : tree _q91 = gimple_assign_rhs2 (_a5);
16138 : 212 : _q91 = do_valueize (valueize, _q91);
16139 : 212 : if (tree_swap_operands_p (_q90, _q91))
16140 : 14 : std::swap (_q90, _q91);
16141 : 212 : switch (TREE_CODE (_q90))
16142 : : {
16143 : 212 : case SSA_NAME:
16144 : 212 : if (gimple *_d6 = get_def (valueize, _q90))
16145 : : {
16146 : 212 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
16147 : 212 : switch (gimple_assign_rhs_code (_a6))
16148 : : {
16149 : 212 : case BIT_AND_EXPR:
16150 : 212 : {
16151 : 212 : tree _q100 = gimple_assign_rhs1 (_a6);
16152 : 212 : _q100 = do_valueize (valueize, _q100);
16153 : 212 : tree _q101 = gimple_assign_rhs2 (_a6);
16154 : 212 : _q101 = do_valueize (valueize, _q101);
16155 : 212 : if (tree_swap_operands_p (_q100, _q101))
16156 : 0 : std::swap (_q100, _q101);
16157 : 212 : switch (TREE_CODE (_q101))
16158 : : {
16159 : 212 : case INTEGER_CST:
16160 : 212 : {
16161 : 212 : switch (TREE_CODE (_q91))
16162 : : {
16163 : 212 : case SSA_NAME:
16164 : 212 : if (gimple *_d7 = get_def (valueize, _q91))
16165 : : {
16166 : 212 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
16167 : 212 : switch (gimple_assign_rhs_code (_a7))
16168 : : {
16169 : 212 : case BIT_AND_EXPR:
16170 : 212 : {
16171 : 212 : tree _q130 = gimple_assign_rhs1 (_a7);
16172 : 212 : _q130 = do_valueize (valueize, _q130);
16173 : 212 : tree _q131 = gimple_assign_rhs2 (_a7);
16174 : 212 : _q131 = do_valueize (valueize, _q131);
16175 : 212 : if (tree_swap_operands_p (_q130, _q131))
16176 : 0 : std::swap (_q130, _q131);
16177 : 212 : switch (TREE_CODE (_q130))
16178 : : {
16179 : 212 : case SSA_NAME:
16180 : 212 : if (gimple *_d8 = get_def (valueize, _q130))
16181 : : {
16182 : 212 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
16183 : 212 : switch (gimple_assign_rhs_code (_a8))
16184 : : {
16185 : 212 : case RSHIFT_EXPR:
16186 : 212 : {
16187 : 212 : tree _q140 = gimple_assign_rhs1 (_a8);
16188 : 212 : _q140 = do_valueize (valueize, _q140);
16189 : 212 : tree _q141 = gimple_assign_rhs2 (_a8);
16190 : 212 : _q141 = do_valueize (valueize, _q141);
16191 : 212 : if ((_q140 == _q100 && ! TREE_SIDE_EFFECTS (_q140)) || (operand_equal_p (_q140, _q100, 0) && types_match (_q140, _q100)))
16192 : : {
16193 : 212 : switch (TREE_CODE (_q140))
16194 : : {
16195 : 212 : case SSA_NAME:
16196 : 212 : if (gimple *_d9 = get_def (valueize, _q140))
16197 : : {
16198 : 212 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
16199 : 172 : switch (gimple_assign_rhs_code (_a9))
16200 : : {
16201 : 172 : case MINUS_EXPR:
16202 : 172 : {
16203 : 172 : tree _q160 = gimple_assign_rhs1 (_a9);
16204 : 172 : _q160 = do_valueize (valueize, _q160);
16205 : 172 : tree _q161 = gimple_assign_rhs2 (_a9);
16206 : 172 : _q161 = do_valueize (valueize, _q161);
16207 : 172 : switch (TREE_CODE (_q161))
16208 : : {
16209 : 172 : case SSA_NAME:
16210 : 172 : if (gimple *_d10 = get_def (valueize, _q161))
16211 : : {
16212 : 172 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
16213 : 172 : switch (gimple_assign_rhs_code (_a10))
16214 : : {
16215 : 172 : case BIT_AND_EXPR:
16216 : 172 : {
16217 : 172 : tree _q180 = gimple_assign_rhs1 (_a10);
16218 : 172 : _q180 = do_valueize (valueize, _q180);
16219 : 172 : tree _q181 = gimple_assign_rhs2 (_a10);
16220 : 172 : _q181 = do_valueize (valueize, _q181);
16221 : 172 : if (tree_swap_operands_p (_q180, _q181))
16222 : 0 : std::swap (_q180, _q181);
16223 : 172 : switch (TREE_CODE (_q180))
16224 : : {
16225 : 172 : case SSA_NAME:
16226 : 172 : if (gimple *_d11 = get_def (valueize, _q180))
16227 : : {
16228 : 172 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
16229 : 172 : switch (gimple_assign_rhs_code (_a11))
16230 : : {
16231 : 172 : case RSHIFT_EXPR:
16232 : 172 : {
16233 : 172 : tree _q190 = gimple_assign_rhs1 (_a11);
16234 : 172 : _q190 = do_valueize (valueize, _q190);
16235 : 172 : tree _q191 = gimple_assign_rhs2 (_a11);
16236 : 172 : _q191 = do_valueize (valueize, _q191);
16237 : 172 : if ((_q190 == _q160 && ! TREE_SIDE_EFFECTS (_q190)) || (operand_equal_p (_q190, _q160, 0) && types_match (_q190, _q160)))
16238 : : {
16239 : 172 : switch (TREE_CODE (_q191))
16240 : : {
16241 : 172 : case INTEGER_CST:
16242 : 172 : {
16243 : 172 : switch (TREE_CODE (_q181))
16244 : : {
16245 : 172 : case INTEGER_CST:
16246 : 172 : {
16247 : 172 : switch (TREE_CODE (_q141))
16248 : : {
16249 : 172 : case INTEGER_CST:
16250 : 172 : {
16251 : 172 : switch (TREE_CODE (_q131))
16252 : : {
16253 : 172 : case INTEGER_CST:
16254 : 172 : {
16255 : 172 : switch (TREE_CODE (_q31))
16256 : : {
16257 : 172 : case INTEGER_CST:
16258 : 172 : {
16259 : 172 : switch (TREE_CODE (_q21))
16260 : : {
16261 : 172 : case INTEGER_CST:
16262 : 172 : {
16263 : 172 : switch (TREE_CODE (_p1))
16264 : : {
16265 : 172 : case INTEGER_CST:
16266 : 172 : {
16267 : 172 : {
16268 : 172 : tree captures[12] ATTRIBUTE_UNUSED = { _q50, _q51, _q100, _q101, _q160, _q191, _q181, _q141, _q131, _q31, _q21, _p1 };
16269 : 172 : if (gimple_simplify_409 (res_op, seq, valueize, type, captures))
16270 : 0 : return true;
16271 : : }
16272 : 172 : break;
16273 : : }
16274 : : default:;
16275 : : }
16276 : : break;
16277 : : }
16278 : : default:;
16279 : : }
16280 : : break;
16281 : : }
16282 : : default:;
16283 : : }
16284 : : break;
16285 : : }
16286 : : default:;
16287 : : }
16288 : : break;
16289 : : }
16290 : : default:;
16291 : : }
16292 : : break;
16293 : : }
16294 : : default:;
16295 : : }
16296 : : break;
16297 : : }
16298 : : default:;
16299 : : }
16300 : : }
16301 : : break;
16302 : : }
16303 : : default:;
16304 : : }
16305 : : }
16306 : : break;
16307 : : default:;
16308 : : }
16309 : 212 : break;
16310 : : }
16311 : : default:;
16312 : : }
16313 : : }
16314 : : break;
16315 : : default:;
16316 : : }
16317 : : break;
16318 : : }
16319 : : default:;
16320 : : }
16321 : : }
16322 : : break;
16323 : : default:;
16324 : : }
16325 : : }
16326 : : break;
16327 : : }
16328 : : default:;
16329 : : }
16330 : : }
16331 : : break;
16332 : : default:;
16333 : : }
16334 : 212 : break;
16335 : : }
16336 : : default:;
16337 : : }
16338 : : }
16339 : : break;
16340 : : default:;
16341 : : }
16342 : : break;
16343 : : }
16344 : 212 : default:;
16345 : : }
16346 : 212 : switch (TREE_CODE (_q100))
16347 : : {
16348 : 212 : case SSA_NAME:
16349 : 212 : if (gimple *_d7 = get_def (valueize, _q100))
16350 : : {
16351 : 212 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
16352 : 172 : switch (gimple_assign_rhs_code (_a7))
16353 : : {
16354 : 0 : case RSHIFT_EXPR:
16355 : 0 : {
16356 : 0 : tree _q110 = gimple_assign_rhs1 (_a7);
16357 : 0 : _q110 = do_valueize (valueize, _q110);
16358 : 0 : tree _q111 = gimple_assign_rhs2 (_a7);
16359 : 0 : _q111 = do_valueize (valueize, _q111);
16360 : 0 : switch (TREE_CODE (_q110))
16361 : : {
16362 : 0 : case SSA_NAME:
16363 : 0 : if (gimple *_d8 = get_def (valueize, _q110))
16364 : : {
16365 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
16366 : 0 : switch (gimple_assign_rhs_code (_a8))
16367 : : {
16368 : 0 : case MINUS_EXPR:
16369 : 0 : {
16370 : 0 : tree _q120 = gimple_assign_rhs1 (_a8);
16371 : 0 : _q120 = do_valueize (valueize, _q120);
16372 : 0 : tree _q121 = gimple_assign_rhs2 (_a8);
16373 : 0 : _q121 = do_valueize (valueize, _q121);
16374 : 0 : switch (TREE_CODE (_q121))
16375 : : {
16376 : 0 : case SSA_NAME:
16377 : 0 : if (gimple *_d9 = get_def (valueize, _q121))
16378 : : {
16379 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
16380 : 0 : switch (gimple_assign_rhs_code (_a9))
16381 : : {
16382 : 0 : case BIT_AND_EXPR:
16383 : 0 : {
16384 : 0 : tree _q140 = gimple_assign_rhs1 (_a9);
16385 : 0 : _q140 = do_valueize (valueize, _q140);
16386 : 0 : tree _q141 = gimple_assign_rhs2 (_a9);
16387 : 0 : _q141 = do_valueize (valueize, _q141);
16388 : 0 : if (tree_swap_operands_p (_q140, _q141))
16389 : 0 : std::swap (_q140, _q141);
16390 : 0 : switch (TREE_CODE (_q140))
16391 : : {
16392 : 0 : case SSA_NAME:
16393 : 0 : if (gimple *_d10 = get_def (valueize, _q140))
16394 : : {
16395 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
16396 : 0 : switch (gimple_assign_rhs_code (_a10))
16397 : : {
16398 : 0 : case RSHIFT_EXPR:
16399 : 0 : {
16400 : 0 : tree _q150 = gimple_assign_rhs1 (_a10);
16401 : 0 : _q150 = do_valueize (valueize, _q150);
16402 : 0 : tree _q151 = gimple_assign_rhs2 (_a10);
16403 : 0 : _q151 = do_valueize (valueize, _q151);
16404 : 0 : if ((_q150 == _q120 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q120, 0) && types_match (_q150, _q120)))
16405 : : {
16406 : 0 : switch (TREE_CODE (_q151))
16407 : : {
16408 : 0 : case INTEGER_CST:
16409 : 0 : {
16410 : 0 : switch (TREE_CODE (_q141))
16411 : : {
16412 : 0 : case INTEGER_CST:
16413 : 0 : {
16414 : 0 : switch (TREE_CODE (_q111))
16415 : : {
16416 : 0 : case INTEGER_CST:
16417 : 0 : {
16418 : 0 : switch (TREE_CODE (_q101))
16419 : : {
16420 : 0 : case INTEGER_CST:
16421 : 0 : {
16422 : 0 : switch (TREE_CODE (_q91))
16423 : : {
16424 : 0 : case SSA_NAME:
16425 : 0 : if (gimple *_d11 = get_def (valueize, _q91))
16426 : : {
16427 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
16428 : 0 : switch (gimple_assign_rhs_code (_a11))
16429 : : {
16430 : 0 : case BIT_AND_EXPR:
16431 : 0 : {
16432 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
16433 : 0 : _q210 = do_valueize (valueize, _q210);
16434 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
16435 : 0 : _q211 = do_valueize (valueize, _q211);
16436 : 0 : if (tree_swap_operands_p (_q210, _q211))
16437 : 0 : std::swap (_q210, _q211);
16438 : 0 : if ((_q210 == _q110 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q110, 0) && types_match (_q210, _q110)))
16439 : : {
16440 : 0 : switch (TREE_CODE (_q211))
16441 : : {
16442 : 0 : case INTEGER_CST:
16443 : 0 : {
16444 : 0 : switch (TREE_CODE (_q31))
16445 : : {
16446 : 0 : case INTEGER_CST:
16447 : 0 : {
16448 : 0 : switch (TREE_CODE (_q21))
16449 : : {
16450 : 0 : case INTEGER_CST:
16451 : 0 : {
16452 : 0 : switch (TREE_CODE (_p1))
16453 : : {
16454 : 0 : case INTEGER_CST:
16455 : 0 : {
16456 : 0 : {
16457 : 0 : tree captures[12] ATTRIBUTE_UNUSED = { _q50, _q51, _q110, _q211, _q120, _q151, _q141, _q111, _q101, _q31, _q21, _p1 };
16458 : 0 : if (gimple_simplify_409 (res_op, seq, valueize, type, captures))
16459 : 0 : return true;
16460 : : }
16461 : 0 : break;
16462 : : }
16463 : : default:;
16464 : : }
16465 : : break;
16466 : : }
16467 : : default:;
16468 : : }
16469 : : break;
16470 : : }
16471 : : default:;
16472 : : }
16473 : : break;
16474 : : }
16475 : : default:;
16476 : : }
16477 : : }
16478 : 3261220 : break;
16479 : : }
16480 : : default:;
16481 : : }
16482 : : }
16483 : : break;
16484 : : default:;
16485 : : }
16486 : : break;
16487 : : }
16488 : : default:;
16489 : : }
16490 : : break;
16491 : : }
16492 : : default:;
16493 : : }
16494 : : break;
16495 : : }
16496 : : default:;
16497 : : }
16498 : : break;
16499 : : }
16500 : : default:;
16501 : : }
16502 : : }
16503 : : break;
16504 : : }
16505 : : default:;
16506 : : }
16507 : : }
16508 : : break;
16509 : : default:;
16510 : : }
16511 : 3261220 : break;
16512 : : }
16513 : : default:;
16514 : : }
16515 : : }
16516 : : break;
16517 : : default:;
16518 : : }
16519 : : break;
16520 : : }
16521 : : default:;
16522 : : }
16523 : : }
16524 : : break;
16525 : : default:;
16526 : : }
16527 : : break;
16528 : : }
16529 : : default:;
16530 : : }
16531 : : }
16532 : : break;
16533 : : default:;
16534 : : }
16535 : 3261220 : break;
16536 : : }
16537 : : default:;
16538 : : }
16539 : : }
16540 : : break;
16541 : : default:;
16542 : : }
16543 : 3261220 : break;
16544 : : }
16545 : : default:;
16546 : : }
16547 : : }
16548 : : break;
16549 : : default:;
16550 : : }
16551 : : }
16552 : : break;
16553 : : }
16554 : : default:;
16555 : : }
16556 : : break;
16557 : : }
16558 : 1669 : case PLUS_EXPR:
16559 : 1669 : {
16560 : 1669 : tree _q50 = gimple_assign_rhs1 (_a4);
16561 : 1669 : _q50 = do_valueize (valueize, _q50);
16562 : 1669 : tree _q51 = gimple_assign_rhs2 (_a4);
16563 : 1669 : _q51 = do_valueize (valueize, _q51);
16564 : 1669 : if (tree_swap_operands_p (_q50, _q51))
16565 : 34 : std::swap (_q50, _q51);
16566 : 1669 : switch (TREE_CODE (_q50))
16567 : : {
16568 : 1669 : case SSA_NAME:
16569 : 1669 : if (gimple *_d5 = get_def (valueize, _q50))
16570 : : {
16571 : 1669 : if (gassign *_a5 = dyn_cast <gassign *> (_d5))
16572 : 1761 : switch (gimple_assign_rhs_code (_a5))
16573 : : {
16574 : 0 : case BIT_AND_EXPR:
16575 : 0 : {
16576 : 0 : tree _q60 = gimple_assign_rhs1 (_a5);
16577 : 0 : _q60 = do_valueize (valueize, _q60);
16578 : 0 : tree _q61 = gimple_assign_rhs2 (_a5);
16579 : 0 : _q61 = do_valueize (valueize, _q61);
16580 : 0 : if (tree_swap_operands_p (_q60, _q61))
16581 : 0 : std::swap (_q60, _q61);
16582 : 0 : switch (TREE_CODE (_q61))
16583 : : {
16584 : 0 : case INTEGER_CST:
16585 : 0 : {
16586 : 0 : switch (TREE_CODE (_q51))
16587 : : {
16588 : 0 : case SSA_NAME:
16589 : 0 : if (gimple *_d6 = get_def (valueize, _q51))
16590 : : {
16591 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
16592 : 0 : switch (gimple_assign_rhs_code (_a6))
16593 : : {
16594 : 0 : case BIT_AND_EXPR:
16595 : 0 : {
16596 : 0 : tree _q90 = gimple_assign_rhs1 (_a6);
16597 : 0 : _q90 = do_valueize (valueize, _q90);
16598 : 0 : tree _q91 = gimple_assign_rhs2 (_a6);
16599 : 0 : _q91 = do_valueize (valueize, _q91);
16600 : 0 : if (tree_swap_operands_p (_q90, _q91))
16601 : 0 : std::swap (_q90, _q91);
16602 : 0 : switch (TREE_CODE (_q90))
16603 : : {
16604 : 0 : case SSA_NAME:
16605 : 0 : if (gimple *_d7 = get_def (valueize, _q90))
16606 : : {
16607 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
16608 : 0 : switch (gimple_assign_rhs_code (_a7))
16609 : : {
16610 : 0 : case RSHIFT_EXPR:
16611 : 0 : {
16612 : 0 : tree _q100 = gimple_assign_rhs1 (_a7);
16613 : 0 : _q100 = do_valueize (valueize, _q100);
16614 : 0 : tree _q101 = gimple_assign_rhs2 (_a7);
16615 : 0 : _q101 = do_valueize (valueize, _q101);
16616 : 0 : if ((_q100 == _q60 && ! TREE_SIDE_EFFECTS (_q100)) || (operand_equal_p (_q100, _q60, 0) && types_match (_q100, _q60)))
16617 : : {
16618 : 0 : switch (TREE_CODE (_q100))
16619 : : {
16620 : 0 : case SSA_NAME:
16621 : 0 : if (gimple *_d8 = get_def (valueize, _q100))
16622 : : {
16623 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
16624 : 0 : switch (gimple_assign_rhs_code (_a8))
16625 : : {
16626 : 0 : case MINUS_EXPR:
16627 : 0 : {
16628 : 0 : tree _q120 = gimple_assign_rhs1 (_a8);
16629 : 0 : _q120 = do_valueize (valueize, _q120);
16630 : 0 : tree _q121 = gimple_assign_rhs2 (_a8);
16631 : 0 : _q121 = do_valueize (valueize, _q121);
16632 : 0 : switch (TREE_CODE (_q121))
16633 : : {
16634 : 0 : case SSA_NAME:
16635 : 0 : if (gimple *_d9 = get_def (valueize, _q121))
16636 : : {
16637 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
16638 : 0 : switch (gimple_assign_rhs_code (_a9))
16639 : : {
16640 : 0 : case BIT_AND_EXPR:
16641 : 0 : {
16642 : 0 : tree _q140 = gimple_assign_rhs1 (_a9);
16643 : 0 : _q140 = do_valueize (valueize, _q140);
16644 : 0 : tree _q141 = gimple_assign_rhs2 (_a9);
16645 : 0 : _q141 = do_valueize (valueize, _q141);
16646 : 0 : if (tree_swap_operands_p (_q140, _q141))
16647 : 0 : std::swap (_q140, _q141);
16648 : 0 : switch (TREE_CODE (_q140))
16649 : : {
16650 : 0 : case SSA_NAME:
16651 : 0 : if (gimple *_d10 = get_def (valueize, _q140))
16652 : : {
16653 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
16654 : 0 : switch (gimple_assign_rhs_code (_a10))
16655 : : {
16656 : 0 : case RSHIFT_EXPR:
16657 : 0 : {
16658 : 0 : tree _q150 = gimple_assign_rhs1 (_a10);
16659 : 0 : _q150 = do_valueize (valueize, _q150);
16660 : 0 : tree _q151 = gimple_assign_rhs2 (_a10);
16661 : 0 : _q151 = do_valueize (valueize, _q151);
16662 : 0 : if ((_q150 == _q120 && ! TREE_SIDE_EFFECTS (_q150)) || (operand_equal_p (_q150, _q120, 0) && types_match (_q150, _q120)))
16663 : : {
16664 : 0 : switch (TREE_CODE (_q151))
16665 : : {
16666 : 0 : case INTEGER_CST:
16667 : 0 : {
16668 : 0 : switch (TREE_CODE (_q141))
16669 : : {
16670 : 0 : case INTEGER_CST:
16671 : 0 : {
16672 : 0 : switch (TREE_CODE (_q101))
16673 : : {
16674 : 0 : case INTEGER_CST:
16675 : 0 : {
16676 : 0 : switch (TREE_CODE (_q91))
16677 : : {
16678 : 0 : case INTEGER_CST:
16679 : 0 : {
16680 : 0 : switch (TREE_CODE (_q41))
16681 : : {
16682 : 0 : case SSA_NAME:
16683 : 0 : if (gimple *_d11 = get_def (valueize, _q41))
16684 : : {
16685 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
16686 : 0 : switch (gimple_assign_rhs_code (_a11))
16687 : : {
16688 : 0 : case RSHIFT_EXPR:
16689 : 0 : {
16690 : 0 : tree _q210 = gimple_assign_rhs1 (_a11);
16691 : 0 : _q210 = do_valueize (valueize, _q210);
16692 : 0 : tree _q211 = gimple_assign_rhs2 (_a11);
16693 : 0 : _q211 = do_valueize (valueize, _q211);
16694 : 0 : if ((_q210 == _q40 && ! TREE_SIDE_EFFECTS (_q210)) || (operand_equal_p (_q210, _q40, 0) && types_match (_q210, _q40)))
16695 : : {
16696 : 0 : switch (TREE_CODE (_q211))
16697 : : {
16698 : 0 : case INTEGER_CST:
16699 : 0 : {
16700 : 0 : switch (TREE_CODE (_q31))
16701 : : {
16702 : 0 : case INTEGER_CST:
16703 : 0 : {
16704 : 0 : switch (TREE_CODE (_q21))
16705 : : {
16706 : 0 : case INTEGER_CST:
16707 : 0 : {
16708 : 0 : switch (TREE_CODE (_p1))
16709 : : {
16710 : 0 : case INTEGER_CST:
16711 : 0 : {
16712 : 0 : {
16713 : 0 : tree captures[12] ATTRIBUTE_UNUSED = { _q40, _q211, _q60, _q61, _q120, _q151, _q141, _q101, _q91, _q31, _q21, _p1 };
16714 : 0 : if (gimple_simplify_409 (res_op, seq, valueize, type, captures))
16715 : 0 : return true;
16716 : : }
16717 : 0 : break;
16718 : : }
16719 : : default:;
16720 : : }
16721 : : break;
16722 : : }
16723 : : default:;
16724 : : }
16725 : : break;
16726 : : }
16727 : : default:;
16728 : : }
16729 : : break;
16730 : : }
16731 : : default:;
16732 : : }
16733 : : }
16734 : : break;
16735 : : }
16736 : : default:;
16737 : : }
16738 : : }
16739 : : break;
16740 : : default:;
16741 : : }
16742 : : break;
16743 : : }
16744 : : default:;
16745 : : }
16746 : : break;
16747 : : }
16748 : : default:;
16749 : : }
16750 : : break;
16751 : : }
16752 : : default:;
16753 : : }
16754 : : break;
16755 : : }
16756 : : default:;
16757 : : }
16758 : : }
16759 : : break;
16760 : : }
16761 : : default:;
16762 : : }
16763 : : }
16764 : : break;
16765 : : default:;
16766 : : }
16767 : 0 : break;
16768 : : }
16769 : : default:;
16770 : : }
16771 : : }
16772 : : break;
16773 : : default:;
16774 : : }
16775 : : break;
16776 : : }
16777 : : default:;
16778 : : }
16779 : : }
16780 : : break;
16781 : : default:;
16782 : : }
16783 : : }
16784 : : break;
16785 : : }
16786 : : default:;
16787 : : }
16788 : : }
16789 : : break;
16790 : : default:;
16791 : : }
16792 : 0 : break;
16793 : : }
16794 : : default:;
16795 : : }
16796 : : }
16797 : : break;
16798 : : default:;
16799 : : }
16800 : : break;
16801 : : }
16802 : 0 : default:;
16803 : : }
16804 : 0 : switch (TREE_CODE (_q60))
16805 : : {
16806 : 0 : case SSA_NAME:
16807 : 0 : if (gimple *_d6 = get_def (valueize, _q60))
16808 : : {
16809 : 0 : if (gassign *_a6 = dyn_cast <gassign *> (_d6))
16810 : 0 : switch (gimple_assign_rhs_code (_a6))
16811 : : {
16812 : 0 : case RSHIFT_EXPR:
16813 : 0 : {
16814 : 0 : tree _q70 = gimple_assign_rhs1 (_a6);
16815 : 0 : _q70 = do_valueize (valueize, _q70);
16816 : 0 : tree _q71 = gimple_assign_rhs2 (_a6);
16817 : 0 : _q71 = do_valueize (valueize, _q71);
16818 : 0 : switch (TREE_CODE (_q70))
16819 : : {
16820 : 0 : case SSA_NAME:
16821 : 0 : if (gimple *_d7 = get_def (valueize, _q70))
16822 : : {
16823 : 0 : if (gassign *_a7 = dyn_cast <gassign *> (_d7))
16824 : 0 : switch (gimple_assign_rhs_code (_a7))
16825 : : {
16826 : 0 : case MINUS_EXPR:
16827 : 0 : {
16828 : 0 : tree _q80 = gimple_assign_rhs1 (_a7);
16829 : 0 : _q80 = do_valueize (valueize, _q80);
16830 : 0 : tree _q81 = gimple_assign_rhs2 (_a7);
16831 : 0 : _q81 = do_valueize (valueize, _q81);
16832 : 0 : switch (TREE_CODE (_q81))
16833 : : {
16834 : 0 : case SSA_NAME:
16835 : 0 : if (gimple *_d8 = get_def (valueize, _q81))
16836 : : {
16837 : 0 : if (gassign *_a8 = dyn_cast <gassign *> (_d8))
16838 : 0 : switch (gimple_assign_rhs_code (_a8))
16839 : : {
16840 : 0 : case BIT_AND_EXPR:
16841 : 0 : {
16842 : 0 : tree _q100 = gimple_assign_rhs1 (_a8);
16843 : 0 : _q100 = do_valueize (valueize, _q100);
16844 : 0 : tree _q101 = gimple_assign_rhs2 (_a8);
16845 : 0 : _q101 = do_valueize (valueize, _q101);
16846 : 0 : if (tree_swap_operands_p (_q100, _q101))
16847 : 0 : std::swap (_q100, _q101);
16848 : 0 : switch (TREE_CODE (_q100))
16849 : : {
16850 : 0 : case SSA_NAME:
16851 : 0 : if (gimple *_d9 = get_def (valueize, _q100))
16852 : : {
16853 : 0 : if (gassign *_a9 = dyn_cast <gassign *> (_d9))
16854 : 0 : switch (gimple_assign_rhs_code (_a9))
16855 : : {
16856 : 0 : case RSHIFT_EXPR:
16857 : 0 : {
16858 : 0 : tree _q110 = gimple_assign_rhs1 (_a9);
16859 : 0 : _q110 = do_valueize (valueize, _q110);
16860 : 0 : tree _q111 = gimple_assign_rhs2 (_a9);
16861 : 0 : _q111 = do_valueize (valueize, _q111);
16862 : 0 : if ((_q110 == _q80 && ! TREE_SIDE_EFFECTS (_q110)) || (operand_equal_p (_q110, _q80, 0) && types_match (_q110, _q80)))
16863 : : {
16864 : 0 : switch (TREE_CODE (_q111))
16865 : : {
16866 : 0 : case INTEGER_CST:
16867 : 0 : {
16868 : 0 : switch (TREE_CODE (_q101))
16869 : : {
16870 : 0 : case INTEGER_CST:
16871 : 0 : {
16872 : 0 : switch (TREE_CODE (_q71))
16873 : : {
16874 : 0 : case INTEGER_CST:
16875 : 0 : {
16876 : 0 : switch (TREE_CODE (_q61))
16877 : : {
16878 : 0 : case INTEGER_CST:
16879 : 0 : {
16880 : 0 : switch (TREE_CODE (_q51))
16881 : : {
16882 : 0 : case SSA_NAME:
16883 : 0 : if (gimple *_d10 = get_def (valueize, _q51))
16884 : : {
16885 : 0 : if (gassign *_a10 = dyn_cast <gassign *> (_d10))
16886 : 0 : switch (gimple_assign_rhs_code (_a10))
16887 : : {
16888 : 0 : case BIT_AND_EXPR:
16889 : 0 : {
16890 : 0 : tree _q170 = gimple_assign_rhs1 (_a10);
16891 : 0 : _q170 = do_valueize (valueize, _q170);
16892 : 0 : tree _q171 = gimple_assign_rhs2 (_a10);
16893 : 0 : _q171 = do_valueize (valueize, _q171);
16894 : 0 : if (tree_swap_operands_p (_q170, _q171))
16895 : 0 : std::swap (_q170, _q171);
16896 : 0 : if ((_q170 == _q70 && ! TREE_SIDE_EFFECTS (_q170)) || (operand_equal_p (_q170, _q70, 0) && types_match (_q170, _q70)))
16897 : : {
16898 : 0 : switch (TREE_CODE (_q171))
16899 : : {
16900 : 0 : case INTEGER_CST:
16901 : 0 : {
16902 : 0 : switch (TREE_CODE (_q41))
16903 : : {
16904 : 0 : case SSA_NAME:
16905 : 0 : if (gimple *_d11 = get_def (valueize, _q41))
16906 : : {
16907 : 0 : if (gassign *_a11 = dyn_cast <gassign *> (_d11))
16908 : 0 : switch (gimple_assign_rhs_code (_a11))
16909 : : {
16910 : 0 : case RSHIFT_EXPR:
16911 : 0 : {
16912 : 0 : tree _q200 = gimple_assign_rhs1 (_a11);
16913 : 0 : _q200 = do_valueize (valueize, _q200);
16914 : 0 : tree _q201 = gimple_assign_rhs2 (_a11);
16915 : 0 : _q201 = do_valueize (valueize, _q201);
16916 : 0 : if ((_q200 == _q40 && ! TREE_SIDE_EFFECTS (_q200)) || (operand_equal_p (_q200, _q40, 0) && types_match (_q200, _q40)))
16917 : : {
16918 : 0 : switch (TREE_CODE (_q201))
16919 : : {
16920 : 0 : case INTEGER_CST:
16921 : 0 : {
16922 : 0 : switch (TREE_CODE (_q31))
16923 : : {
16924 : 0 : case INTEGER_CST:
16925 : 0 : {
16926 : 0 : switch (TREE_CODE (_q21))
16927 : : {
16928 : 0 : case INTEGER_CST:
16929 : 0 : {
16930 : 0 : switch (TREE_CODE (_p1))
16931 : : {
16932 : 0 : case INTEGER_CST:
16933 : 0 : {
16934 : 0 : {
16935 : 0 : tree captures[12] ATTRIBUTE_UNUSED = { _q40, _q201, _q70, _q171, _q80, _q111, _q101, _q71, _q61, _q31, _q21, _p1 };
16936 : 0 : if (gimple_simplify_409 (res_op, seq, valueize, type, captures))
16937 : 0 : return true;
16938 : : }
16939 : 0 : break;
16940 : : }
16941 : : default:;
16942 : : }
16943 : : break;
16944 : : }
16945 : : default:;
16946 : : }
16947 : : break;
16948 : : }
16949 : : default:;
16950 : : }
16951 : : break;
16952 : : }
16953 : : default:;
16954 : : }
16955 : : }
16956 : : break;
16957 : : }
16958 : : default:;
16959 : : }
16960 : : }
16961 : : break;
16962 : : default:;
16963 : : }
16964 : : break;
16965 : : }
16966 : : default:;
16967 : : }
16968 : : }
16969 : 3261220 : break;
16970 : : }
16971 : : default:;
16972 : : }
16973 : : }
16974 : : break;
16975 : : default:;
16976 : : }
16977 : : break;
16978 : : }
16979 : : default:;
16980 : : }
16981 : : break;
16982 : : }
16983 : : default:;
16984 : : }
16985 : : break;
16986 : : }
16987 : : default:;
16988 : : }
16989 : : break;
16990 : : }
16991 : : default:;
16992 : : }
16993 : : }
16994 : : break;
16995 : : }
16996 : : default:;
16997 : : }
16998 : : }
16999 : : break;
17000 : : default:;
17001 : : }
17002 : 3261220 : break;
17003 : : }
17004 : : default:;
17005 : : }
17006 : : }
17007 : : break;
17008 : : default:;
17009 : : }
17010 : : break;
17011 : : }
17012 : : default:;
17013 : : }
17014 : : }
17015 : : break;
17016 : : default:;
17017 : : }
17018 : : break;
17019 : : }
17020 : : default:;
17021 : : }
17022 : : }
17023 : : break;
17024 : : default:;
17025 : : }
17026 : 3261220 : break;
17027 : : }
17028 : : default:;
17029 : : }
17030 : : }
17031 : : break;
17032 : : default:;
17033 : : }
17034 : 3261220 : break;
17035 : : }
17036 : : default:;
17037 : : }
17038 : : }
17039 : : break;
17040 : : default:;
17041 : : }
17042 : 3261220 : break;
17043 : : }
17044 : : default:;
17045 : : }
17046 : : }
17047 : : break;
17048 : : default:;
17049 : : }
17050 : 3261220 : break;
17051 : : }
17052 : : default:;
17053 : : }
17054 : : }
17055 : : break;
17056 : : default:;
17057 : : }
17058 : 3261220 : break;
17059 : : }
17060 : 581 : case VEC_PERM_EXPR:
17061 : 581 : {
17062 : 581 : tree _q20 = gimple_assign_rhs1 (_a1);
17063 : 581 : _q20 = do_valueize (valueize, _q20);
17064 : 581 : tree _q21 = gimple_assign_rhs2 (_a1);
17065 : 581 : _q21 = do_valueize (valueize, _q21);
17066 : 581 : tree _q22 = gimple_assign_rhs3 (_a1);
17067 : 581 : _q22 = do_valueize (valueize, _q22);
17068 : 581 : if ((_q21 == _q20 && ! TREE_SIDE_EFFECTS (_q21)) || (operand_equal_p (_q21, _q20, 0) && types_match (_q21, _q20)))
17069 : : {
17070 : 158 : switch (TREE_CODE (_p1))
17071 : : {
17072 : 62 : case SSA_NAME:
17073 : 62 : if (gimple *_d2 = get_def (valueize, _p1))
17074 : : {
17075 : 54 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
17076 : 42 : switch (gimple_assign_rhs_code (_a2))
17077 : : {
17078 : 2 : case VEC_PERM_EXPR:
17079 : 2 : {
17080 : 2 : tree _q60 = gimple_assign_rhs1 (_a2);
17081 : 2 : _q60 = do_valueize (valueize, _q60);
17082 : 2 : tree _q61 = gimple_assign_rhs2 (_a2);
17083 : 2 : _q61 = do_valueize (valueize, _q61);
17084 : 2 : tree _q62 = gimple_assign_rhs3 (_a2);
17085 : 2 : _q62 = do_valueize (valueize, _q62);
17086 : 2 : if ((_q61 == _q60 && ! TREE_SIDE_EFFECTS (_q61)) || (operand_equal_p (_q61, _q60, 0) && types_match (_q61, _q60)))
17087 : : {
17088 : 2 : if ((_q62 == _q22 && ! TREE_SIDE_EFFECTS (_q62)) || (operand_equal_p (_q62, _q22, 0) && types_match (_q62, _q22)))
17089 : : {
17090 : 2 : {
17091 : 2 : tree captures[4] ATTRIBUTE_UNUSED = { _q20, _q22, _q60 };
17092 : 2 : if (VECTOR_INTEGER_TYPE_P (type)
17093 : : )
17094 : : {
17095 : 2 : gimple_seq *lseq = seq;
17096 : 2 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2390;
17097 : 2 : {
17098 : 2 : res_op->set_op (VEC_PERM_EXPR, type, 3);
17099 : 2 : {
17100 : 2 : tree _o1[2], _r1;
17101 : 2 : _o1[0] = captures[0];
17102 : 2 : _o1[1] = captures[2];
17103 : 2 : gimple_match_op tem_op (res_op->cond.any_else (), RSHIFT_EXPR, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
17104 : 2 : tem_op.resimplify (lseq, valueize);
17105 : 2 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
17106 : 2 : if (!_r1) goto next_after_fail2390;
17107 : 1 : captures[3] = _r1;
17108 : : }
17109 : 1 : res_op->ops[0] = captures[3];
17110 : 1 : res_op->ops[1] = captures[3];
17111 : 1 : res_op->ops[2] = captures[1];
17112 : 1 : res_op->resimplify (lseq, valueize);
17113 : 1 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1022, __FILE__, __LINE__, true);
17114 : 1 : return true;
17115 : : }
17116 : : next_after_fail2390:;
17117 : : }
17118 : : }
17119 : : }
17120 : : }
17121 : : break;
17122 : : }
17123 : : default:;
17124 : : }
17125 : : }
17126 : : break;
17127 : : default:;
17128 : : }
17129 : : }
17130 : : break;
17131 : : }
17132 : : default:;
17133 : : }
17134 : : }
17135 : : break;
17136 : : default:;
17137 : : }
17138 : : return false;
17139 : : }
17140 : :
17141 : : bool
17142 : 11 : gimple_simplify_CFN_BUILT_IN_FMAXF16 (gimple_match_op *res_op, gimple_seq *seq,
17143 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
17144 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
17145 : : {
17146 : 11 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
17147 : 11 : if ((_p1 == _p0 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _p0, 0) && types_match (_p1, _p0)))
17148 : : {
17149 : 0 : {
17150 : 0 : tree captures[1] ATTRIBUTE_UNUSED = { _p0 };
17151 : 0 : if (gimple_simplify_601 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_FMAXF16))
17152 : 0 : return true;
17153 : : }
17154 : : }
17155 : 11 : switch (TREE_CODE (_p1))
17156 : : {
17157 : 0 : case REAL_CST:
17158 : 0 : {
17159 : 0 : {
17160 : 0 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17161 : 0 : if (gimple_simplify_602 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_FMAXF16))
17162 : 0 : return true;
17163 : : }
17164 : 0 : break;
17165 : : }
17166 : 11 : default:;
17167 : : }
17168 : 11 : switch (TREE_CODE (_p0))
17169 : : {
17170 : 0 : case REAL_CST:
17171 : 0 : {
17172 : 0 : {
17173 : 0 : tree captures[2] ATTRIBUTE_UNUSED = { _p1, _p0 };
17174 : 0 : if (gimple_simplify_602 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_FMAXF16))
17175 : 0 : return true;
17176 : : }
17177 : 0 : break;
17178 : : }
17179 : 11 : default:;
17180 : : }
17181 : 11 : {
17182 : 11 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17183 : 11 : if (gimple_simplify_604 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_FMAXF16))
17184 : 11 : return true;
17185 : : }
17186 : 0 : switch (TREE_CODE (_p0))
17187 : : {
17188 : 0 : case SSA_NAME:
17189 : 0 : if (gimple *_d1 = get_def (valueize, _p0))
17190 : : {
17191 : 0 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17192 : 0 : switch (gimple_assign_rhs_code (_a1))
17193 : : {
17194 : 0 : case NEGATE_EXPR:
17195 : 0 : {
17196 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
17197 : 0 : _q20 = do_valueize (valueize, _q20);
17198 : 0 : switch (TREE_CODE (_p1))
17199 : : {
17200 : 0 : case SSA_NAME:
17201 : 0 : if (gimple *_d2 = get_def (valueize, _p1))
17202 : : {
17203 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
17204 : 0 : switch (gimple_assign_rhs_code (_a2))
17205 : : {
17206 : 0 : case NEGATE_EXPR:
17207 : 0 : {
17208 : 0 : tree _q40 = gimple_assign_rhs1 (_a2);
17209 : 0 : _q40 = do_valueize (valueize, _q40);
17210 : 0 : {
17211 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _p0, _q20, _p1, _q40 };
17212 : 0 : if (FLOAT_TYPE_P (TREE_TYPE (captures[1]))
17213 : 0 : || (ANY_INTEGRAL_TYPE_P (TREE_TYPE (captures[1]))
17214 : 0 : && TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[1])))
17215 : : )
17216 : : {
17217 : 0 : gimple_seq *lseq = seq;
17218 : 0 : if (lseq
17219 : 0 : && (!single_use (captures[0])
17220 : 0 : || !single_use (captures[2])))
17221 : 0 : lseq = NULL;
17222 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2553;
17223 : 0 : {
17224 : 0 : res_op->set_op (NEGATE_EXPR, type, 1);
17225 : 0 : {
17226 : 0 : tree _o1[2], _r1;
17227 : 0 : _o1[0] = captures[1];
17228 : 0 : _o1[1] = captures[3];
17229 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), CFN_BUILT_IN_FMINF16, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
17230 : 0 : tem_op.resimplify (lseq, valueize);
17231 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
17232 : 0 : if (!_r1) goto next_after_fail2553;
17233 : 0 : res_op->ops[0] = _r1;
17234 : : }
17235 : 0 : res_op->resimplify (lseq, valueize);
17236 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1172, __FILE__, __LINE__, true);
17237 : 0 : return true;
17238 : : }
17239 : 0 : next_after_fail2553:;
17240 : : }
17241 : : }
17242 : 0 : break;
17243 : : }
17244 : : default:;
17245 : : }
17246 : : }
17247 : : break;
17248 : : default:;
17249 : : }
17250 : : break;
17251 : : }
17252 : : default:;
17253 : : }
17254 : : }
17255 : : break;
17256 : : default:;
17257 : : }
17258 : : return false;
17259 : : }
17260 : :
17261 : : bool
17262 : 44 : gimple_simplify_CFN_BUILT_IN_FMAXF128 (gimple_match_op *res_op, gimple_seq *seq,
17263 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
17264 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
17265 : : {
17266 : 44 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
17267 : 44 : if ((_p1 == _p0 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _p0, 0) && types_match (_p1, _p0)))
17268 : : {
17269 : 0 : {
17270 : 0 : tree captures[1] ATTRIBUTE_UNUSED = { _p0 };
17271 : 0 : if (gimple_simplify_601 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_FMAXF128))
17272 : 0 : return true;
17273 : : }
17274 : : }
17275 : 44 : switch (TREE_CODE (_p1))
17276 : : {
17277 : 0 : case REAL_CST:
17278 : 0 : {
17279 : 0 : {
17280 : 0 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17281 : 0 : if (gimple_simplify_602 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_FMAXF128))
17282 : 0 : return true;
17283 : : }
17284 : 0 : break;
17285 : : }
17286 : 44 : default:;
17287 : : }
17288 : 44 : switch (TREE_CODE (_p0))
17289 : : {
17290 : 0 : case REAL_CST:
17291 : 0 : {
17292 : 0 : {
17293 : 0 : tree captures[2] ATTRIBUTE_UNUSED = { _p1, _p0 };
17294 : 0 : if (gimple_simplify_602 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_FMAXF128))
17295 : 0 : return true;
17296 : : }
17297 : 0 : break;
17298 : : }
17299 : 44 : default:;
17300 : : }
17301 : 44 : {
17302 : 44 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17303 : 44 : if (gimple_simplify_604 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_FMAXF128))
17304 : 0 : return true;
17305 : : }
17306 : 44 : switch (TREE_CODE (_p0))
17307 : : {
17308 : 42 : case SSA_NAME:
17309 : 42 : if (gimple *_d1 = get_def (valueize, _p0))
17310 : : {
17311 : 28 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17312 : 44 : switch (gimple_assign_rhs_code (_a1))
17313 : : {
17314 : 0 : case NEGATE_EXPR:
17315 : 0 : {
17316 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
17317 : 0 : _q20 = do_valueize (valueize, _q20);
17318 : 0 : switch (TREE_CODE (_p1))
17319 : : {
17320 : 0 : case SSA_NAME:
17321 : 0 : if (gimple *_d2 = get_def (valueize, _p1))
17322 : : {
17323 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
17324 : 0 : switch (gimple_assign_rhs_code (_a2))
17325 : : {
17326 : 0 : case NEGATE_EXPR:
17327 : 0 : {
17328 : 0 : tree _q40 = gimple_assign_rhs1 (_a2);
17329 : 0 : _q40 = do_valueize (valueize, _q40);
17330 : 0 : {
17331 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _p0, _q20, _p1, _q40 };
17332 : 0 : if (FLOAT_TYPE_P (TREE_TYPE (captures[1]))
17333 : 0 : || (ANY_INTEGRAL_TYPE_P (TREE_TYPE (captures[1]))
17334 : 0 : && TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[1])))
17335 : : )
17336 : : {
17337 : 0 : gimple_seq *lseq = seq;
17338 : 0 : if (lseq
17339 : 0 : && (!single_use (captures[0])
17340 : 0 : || !single_use (captures[2])))
17341 : 0 : lseq = NULL;
17342 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2556;
17343 : 0 : {
17344 : 0 : res_op->set_op (NEGATE_EXPR, type, 1);
17345 : 0 : {
17346 : 0 : tree _o1[2], _r1;
17347 : 0 : _o1[0] = captures[1];
17348 : 0 : _o1[1] = captures[3];
17349 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), CFN_BUILT_IN_FMINF128, TREE_TYPE (_o1[0]), _o1[0], _o1[1]);
17350 : 0 : tem_op.resimplify (lseq, valueize);
17351 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
17352 : 0 : if (!_r1) goto next_after_fail2556;
17353 : 0 : res_op->ops[0] = _r1;
17354 : : }
17355 : 0 : res_op->resimplify (lseq, valueize);
17356 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1172, __FILE__, __LINE__, true);
17357 : 0 : return true;
17358 : : }
17359 : 0 : next_after_fail2556:;
17360 : : }
17361 : : }
17362 : 0 : break;
17363 : : }
17364 : : default:;
17365 : : }
17366 : : }
17367 : : break;
17368 : : default:;
17369 : : }
17370 : : break;
17371 : : }
17372 : : default:;
17373 : : }
17374 : : }
17375 : : break;
17376 : : default:;
17377 : : }
17378 : : return false;
17379 : : }
17380 : :
17381 : : bool
17382 : 183695 : gimple_simplify_COMPLEX_EXPR (gimple_match_op *res_op, gimple_seq *seq,
17383 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
17384 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
17385 : : {
17386 : 183695 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
17387 : 183695 : switch (TREE_CODE (_p0))
17388 : : {
17389 : 177908 : case SSA_NAME:
17390 : 177908 : if (gimple *_d1 = get_def (valueize, _p0))
17391 : : {
17392 : 132387 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17393 : 125651 : switch (gimple_assign_rhs_code (_a1))
17394 : : {
17395 : 4690 : case REALPART_EXPR:
17396 : 4690 : {
17397 : 4690 : tree _q20 = TREE_OPERAND (gimple_assign_rhs1 (_a1), 0);
17398 : 4690 : if ((TREE_CODE (_q20) == SSA_NAME
17399 : 4690 : || is_gimple_min_invariant (_q20)))
17400 : : {
17401 : 3554 : _q20 = do_valueize (valueize, _q20);
17402 : 3554 : switch (TREE_CODE (_p1))
17403 : : {
17404 : 3286 : case SSA_NAME:
17405 : 3286 : if (gimple *_d2 = get_def (valueize, _p1))
17406 : : {
17407 : 3204 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
17408 : 4505 : switch (gimple_assign_rhs_code (_a2))
17409 : : {
17410 : 1653 : case IMAGPART_EXPR:
17411 : 1653 : {
17412 : 1653 : tree _q40 = TREE_OPERAND (gimple_assign_rhs1 (_a2), 0);
17413 : 1653 : if ((TREE_CODE (_q40) == SSA_NAME
17414 : 1653 : || is_gimple_min_invariant (_q40)))
17415 : : {
17416 : 1653 : _q40 = do_valueize (valueize, _q40);
17417 : 1653 : if ((_q40 == _q20 && ! TREE_SIDE_EFFECTS (_q40)) || (operand_equal_p (_q40, _q20, 0) && types_match (_q40, _q20)))
17418 : : {
17419 : 1607 : {
17420 : 1607 : tree captures[1] ATTRIBUTE_UNUSED = { _q20 };
17421 : 1607 : gimple_seq *lseq = seq;
17422 : 1607 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2562;
17423 : 1607 : {
17424 : 1607 : tree tem;
17425 : 1607 : tem = captures[0];
17426 : 1607 : res_op->set_value (tem);
17427 : 1607 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1178, __FILE__, __LINE__, true);
17428 : 1607 : return true;
17429 : : }
17430 : 0 : next_after_fail2562:;
17431 : : }
17432 : : }
17433 : : }
17434 : : break;
17435 : : }
17436 : : default:;
17437 : : }
17438 : : }
17439 : : break;
17440 : : default:;
17441 : : }
17442 : : }
17443 : : break;
17444 : : }
17445 : : default:;
17446 : : }
17447 : : }
17448 : : break;
17449 : : default:;
17450 : : }
17451 : : return false;
17452 : : }
17453 : :
17454 : : bool
17455 : 163832 : gimple_simplify_UNGT_EXPR (gimple_match_op *res_op, gimple_seq *seq,
17456 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
17457 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
17458 : : {
17459 : 163832 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
17460 : 163832 : switch (TREE_CODE (_p0))
17461 : : {
17462 : 163409 : case SSA_NAME:
17463 : 163409 : if (gimple *_d1 = get_def (valueize, _p0))
17464 : : {
17465 : 58847 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17466 : 63649 : switch (gimple_assign_rhs_code (_a1))
17467 : : {
17468 : 0 : case VEC_COND_EXPR:
17469 : 0 : {
17470 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
17471 : 0 : _q20 = do_valueize (valueize, _q20);
17472 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
17473 : 0 : _q21 = do_valueize (valueize, _q21);
17474 : 0 : tree _q22 = gimple_assign_rhs3 (_a1);
17475 : 0 : _q22 = do_valueize (valueize, _q22);
17476 : 0 : switch (TREE_CODE (_p1))
17477 : : {
17478 : 0 : case SSA_NAME:
17479 : 0 : if (gimple *_d2 = get_def (valueize, _p1))
17480 : : {
17481 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
17482 : 0 : switch (gimple_assign_rhs_code (_a2))
17483 : : {
17484 : 0 : case VEC_COND_EXPR:
17485 : 0 : {
17486 : 0 : tree _q60 = gimple_assign_rhs1 (_a2);
17487 : 0 : _q60 = do_valueize (valueize, _q60);
17488 : 0 : tree _q61 = gimple_assign_rhs2 (_a2);
17489 : 0 : _q61 = do_valueize (valueize, _q61);
17490 : 0 : tree _q62 = gimple_assign_rhs3 (_a2);
17491 : 0 : _q62 = do_valueize (valueize, _q62);
17492 : 0 : if ((_q60 == _q20 && ! TREE_SIDE_EFFECTS (_q60)) || (operand_equal_p (_q60, _q20, 0) && types_match (_q60, _q20)))
17493 : : {
17494 : 0 : {
17495 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _q22, _p1, _q61, _q62 };
17496 : 0 : if (VECTOR_TYPE_P (type)
17497 : 0 : && (TREE_CODE_CLASS (UNGT_EXPR) != tcc_comparison
17498 : 0 : || types_match (type, TREE_TYPE (captures[2]))
17499 : 0 : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[1]))
17500 : : || (optimize_vectors_before_lowering_p ()
17501 : 0 : && !expand_vec_cond_expr_p (TREE_TYPE (captures[2]), TREE_TYPE (captures[1]))))
17502 : : )
17503 : : {
17504 : 0 : gimple_seq *lseq = seq;
17505 : 0 : if (lseq
17506 : 0 : && (!single_use (captures[0])
17507 : 0 : || !single_use (captures[4])))
17508 : 0 : lseq = NULL;
17509 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2579;
17510 : 0 : {
17511 : 0 : res_op->set_op (VEC_COND_EXPR, type, 3);
17512 : 0 : res_op->ops[0] = captures[1];
17513 : 0 : {
17514 : 0 : tree _o1[2], _r1;
17515 : 0 : _o1[0] = captures[2];
17516 : 0 : _o1[1] = captures[5];
17517 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), UNGT_EXPR, type, _o1[0], _o1[1]);
17518 : 0 : tem_op.resimplify (NULL, valueize);
17519 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
17520 : 0 : if (!_r1) goto next_after_fail2579;
17521 : 0 : res_op->ops[1] = _r1;
17522 : : }
17523 : 0 : {
17524 : 0 : tree _o1[2], _r1;
17525 : 0 : _o1[0] = captures[3];
17526 : 0 : _o1[1] = captures[6];
17527 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), UNGT_EXPR, type, _o1[0], _o1[1]);
17528 : 0 : tem_op.resimplify (NULL, valueize);
17529 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
17530 : 0 : if (!_r1) goto next_after_fail2579;
17531 : 0 : res_op->ops[2] = _r1;
17532 : : }
17533 : 0 : res_op->resimplify (lseq, valueize);
17534 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1019, __FILE__, __LINE__, true);
17535 : 0 : return true;
17536 : : }
17537 : 0 : next_after_fail2579:;
17538 : : }
17539 : : }
17540 : : }
17541 : : break;
17542 : : }
17543 : : default:;
17544 : : }
17545 : : }
17546 : : break;
17547 : 0 : default:;
17548 : : }
17549 : 0 : {
17550 : 0 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _q22, _p1 };
17551 : 0 : if (VECTOR_TYPE_P (type)
17552 : 0 : && (TREE_CODE_CLASS (UNGT_EXPR) != tcc_comparison
17553 : 0 : || types_match (type, TREE_TYPE (captures[2]))
17554 : 0 : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[1]))
17555 : : || (optimize_vectors_before_lowering_p ()
17556 : 0 : && !expand_vec_cond_expr_p (TREE_TYPE (captures[2]), TREE_TYPE (captures[1]))))
17557 : : )
17558 : : {
17559 : 0 : gimple_seq *lseq = seq;
17560 : 0 : if (lseq
17561 : 0 : && (!single_use (captures[0])))
17562 : 0 : lseq = NULL;
17563 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2580;
17564 : 0 : {
17565 : 0 : res_op->set_op (VEC_COND_EXPR, type, 3);
17566 : 0 : res_op->ops[0] = captures[1];
17567 : 0 : {
17568 : 0 : tree _o1[2], _r1;
17569 : 0 : _o1[0] = captures[2];
17570 : 0 : _o1[1] = captures[4];
17571 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), UNGT_EXPR, type, _o1[0], _o1[1]);
17572 : 0 : tem_op.resimplify (NULL, valueize);
17573 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
17574 : 0 : if (!_r1) goto next_after_fail2580;
17575 : 0 : res_op->ops[1] = _r1;
17576 : : }
17577 : 0 : {
17578 : 0 : tree _o1[2], _r1;
17579 : 0 : _o1[0] = captures[3];
17580 : 0 : _o1[1] = captures[4];
17581 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), UNGT_EXPR, type, _o1[0], _o1[1]);
17582 : 0 : tem_op.resimplify (NULL, valueize);
17583 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
17584 : 0 : if (!_r1) goto next_after_fail2580;
17585 : 0 : res_op->ops[2] = _r1;
17586 : : }
17587 : 0 : res_op->resimplify (lseq, valueize);
17588 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1020, __FILE__, __LINE__, true);
17589 : 0 : return true;
17590 : : }
17591 : 0 : next_after_fail2580:;
17592 : : }
17593 : : }
17594 : 0 : break;
17595 : : }
17596 : : default:;
17597 : : }
17598 : : }
17599 : : break;
17600 : 163832 : default:;
17601 : : }
17602 : 163832 : switch (TREE_CODE (_p1))
17603 : : {
17604 : 13424 : case SSA_NAME:
17605 : 13424 : if (gimple *_d1 = get_def (valueize, _p1))
17606 : : {
17607 : 7634 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17608 : 10702 : switch (gimple_assign_rhs_code (_a1))
17609 : : {
17610 : 0 : case VEC_COND_EXPR:
17611 : 0 : {
17612 : 0 : tree _q30 = gimple_assign_rhs1 (_a1);
17613 : 0 : _q30 = do_valueize (valueize, _q30);
17614 : 0 : tree _q31 = gimple_assign_rhs2 (_a1);
17615 : 0 : _q31 = do_valueize (valueize, _q31);
17616 : 0 : tree _q32 = gimple_assign_rhs3 (_a1);
17617 : 0 : _q32 = do_valueize (valueize, _q32);
17618 : 0 : {
17619 : 0 : tree captures[5] ATTRIBUTE_UNUSED = { _p0, _p1, _q30, _q31, _q32 };
17620 : 0 : if (VECTOR_TYPE_P (type)
17621 : 0 : && (TREE_CODE_CLASS (UNGT_EXPR) != tcc_comparison
17622 : 0 : || types_match (type, TREE_TYPE (captures[3]))
17623 : 0 : || expand_vec_cond_expr_p (type, TREE_TYPE (captures[2]))
17624 : : || (optimize_vectors_before_lowering_p ()
17625 : 0 : && !expand_vec_cond_expr_p (TREE_TYPE (captures[3]), TREE_TYPE (captures[2]))))
17626 : : )
17627 : : {
17628 : 0 : gimple_seq *lseq = seq;
17629 : 0 : if (lseq
17630 : 0 : && (!single_use (captures[1])))
17631 : 0 : lseq = NULL;
17632 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2581;
17633 : 0 : {
17634 : 0 : res_op->set_op (VEC_COND_EXPR, type, 3);
17635 : 0 : res_op->ops[0] = captures[2];
17636 : 0 : {
17637 : 0 : tree _o1[2], _r1;
17638 : 0 : _o1[0] = captures[0];
17639 : 0 : _o1[1] = captures[3];
17640 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), UNGT_EXPR, type, _o1[0], _o1[1]);
17641 : 0 : tem_op.resimplify (NULL, valueize);
17642 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
17643 : 0 : if (!_r1) goto next_after_fail2581;
17644 : 0 : res_op->ops[1] = _r1;
17645 : : }
17646 : 0 : {
17647 : 0 : tree _o1[2], _r1;
17648 : 0 : _o1[0] = captures[0];
17649 : 0 : _o1[1] = captures[4];
17650 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), UNGT_EXPR, type, _o1[0], _o1[1]);
17651 : 0 : tem_op.resimplify (NULL, valueize);
17652 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, NULL);
17653 : 0 : if (!_r1) goto next_after_fail2581;
17654 : 0 : res_op->ops[2] = _r1;
17655 : : }
17656 : 0 : res_op->resimplify (lseq, valueize);
17657 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1021, __FILE__, __LINE__, true);
17658 : 0 : return true;
17659 : : }
17660 : 0 : next_after_fail2581:;
17661 : : }
17662 : : }
17663 : 0 : break;
17664 : : }
17665 : : default:;
17666 : : }
17667 : : }
17668 : : break;
17669 : 163832 : default:;
17670 : : }
17671 : 163832 : if ((_p1 == _p0 && ! TREE_SIDE_EFFECTS (_p1)) || (operand_equal_p (_p1, _p0, 0) && types_match (_p1, _p0)))
17672 : : {
17673 : 5 : {
17674 : 5 : tree captures[1] ATTRIBUTE_UNUSED = { _p0 };
17675 : 5 : if (gimple_simplify_633 (res_op, seq, valueize, type, captures, UNGT_EXPR))
17676 : 5 : return true;
17677 : : }
17678 : : }
17679 : 163827 : switch (TREE_CODE (_p0))
17680 : : {
17681 : 163404 : case SSA_NAME:
17682 : 163404 : if (gimple *_d1 = get_def (valueize, _p0))
17683 : : {
17684 : 58846 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17685 : 63649 : switch (gimple_assign_rhs_code (_a1))
17686 : : {
17687 : 772 : case FLOAT_EXPR:
17688 : 772 : {
17689 : 772 : tree _q20 = gimple_assign_rhs1 (_a1);
17690 : 772 : _q20 = do_valueize (valueize, _q20);
17691 : 772 : switch (TREE_CODE (_p1))
17692 : : {
17693 : 0 : case SSA_NAME:
17694 : 0 : if (gimple *_d2 = get_def (valueize, _p1))
17695 : : {
17696 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
17697 : 0 : switch (gimple_assign_rhs_code (_a2))
17698 : : {
17699 : 0 : case FLOAT_EXPR:
17700 : 0 : {
17701 : 0 : tree _q40 = gimple_assign_rhs1 (_a2);
17702 : 0 : _q40 = do_valueize (valueize, _q40);
17703 : 0 : {
17704 : 0 : tree captures[3] ATTRIBUTE_UNUSED = { _p0, _q20, _q40 };
17705 : 0 : if (gimple_simplify_274 (res_op, seq, valueize, type, captures, UNGT_EXPR, GT_EXPR))
17706 : 0 : return true;
17707 : : }
17708 : 0 : break;
17709 : : }
17710 : : default:;
17711 : : }
17712 : : }
17713 : : break;
17714 : : default:;
17715 : : }
17716 : : break;
17717 : : }
17718 : 30 : case NEGATE_EXPR:
17719 : 30 : {
17720 : 30 : tree _q20 = gimple_assign_rhs1 (_a1);
17721 : 30 : _q20 = do_valueize (valueize, _q20);
17722 : 30 : switch (TREE_CODE (_p1))
17723 : : {
17724 : 30 : case SSA_NAME:
17725 : 30 : if (gimple *_d2 = get_def (valueize, _p1))
17726 : : {
17727 : 30 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
17728 : 30 : switch (gimple_assign_rhs_code (_a2))
17729 : : {
17730 : 30 : case NEGATE_EXPR:
17731 : 30 : {
17732 : 30 : tree _q40 = gimple_assign_rhs1 (_a2);
17733 : 30 : _q40 = do_valueize (valueize, _q40);
17734 : 30 : {
17735 : 30 : tree captures[2] ATTRIBUTE_UNUSED = { _q20, _q40 };
17736 : 30 : if (gimple_simplify_277 (res_op, seq, valueize, type, captures, UNGT_EXPR, UNLT_EXPR))
17737 : 30 : return true;
17738 : : }
17739 : 0 : break;
17740 : : }
17741 : : default:;
17742 : : }
17743 : : }
17744 : : break;
17745 : 0 : default:;
17746 : : }
17747 : 0 : if (CONSTANT_CLASS_P (_p1))
17748 : : {
17749 : 0 : {
17750 : 0 : tree captures[2] ATTRIBUTE_UNUSED = { _q20, _p1 };
17751 : 0 : if (gimple_simplify_278 (res_op, seq, valueize, type, captures, UNGT_EXPR, UNLT_EXPR))
17752 : 0 : return true;
17753 : : }
17754 : : }
17755 : : break;
17756 : : }
17757 : : default:;
17758 : : }
17759 : : }
17760 : : break;
17761 : 163797 : default:;
17762 : : }
17763 : 163797 : switch (TREE_CODE (_p1))
17764 : : {
17765 : 150106 : case REAL_CST:
17766 : 150106 : {
17767 : 150106 : {
17768 : 150106 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17769 : 150106 : if (gimple_simplify_632 (res_op, seq, valueize, type, captures, UNGT_EXPR))
17770 : 0 : return true;
17771 : : }
17772 : 150106 : break;
17773 : : }
17774 : : default:;
17775 : : }
17776 : : return false;
17777 : : }
17778 : :
17779 : : bool
17780 : 11 : gimple_simplify_CFN_BUILT_IN_POWF16 (gimple_match_op *res_op, gimple_seq *seq,
17781 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
17782 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
17783 : : {
17784 : 11 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
17785 : 11 : switch (TREE_CODE (_p0))
17786 : : {
17787 : 8 : case SSA_NAME:
17788 : 8 : if (gimple *_d1 = get_def (valueize, _p0))
17789 : : {
17790 : 6 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17791 : 2 : switch (gimple_assign_rhs_code (_a1))
17792 : : {
17793 : 2 : case RDIV_EXPR:
17794 : 2 : {
17795 : 2 : tree _q20 = gimple_assign_rhs1 (_a1);
17796 : 2 : _q20 = do_valueize (valueize, _q20);
17797 : 2 : tree _q21 = gimple_assign_rhs2 (_a1);
17798 : 2 : _q21 = do_valueize (valueize, _q21);
17799 : 2 : if (real_onep (_q20))
17800 : : {
17801 : 2 : {
17802 : 2 : tree captures[4] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _p1 };
17803 : 2 : if (gimple_simplify_426 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_POWF16))
17804 : 1 : return true;
17805 : : }
17806 : : }
17807 : : break;
17808 : : }
17809 : : default:;
17810 : : }
17811 : : }
17812 : : break;
17813 : 10 : default:;
17814 : : }
17815 : 10 : if (real_zerop (_p0))
17816 : : {
17817 : 1 : {
17818 : 1 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17819 : 1 : if (gimple_simplify_427 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_POWF16))
17820 : 1 : return true;
17821 : : }
17822 : : }
17823 : : return false;
17824 : : }
17825 : :
17826 : : bool
17827 : 0 : gimple_simplify_CFN_BUILT_IN_POWF64X (gimple_match_op *res_op, gimple_seq *seq,
17828 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
17829 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
17830 : : {
17831 : 0 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
17832 : 0 : switch (TREE_CODE (_p0))
17833 : : {
17834 : 0 : case SSA_NAME:
17835 : 0 : if (gimple *_d1 = get_def (valueize, _p0))
17836 : : {
17837 : 0 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17838 : 0 : switch (gimple_assign_rhs_code (_a1))
17839 : : {
17840 : 0 : case RDIV_EXPR:
17841 : 0 : {
17842 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
17843 : 0 : _q20 = do_valueize (valueize, _q20);
17844 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
17845 : 0 : _q21 = do_valueize (valueize, _q21);
17846 : 0 : if (real_onep (_q20))
17847 : : {
17848 : 0 : {
17849 : 0 : tree captures[4] ATTRIBUTE_UNUSED = { _p0, _q20, _q21, _p1 };
17850 : 0 : if (gimple_simplify_426 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_POWF64X))
17851 : 0 : return true;
17852 : : }
17853 : : }
17854 : : break;
17855 : : }
17856 : : default:;
17857 : : }
17858 : : }
17859 : : break;
17860 : 0 : default:;
17861 : : }
17862 : 0 : if (real_zerop (_p0))
17863 : : {
17864 : 0 : {
17865 : 0 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17866 : 0 : if (gimple_simplify_427 (res_op, seq, valueize, type, captures, CFN_BUILT_IN_POWF64X))
17867 : 0 : return true;
17868 : : }
17869 : : }
17870 : : return false;
17871 : : }
17872 : :
17873 : : bool
17874 : 4597 : gimple_simplify_CFN_BUILT_IN_SCALBNF (gimple_match_op *res_op, gimple_seq *seq,
17875 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
17876 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
17877 : : {
17878 : 4597 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
17879 : 4597 : if (real_zerop (_p0))
17880 : : {
17881 : 28 : {
17882 : 28 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17883 : 28 : if (gimple_simplify_648 (res_op, seq, valueize, type, captures))
17884 : 28 : return true;
17885 : : }
17886 : : }
17887 : 4569 : if (integer_zerop (_p1))
17888 : : {
17889 : 7 : {
17890 : 7 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17891 : 7 : if (gimple_simplify_649 (res_op, seq, valueize, type, captures))
17892 : 7 : return true;
17893 : : }
17894 : : }
17895 : 4562 : switch (TREE_CODE (_p0))
17896 : : {
17897 : 2348 : case REAL_CST:
17898 : 2348 : {
17899 : 2348 : {
17900 : 2348 : tree captures[2] ATTRIBUTE_UNUSED = { _p0, _p1 };
17901 : 2348 : if (!real_isfinite (TREE_REAL_CST_PTR (captures[0]))
17902 : : )
17903 : : {
17904 : 71 : gimple_seq *lseq = seq;
17905 : 71 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2596;
17906 : 71 : {
17907 : 71 : tree tem;
17908 : 71 : tem = captures[0];
17909 : 71 : res_op->set_value (tem);
17910 : 71 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1184, __FILE__, __LINE__, true);
17911 : 71 : return true;
17912 : : }
17913 : 0 : next_after_fail2596:;
17914 : : }
17915 : : }
17916 : 2277 : break;
17917 : : }
17918 : : default:;
17919 : : }
17920 : : return false;
17921 : : }
17922 : :
17923 : : bool
17924 : 0 : gimple_simplify_TRUTH_ORIF_EXPR (gimple_match_op *res_op, gimple_seq *seq,
17925 : : tree (*valueize)(tree) ATTRIBUTE_UNUSED,
17926 : : code_helper ARG_UNUSED (code), tree ARG_UNUSED (type), tree _p0, tree _p1)
17927 : : {
17928 : 0 : const bool debug_dump = dump_file && (dump_flags & TDF_FOLDING);
17929 : 0 : switch (TREE_CODE (_p0))
17930 : : {
17931 : 0 : case SSA_NAME:
17932 : 0 : if (gimple *_d1 = get_def (valueize, _p0))
17933 : : {
17934 : 0 : if (gassign *_a1 = dyn_cast <gassign *> (_d1))
17935 : 0 : switch (gimple_assign_rhs_code (_a1))
17936 : : {
17937 : 0 : case LE_EXPR:
17938 : 0 : {
17939 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
17940 : 0 : _q20 = do_valueize (valueize, _q20);
17941 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
17942 : 0 : _q21 = do_valueize (valueize, _q21);
17943 : 0 : switch (TREE_CODE (_q20))
17944 : : {
17945 : 0 : case SSA_NAME:
17946 : 0 : if (gimple *_d2 = get_def (valueize, _q20))
17947 : : {
17948 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
17949 : 0 : switch (gimple_assign_rhs_code (_a2))
17950 : : {
17951 : 0 : case POINTER_PLUS_EXPR:
17952 : 0 : {
17953 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
17954 : 0 : _q30 = do_valueize (valueize, _q30);
17955 : 0 : tree _q31 = gimple_assign_rhs2 (_a2);
17956 : 0 : _q31 = do_valueize (valueize, _q31);
17957 : 0 : switch (TREE_CODE (_q31))
17958 : : {
17959 : 0 : case INTEGER_CST:
17960 : 0 : {
17961 : 0 : switch (TREE_CODE (_p1))
17962 : : {
17963 : 0 : case SSA_NAME:
17964 : 0 : if (gimple *_d3 = get_def (valueize, _p1))
17965 : : {
17966 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
17967 : 0 : switch (gimple_assign_rhs_code (_a3))
17968 : : {
17969 : 0 : case LE_EXPR:
17970 : 0 : {
17971 : 0 : tree _q70 = gimple_assign_rhs1 (_a3);
17972 : 0 : _q70 = do_valueize (valueize, _q70);
17973 : 0 : tree _q71 = gimple_assign_rhs2 (_a3);
17974 : 0 : _q71 = do_valueize (valueize, _q71);
17975 : 0 : switch (TREE_CODE (_q70))
17976 : : {
17977 : 0 : case SSA_NAME:
17978 : 0 : if (gimple *_d4 = get_def (valueize, _q70))
17979 : : {
17980 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
17981 : 0 : switch (gimple_assign_rhs_code (_a4))
17982 : : {
17983 : 0 : case POINTER_PLUS_EXPR:
17984 : 0 : {
17985 : 0 : tree _q80 = gimple_assign_rhs1 (_a4);
17986 : 0 : _q80 = do_valueize (valueize, _q80);
17987 : 0 : tree _q81 = gimple_assign_rhs2 (_a4);
17988 : 0 : _q81 = do_valueize (valueize, _q81);
17989 : 0 : if ((_q80 == _q21 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q21, 0) && types_match (_q80, _q21)))
17990 : : {
17991 : 0 : if ((_q81 == _q31 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q31, 0) && types_match (_q81, _q31)))
17992 : : {
17993 : 0 : if ((_q71 == _q30 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q30, 0) && types_match (_q71, _q30)))
17994 : : {
17995 : 0 : {
17996 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q20, _q30, _q31, _q21, _p1, _q70 };
17997 : 0 : const enum tree_code cmp = LE_EXPR;
17998 : 0 : if (TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[2]))
17999 : 0 : && TYPE_OVERFLOW_WRAPS (sizetype)
18000 : 0 : && TYPE_PRECISION (TREE_TYPE (captures[2])) == TYPE_PRECISION (sizetype)
18001 : : )
18002 : : {
18003 : 0 : {
18004 : 0 : offset_int off = wi::to_offset (captures[3]) - (cmp == LE_EXPR ? 1 : 0);
18005 : 0 : offset_int rhs = off * 2;
18006 : 0 : if (wi::min_precision (rhs, UNSIGNED) <= TYPE_PRECISION (sizetype)
18007 : : )
18008 : : {
18009 : 0 : {
18010 : 0 : bool swap_p = tree_swap_operands_p (captures[2], captures[4]);
18011 : 0 : tree rhs_tree = wide_int_to_tree (sizetype, rhs);
18012 : 0 : if (cmp == LT_EXPR
18013 : : )
18014 : : {
18015 : : gimple_seq *lseq = seq;
18016 : : if (lseq
18017 : : && (!single_use (captures[0])
18018 : : || !single_use (captures[5])))
18019 : : lseq = NULL;
18020 : : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2602;
18021 : : {
18022 : : res_op->set_op (GT_EXPR, type, 2);
18023 : : {
18024 : : tree _o1[1], _r1;
18025 : : {
18026 : : tree _o2[2], _r2;
18027 : : _o2[0] = swap_p ? captures[6] : captures[1];
18028 : : _o2[1] = swap_p ? captures[2] : captures[4];
18029 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18030 : : tem_op.resimplify (lseq, valueize);
18031 : : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18032 : : if (!_r2) goto next_after_fail2602;
18033 : : _o1[0] = _r2;
18034 : : }
18035 : : if (sizetype != TREE_TYPE (_o1[0])
18036 : : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18037 : : {
18038 : : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18039 : : tem_op.resimplify (lseq, valueize);
18040 : : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18041 : : if (!_r1) goto next_after_fail2602;
18042 : : }
18043 : : else
18044 : : _r1 = _o1[0];
18045 : : res_op->ops[0] = _r1;
18046 : : }
18047 : : res_op->ops[1] = rhs_tree;
18048 : : res_op->resimplify (lseq, valueize);
18049 : : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1067, __FILE__, __LINE__, true);
18050 : 0 : return true;
18051 : : }
18052 : : next_after_fail2602:;
18053 : : }
18054 : : else
18055 : : {
18056 : 0 : gimple_seq *lseq = seq;
18057 : 0 : if (lseq
18058 : 0 : && (!single_use (captures[0])
18059 : 0 : || !single_use (captures[5])))
18060 : 0 : lseq = NULL;
18061 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2603;
18062 : 0 : {
18063 : 0 : res_op->set_op (GT_EXPR, type, 2);
18064 : 0 : {
18065 : 0 : tree _o1[1], _r1;
18066 : 0 : {
18067 : 0 : tree _o2[2], _r2;
18068 : 0 : {
18069 : 0 : tree _o3[2], _r3;
18070 : 0 : _o3[0] = swap_p ? captures[4] : captures[2];
18071 : 0 : _o3[1] = wide_int_to_tree (sizetype, off);
18072 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_PLUS_EXPR, TREE_TYPE (_o3[0]), _o3[0], _o3[1]);
18073 : 0 : tem_op.resimplify (lseq, valueize);
18074 : 0 : _r3 = maybe_push_res_to_seq (&tem_op, lseq);
18075 : 0 : if (!_r3) goto next_after_fail2603;
18076 : 0 : _o2[0] = _r3;
18077 : : }
18078 : 0 : _o2[1] = swap_p ? captures[2] : captures[4];
18079 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18080 : 0 : tem_op.resimplify (lseq, valueize);
18081 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18082 : 0 : if (!_r2) goto next_after_fail2603;
18083 : 0 : _o1[0] = _r2;
18084 : : }
18085 : 0 : if (sizetype != TREE_TYPE (_o1[0])
18086 : 0 : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18087 : : {
18088 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18089 : 0 : tem_op.resimplify (lseq, valueize);
18090 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18091 : 0 : if (!_r1) goto next_after_fail2603;
18092 : : }
18093 : : else
18094 : : _r1 = _o1[0];
18095 : 0 : res_op->ops[0] = _r1;
18096 : : }
18097 : 0 : res_op->ops[1] = rhs_tree;
18098 : 0 : res_op->resimplify (lseq, valueize);
18099 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1068, __FILE__, __LINE__, true);
18100 : 0 : return true;
18101 : : }
18102 : 0 : next_after_fail2603:;
18103 : : }
18104 : : }
18105 : : }
18106 : : }
18107 : : }
18108 : : }
18109 : : }
18110 : : }
18111 : : }
18112 : : break;
18113 : : }
18114 : : default:;
18115 : : }
18116 : : }
18117 : : break;
18118 : : default:;
18119 : : }
18120 : : break;
18121 : : }
18122 : 0 : case GE_EXPR:
18123 : 0 : {
18124 : 0 : tree _q70 = gimple_assign_rhs1 (_a3);
18125 : 0 : _q70 = do_valueize (valueize, _q70);
18126 : 0 : tree _q71 = gimple_assign_rhs2 (_a3);
18127 : 0 : _q71 = do_valueize (valueize, _q71);
18128 : 0 : if ((_q70 == _q30 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q30, 0) && types_match (_q70, _q30)))
18129 : : {
18130 : 0 : switch (TREE_CODE (_q71))
18131 : : {
18132 : 0 : case SSA_NAME:
18133 : 0 : if (gimple *_d4 = get_def (valueize, _q71))
18134 : : {
18135 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
18136 : 0 : switch (gimple_assign_rhs_code (_a4))
18137 : : {
18138 : 0 : case POINTER_PLUS_EXPR:
18139 : 0 : {
18140 : 0 : tree _q90 = gimple_assign_rhs1 (_a4);
18141 : 0 : _q90 = do_valueize (valueize, _q90);
18142 : 0 : tree _q91 = gimple_assign_rhs2 (_a4);
18143 : 0 : _q91 = do_valueize (valueize, _q91);
18144 : 0 : if ((_q90 == _q21 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q21, 0) && types_match (_q90, _q21)))
18145 : : {
18146 : 0 : if ((_q91 == _q31 && ! TREE_SIDE_EFFECTS (_q91)) || (operand_equal_p (_q91, _q31, 0) && types_match (_q91, _q31)))
18147 : : {
18148 : 0 : {
18149 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q20, _q30, _q31, _q21, _p1, _q71 };
18150 : 0 : const enum tree_code cmp = LE_EXPR;
18151 : 0 : if (TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[2]))
18152 : 0 : && TYPE_OVERFLOW_WRAPS (sizetype)
18153 : 0 : && TYPE_PRECISION (TREE_TYPE (captures[2])) == TYPE_PRECISION (sizetype)
18154 : : )
18155 : : {
18156 : 0 : {
18157 : 0 : offset_int off = wi::to_offset (captures[3]) - (cmp == LE_EXPR ? 1 : 0);
18158 : 0 : offset_int rhs = off * 2;
18159 : 0 : if (wi::min_precision (rhs, UNSIGNED) <= TYPE_PRECISION (sizetype)
18160 : : )
18161 : : {
18162 : 0 : {
18163 : 0 : bool swap_p = tree_swap_operands_p (captures[2], captures[4]);
18164 : 0 : tree rhs_tree = wide_int_to_tree (sizetype, rhs);
18165 : 0 : if (cmp == LT_EXPR
18166 : : )
18167 : : {
18168 : : gimple_seq *lseq = seq;
18169 : : if (lseq
18170 : : && (!single_use (captures[0])
18171 : : || !single_use (captures[5])))
18172 : : lseq = NULL;
18173 : : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2604;
18174 : : {
18175 : : res_op->set_op (GT_EXPR, type, 2);
18176 : : {
18177 : : tree _o1[1], _r1;
18178 : : {
18179 : : tree _o2[2], _r2;
18180 : : _o2[0] = swap_p ? captures[6] : captures[1];
18181 : : _o2[1] = swap_p ? captures[2] : captures[4];
18182 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18183 : : tem_op.resimplify (lseq, valueize);
18184 : : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18185 : : if (!_r2) goto next_after_fail2604;
18186 : : _o1[0] = _r2;
18187 : : }
18188 : : if (sizetype != TREE_TYPE (_o1[0])
18189 : : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18190 : : {
18191 : : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18192 : : tem_op.resimplify (lseq, valueize);
18193 : : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18194 : : if (!_r1) goto next_after_fail2604;
18195 : : }
18196 : : else
18197 : : _r1 = _o1[0];
18198 : : res_op->ops[0] = _r1;
18199 : : }
18200 : : res_op->ops[1] = rhs_tree;
18201 : : res_op->resimplify (lseq, valueize);
18202 : : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1067, __FILE__, __LINE__, true);
18203 : 0 : return true;
18204 : : }
18205 : : next_after_fail2604:;
18206 : : }
18207 : : else
18208 : : {
18209 : 0 : gimple_seq *lseq = seq;
18210 : 0 : if (lseq
18211 : 0 : && (!single_use (captures[0])
18212 : 0 : || !single_use (captures[5])))
18213 : 0 : lseq = NULL;
18214 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2605;
18215 : 0 : {
18216 : 0 : res_op->set_op (GT_EXPR, type, 2);
18217 : 0 : {
18218 : 0 : tree _o1[1], _r1;
18219 : 0 : {
18220 : 0 : tree _o2[2], _r2;
18221 : 0 : {
18222 : 0 : tree _o3[2], _r3;
18223 : 0 : _o3[0] = swap_p ? captures[4] : captures[2];
18224 : 0 : _o3[1] = wide_int_to_tree (sizetype, off);
18225 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_PLUS_EXPR, TREE_TYPE (_o3[0]), _o3[0], _o3[1]);
18226 : 0 : tem_op.resimplify (lseq, valueize);
18227 : 0 : _r3 = maybe_push_res_to_seq (&tem_op, lseq);
18228 : 0 : if (!_r3) goto next_after_fail2605;
18229 : 0 : _o2[0] = _r3;
18230 : : }
18231 : 0 : _o2[1] = swap_p ? captures[2] : captures[4];
18232 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18233 : 0 : tem_op.resimplify (lseq, valueize);
18234 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18235 : 0 : if (!_r2) goto next_after_fail2605;
18236 : 0 : _o1[0] = _r2;
18237 : : }
18238 : 0 : if (sizetype != TREE_TYPE (_o1[0])
18239 : 0 : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18240 : : {
18241 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18242 : 0 : tem_op.resimplify (lseq, valueize);
18243 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18244 : 0 : if (!_r1) goto next_after_fail2605;
18245 : : }
18246 : : else
18247 : : _r1 = _o1[0];
18248 : 0 : res_op->ops[0] = _r1;
18249 : : }
18250 : 0 : res_op->ops[1] = rhs_tree;
18251 : 0 : res_op->resimplify (lseq, valueize);
18252 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1068, __FILE__, __LINE__, true);
18253 : 0 : return true;
18254 : : }
18255 : 0 : next_after_fail2605:;
18256 : : }
18257 : : }
18258 : : }
18259 : : }
18260 : : }
18261 : : }
18262 : : }
18263 : : }
18264 : : break;
18265 : : }
18266 : : default:;
18267 : : }
18268 : : }
18269 : : break;
18270 : : default:;
18271 : : }
18272 : : }
18273 : : break;
18274 : : }
18275 : : default:;
18276 : : }
18277 : : }
18278 : : break;
18279 : : default:;
18280 : : }
18281 : : break;
18282 : : }
18283 : : default:;
18284 : : }
18285 : : break;
18286 : : }
18287 : : default:;
18288 : : }
18289 : : }
18290 : : break;
18291 : : default:;
18292 : : }
18293 : : break;
18294 : : }
18295 : 0 : case LT_EXPR:
18296 : 0 : {
18297 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
18298 : 0 : _q20 = do_valueize (valueize, _q20);
18299 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
18300 : 0 : _q21 = do_valueize (valueize, _q21);
18301 : 0 : switch (TREE_CODE (_q20))
18302 : : {
18303 : 0 : case SSA_NAME:
18304 : 0 : if (gimple *_d2 = get_def (valueize, _q20))
18305 : : {
18306 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
18307 : 0 : switch (gimple_assign_rhs_code (_a2))
18308 : : {
18309 : 0 : case POINTER_PLUS_EXPR:
18310 : 0 : {
18311 : 0 : tree _q30 = gimple_assign_rhs1 (_a2);
18312 : 0 : _q30 = do_valueize (valueize, _q30);
18313 : 0 : tree _q31 = gimple_assign_rhs2 (_a2);
18314 : 0 : _q31 = do_valueize (valueize, _q31);
18315 : 0 : switch (TREE_CODE (_q31))
18316 : : {
18317 : 0 : case INTEGER_CST:
18318 : 0 : {
18319 : 0 : switch (TREE_CODE (_p1))
18320 : : {
18321 : 0 : case SSA_NAME:
18322 : 0 : if (gimple *_d3 = get_def (valueize, _p1))
18323 : : {
18324 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
18325 : 0 : switch (gimple_assign_rhs_code (_a3))
18326 : : {
18327 : 0 : case LT_EXPR:
18328 : 0 : {
18329 : 0 : tree _q70 = gimple_assign_rhs1 (_a3);
18330 : 0 : _q70 = do_valueize (valueize, _q70);
18331 : 0 : tree _q71 = gimple_assign_rhs2 (_a3);
18332 : 0 : _q71 = do_valueize (valueize, _q71);
18333 : 0 : switch (TREE_CODE (_q70))
18334 : : {
18335 : 0 : case SSA_NAME:
18336 : 0 : if (gimple *_d4 = get_def (valueize, _q70))
18337 : : {
18338 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
18339 : 0 : switch (gimple_assign_rhs_code (_a4))
18340 : : {
18341 : 0 : case POINTER_PLUS_EXPR:
18342 : 0 : {
18343 : 0 : tree _q80 = gimple_assign_rhs1 (_a4);
18344 : 0 : _q80 = do_valueize (valueize, _q80);
18345 : 0 : tree _q81 = gimple_assign_rhs2 (_a4);
18346 : 0 : _q81 = do_valueize (valueize, _q81);
18347 : 0 : if ((_q80 == _q21 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q21, 0) && types_match (_q80, _q21)))
18348 : : {
18349 : 0 : if ((_q81 == _q31 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q31, 0) && types_match (_q81, _q31)))
18350 : : {
18351 : 0 : if ((_q71 == _q30 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q30, 0) && types_match (_q71, _q30)))
18352 : : {
18353 : 0 : {
18354 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q20, _q30, _q31, _q21, _p1, _q70 };
18355 : 0 : const enum tree_code cmp = LT_EXPR;
18356 : 0 : if (TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[2]))
18357 : 0 : && TYPE_OVERFLOW_WRAPS (sizetype)
18358 : 0 : && TYPE_PRECISION (TREE_TYPE (captures[2])) == TYPE_PRECISION (sizetype)
18359 : : )
18360 : : {
18361 : 0 : {
18362 : 0 : offset_int off = wi::to_offset (captures[3]) - (cmp == LE_EXPR ? 1 : 0);
18363 : 0 : offset_int rhs = off * 2;
18364 : 0 : if (wi::min_precision (rhs, UNSIGNED) <= TYPE_PRECISION (sizetype)
18365 : : )
18366 : : {
18367 : 0 : {
18368 : 0 : bool swap_p = tree_swap_operands_p (captures[2], captures[4]);
18369 : 0 : tree rhs_tree = wide_int_to_tree (sizetype, rhs);
18370 : 0 : if (cmp == LT_EXPR
18371 : : )
18372 : : {
18373 : 0 : gimple_seq *lseq = seq;
18374 : 0 : if (lseq
18375 : 0 : && (!single_use (captures[0])
18376 : 0 : || !single_use (captures[5])))
18377 : 0 : lseq = NULL;
18378 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2606;
18379 : 0 : {
18380 : 0 : res_op->set_op (GT_EXPR, type, 2);
18381 : 0 : {
18382 : 0 : tree _o1[1], _r1;
18383 : 0 : {
18384 : 0 : tree _o2[2], _r2;
18385 : 0 : _o2[0] = swap_p ? captures[6] : captures[1];
18386 : 0 : _o2[1] = swap_p ? captures[2] : captures[4];
18387 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18388 : 0 : tem_op.resimplify (lseq, valueize);
18389 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18390 : 0 : if (!_r2) goto next_after_fail2606;
18391 : 0 : _o1[0] = _r2;
18392 : : }
18393 : 0 : if (sizetype != TREE_TYPE (_o1[0])
18394 : 0 : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18395 : : {
18396 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18397 : 0 : tem_op.resimplify (lseq, valueize);
18398 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18399 : 0 : if (!_r1) goto next_after_fail2606;
18400 : : }
18401 : : else
18402 : : _r1 = _o1[0];
18403 : 0 : res_op->ops[0] = _r1;
18404 : : }
18405 : 0 : res_op->ops[1] = rhs_tree;
18406 : 0 : res_op->resimplify (lseq, valueize);
18407 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1067, __FILE__, __LINE__, true);
18408 : 0 : return true;
18409 : : }
18410 : 0 : next_after_fail2606:;
18411 : : }
18412 : : else
18413 : : {
18414 : : gimple_seq *lseq = seq;
18415 : : if (lseq
18416 : : && (!single_use (captures[0])
18417 : : || !single_use (captures[5])))
18418 : : lseq = NULL;
18419 : : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2607;
18420 : : {
18421 : : res_op->set_op (GT_EXPR, type, 2);
18422 : : {
18423 : : tree _o1[1], _r1;
18424 : : {
18425 : : tree _o2[2], _r2;
18426 : : {
18427 : : tree _o3[2], _r3;
18428 : : _o3[0] = swap_p ? captures[4] : captures[2];
18429 : : _o3[1] = wide_int_to_tree (sizetype, off);
18430 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_PLUS_EXPR, TREE_TYPE (_o3[0]), _o3[0], _o3[1]);
18431 : : tem_op.resimplify (lseq, valueize);
18432 : : _r3 = maybe_push_res_to_seq (&tem_op, lseq);
18433 : : if (!_r3) goto next_after_fail2607;
18434 : : _o2[0] = _r3;
18435 : : }
18436 : : _o2[1] = swap_p ? captures[2] : captures[4];
18437 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18438 : : tem_op.resimplify (lseq, valueize);
18439 : : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18440 : : if (!_r2) goto next_after_fail2607;
18441 : : _o1[0] = _r2;
18442 : : }
18443 : : if (sizetype != TREE_TYPE (_o1[0])
18444 : : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18445 : : {
18446 : : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18447 : : tem_op.resimplify (lseq, valueize);
18448 : : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18449 : : if (!_r1) goto next_after_fail2607;
18450 : : }
18451 : : else
18452 : : _r1 = _o1[0];
18453 : : res_op->ops[0] = _r1;
18454 : : }
18455 : : res_op->ops[1] = rhs_tree;
18456 : : res_op->resimplify (lseq, valueize);
18457 : : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1068, __FILE__, __LINE__, true);
18458 : : return true;
18459 : : }
18460 : : next_after_fail2607:;
18461 : : }
18462 : : }
18463 : : }
18464 : : }
18465 : : }
18466 : : }
18467 : : }
18468 : : }
18469 : : }
18470 : : break;
18471 : : }
18472 : : default:;
18473 : : }
18474 : : }
18475 : : break;
18476 : : default:;
18477 : : }
18478 : : break;
18479 : : }
18480 : 0 : case GT_EXPR:
18481 : 0 : {
18482 : 0 : tree _q70 = gimple_assign_rhs1 (_a3);
18483 : 0 : _q70 = do_valueize (valueize, _q70);
18484 : 0 : tree _q71 = gimple_assign_rhs2 (_a3);
18485 : 0 : _q71 = do_valueize (valueize, _q71);
18486 : 0 : if ((_q70 == _q30 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q30, 0) && types_match (_q70, _q30)))
18487 : : {
18488 : 0 : switch (TREE_CODE (_q71))
18489 : : {
18490 : 0 : case SSA_NAME:
18491 : 0 : if (gimple *_d4 = get_def (valueize, _q71))
18492 : : {
18493 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
18494 : 0 : switch (gimple_assign_rhs_code (_a4))
18495 : : {
18496 : 0 : case POINTER_PLUS_EXPR:
18497 : 0 : {
18498 : 0 : tree _q90 = gimple_assign_rhs1 (_a4);
18499 : 0 : _q90 = do_valueize (valueize, _q90);
18500 : 0 : tree _q91 = gimple_assign_rhs2 (_a4);
18501 : 0 : _q91 = do_valueize (valueize, _q91);
18502 : 0 : if ((_q90 == _q21 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q21, 0) && types_match (_q90, _q21)))
18503 : : {
18504 : 0 : if ((_q91 == _q31 && ! TREE_SIDE_EFFECTS (_q91)) || (operand_equal_p (_q91, _q31, 0) && types_match (_q91, _q31)))
18505 : : {
18506 : 0 : {
18507 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q20, _q30, _q31, _q21, _p1, _q71 };
18508 : 0 : const enum tree_code cmp = LT_EXPR;
18509 : 0 : if (TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[2]))
18510 : 0 : && TYPE_OVERFLOW_WRAPS (sizetype)
18511 : 0 : && TYPE_PRECISION (TREE_TYPE (captures[2])) == TYPE_PRECISION (sizetype)
18512 : : )
18513 : : {
18514 : 0 : {
18515 : 0 : offset_int off = wi::to_offset (captures[3]) - (cmp == LE_EXPR ? 1 : 0);
18516 : 0 : offset_int rhs = off * 2;
18517 : 0 : if (wi::min_precision (rhs, UNSIGNED) <= TYPE_PRECISION (sizetype)
18518 : : )
18519 : : {
18520 : 0 : {
18521 : 0 : bool swap_p = tree_swap_operands_p (captures[2], captures[4]);
18522 : 0 : tree rhs_tree = wide_int_to_tree (sizetype, rhs);
18523 : 0 : if (cmp == LT_EXPR
18524 : : )
18525 : : {
18526 : 0 : gimple_seq *lseq = seq;
18527 : 0 : if (lseq
18528 : 0 : && (!single_use (captures[0])
18529 : 0 : || !single_use (captures[5])))
18530 : 0 : lseq = NULL;
18531 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2608;
18532 : 0 : {
18533 : 0 : res_op->set_op (GT_EXPR, type, 2);
18534 : 0 : {
18535 : 0 : tree _o1[1], _r1;
18536 : 0 : {
18537 : 0 : tree _o2[2], _r2;
18538 : 0 : _o2[0] = swap_p ? captures[6] : captures[1];
18539 : 0 : _o2[1] = swap_p ? captures[2] : captures[4];
18540 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18541 : 0 : tem_op.resimplify (lseq, valueize);
18542 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18543 : 0 : if (!_r2) goto next_after_fail2608;
18544 : 0 : _o1[0] = _r2;
18545 : : }
18546 : 0 : if (sizetype != TREE_TYPE (_o1[0])
18547 : 0 : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18548 : : {
18549 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18550 : 0 : tem_op.resimplify (lseq, valueize);
18551 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18552 : 0 : if (!_r1) goto next_after_fail2608;
18553 : : }
18554 : : else
18555 : : _r1 = _o1[0];
18556 : 0 : res_op->ops[0] = _r1;
18557 : : }
18558 : 0 : res_op->ops[1] = rhs_tree;
18559 : 0 : res_op->resimplify (lseq, valueize);
18560 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1067, __FILE__, __LINE__, true);
18561 : 0 : return true;
18562 : : }
18563 : 0 : next_after_fail2608:;
18564 : : }
18565 : : else
18566 : : {
18567 : : gimple_seq *lseq = seq;
18568 : : if (lseq
18569 : : && (!single_use (captures[0])
18570 : : || !single_use (captures[5])))
18571 : : lseq = NULL;
18572 : : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2609;
18573 : : {
18574 : : res_op->set_op (GT_EXPR, type, 2);
18575 : : {
18576 : : tree _o1[1], _r1;
18577 : : {
18578 : : tree _o2[2], _r2;
18579 : : {
18580 : : tree _o3[2], _r3;
18581 : : _o3[0] = swap_p ? captures[4] : captures[2];
18582 : : _o3[1] = wide_int_to_tree (sizetype, off);
18583 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_PLUS_EXPR, TREE_TYPE (_o3[0]), _o3[0], _o3[1]);
18584 : : tem_op.resimplify (lseq, valueize);
18585 : : _r3 = maybe_push_res_to_seq (&tem_op, lseq);
18586 : : if (!_r3) goto next_after_fail2609;
18587 : : _o2[0] = _r3;
18588 : : }
18589 : : _o2[1] = swap_p ? captures[2] : captures[4];
18590 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18591 : : tem_op.resimplify (lseq, valueize);
18592 : : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18593 : : if (!_r2) goto next_after_fail2609;
18594 : : _o1[0] = _r2;
18595 : : }
18596 : : if (sizetype != TREE_TYPE (_o1[0])
18597 : : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18598 : : {
18599 : : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18600 : : tem_op.resimplify (lseq, valueize);
18601 : : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18602 : : if (!_r1) goto next_after_fail2609;
18603 : : }
18604 : : else
18605 : : _r1 = _o1[0];
18606 : : res_op->ops[0] = _r1;
18607 : : }
18608 : : res_op->ops[1] = rhs_tree;
18609 : : res_op->resimplify (lseq, valueize);
18610 : : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1068, __FILE__, __LINE__, true);
18611 : : return true;
18612 : : }
18613 : : next_after_fail2609:;
18614 : : }
18615 : : }
18616 : : }
18617 : : }
18618 : : }
18619 : : }
18620 : : }
18621 : : }
18622 : : break;
18623 : : }
18624 : : default:;
18625 : : }
18626 : : }
18627 : : break;
18628 : : default:;
18629 : : }
18630 : : }
18631 : : break;
18632 : : }
18633 : : default:;
18634 : : }
18635 : : }
18636 : : break;
18637 : : default:;
18638 : : }
18639 : : break;
18640 : : }
18641 : : default:;
18642 : : }
18643 : : break;
18644 : : }
18645 : : default:;
18646 : : }
18647 : : }
18648 : : break;
18649 : : default:;
18650 : : }
18651 : : break;
18652 : : }
18653 : 0 : case GE_EXPR:
18654 : 0 : {
18655 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
18656 : 0 : _q20 = do_valueize (valueize, _q20);
18657 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
18658 : 0 : _q21 = do_valueize (valueize, _q21);
18659 : 0 : switch (TREE_CODE (_q21))
18660 : : {
18661 : 0 : case SSA_NAME:
18662 : 0 : if (gimple *_d2 = get_def (valueize, _q21))
18663 : : {
18664 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
18665 : 0 : switch (gimple_assign_rhs_code (_a2))
18666 : : {
18667 : 0 : case POINTER_PLUS_EXPR:
18668 : 0 : {
18669 : 0 : tree _q40 = gimple_assign_rhs1 (_a2);
18670 : 0 : _q40 = do_valueize (valueize, _q40);
18671 : 0 : tree _q41 = gimple_assign_rhs2 (_a2);
18672 : 0 : _q41 = do_valueize (valueize, _q41);
18673 : 0 : switch (TREE_CODE (_q41))
18674 : : {
18675 : 0 : case INTEGER_CST:
18676 : 0 : {
18677 : 0 : switch (TREE_CODE (_p1))
18678 : : {
18679 : 0 : case SSA_NAME:
18680 : 0 : if (gimple *_d3 = get_def (valueize, _p1))
18681 : : {
18682 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
18683 : 0 : switch (gimple_assign_rhs_code (_a3))
18684 : : {
18685 : 0 : case LE_EXPR:
18686 : 0 : {
18687 : 0 : tree _q70 = gimple_assign_rhs1 (_a3);
18688 : 0 : _q70 = do_valueize (valueize, _q70);
18689 : 0 : tree _q71 = gimple_assign_rhs2 (_a3);
18690 : 0 : _q71 = do_valueize (valueize, _q71);
18691 : 0 : switch (TREE_CODE (_q70))
18692 : : {
18693 : 0 : case SSA_NAME:
18694 : 0 : if (gimple *_d4 = get_def (valueize, _q70))
18695 : : {
18696 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
18697 : 0 : switch (gimple_assign_rhs_code (_a4))
18698 : : {
18699 : 0 : case POINTER_PLUS_EXPR:
18700 : 0 : {
18701 : 0 : tree _q80 = gimple_assign_rhs1 (_a4);
18702 : 0 : _q80 = do_valueize (valueize, _q80);
18703 : 0 : tree _q81 = gimple_assign_rhs2 (_a4);
18704 : 0 : _q81 = do_valueize (valueize, _q81);
18705 : 0 : if ((_q80 == _q20 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q20, 0) && types_match (_q80, _q20)))
18706 : : {
18707 : 0 : if ((_q81 == _q41 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q41, 0) && types_match (_q81, _q41)))
18708 : : {
18709 : 0 : if ((_q71 == _q40 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q40, 0) && types_match (_q71, _q40)))
18710 : : {
18711 : 0 : {
18712 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q21, _q40, _q41, _q20, _p1, _q70 };
18713 : 0 : const enum tree_code cmp = LE_EXPR;
18714 : 0 : if (TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[2]))
18715 : 0 : && TYPE_OVERFLOW_WRAPS (sizetype)
18716 : 0 : && TYPE_PRECISION (TREE_TYPE (captures[2])) == TYPE_PRECISION (sizetype)
18717 : : )
18718 : : {
18719 : 0 : {
18720 : 0 : offset_int off = wi::to_offset (captures[3]) - (cmp == LE_EXPR ? 1 : 0);
18721 : 0 : offset_int rhs = off * 2;
18722 : 0 : if (wi::min_precision (rhs, UNSIGNED) <= TYPE_PRECISION (sizetype)
18723 : : )
18724 : : {
18725 : 0 : {
18726 : 0 : bool swap_p = tree_swap_operands_p (captures[2], captures[4]);
18727 : 0 : tree rhs_tree = wide_int_to_tree (sizetype, rhs);
18728 : 0 : if (cmp == LT_EXPR
18729 : : )
18730 : : {
18731 : : gimple_seq *lseq = seq;
18732 : : if (lseq
18733 : : && (!single_use (captures[0])
18734 : : || !single_use (captures[5])))
18735 : : lseq = NULL;
18736 : : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2610;
18737 : : {
18738 : : res_op->set_op (GT_EXPR, type, 2);
18739 : : {
18740 : : tree _o1[1], _r1;
18741 : : {
18742 : : tree _o2[2], _r2;
18743 : : _o2[0] = swap_p ? captures[6] : captures[1];
18744 : : _o2[1] = swap_p ? captures[2] : captures[4];
18745 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18746 : : tem_op.resimplify (lseq, valueize);
18747 : : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18748 : : if (!_r2) goto next_after_fail2610;
18749 : : _o1[0] = _r2;
18750 : : }
18751 : : if (sizetype != TREE_TYPE (_o1[0])
18752 : : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18753 : : {
18754 : : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18755 : : tem_op.resimplify (lseq, valueize);
18756 : : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18757 : : if (!_r1) goto next_after_fail2610;
18758 : : }
18759 : : else
18760 : : _r1 = _o1[0];
18761 : : res_op->ops[0] = _r1;
18762 : : }
18763 : : res_op->ops[1] = rhs_tree;
18764 : : res_op->resimplify (lseq, valueize);
18765 : : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1067, __FILE__, __LINE__, true);
18766 : 0 : return true;
18767 : : }
18768 : : next_after_fail2610:;
18769 : : }
18770 : : else
18771 : : {
18772 : 0 : gimple_seq *lseq = seq;
18773 : 0 : if (lseq
18774 : 0 : && (!single_use (captures[0])
18775 : 0 : || !single_use (captures[5])))
18776 : 0 : lseq = NULL;
18777 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2611;
18778 : 0 : {
18779 : 0 : res_op->set_op (GT_EXPR, type, 2);
18780 : 0 : {
18781 : 0 : tree _o1[1], _r1;
18782 : 0 : {
18783 : 0 : tree _o2[2], _r2;
18784 : 0 : {
18785 : 0 : tree _o3[2], _r3;
18786 : 0 : _o3[0] = swap_p ? captures[4] : captures[2];
18787 : 0 : _o3[1] = wide_int_to_tree (sizetype, off);
18788 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_PLUS_EXPR, TREE_TYPE (_o3[0]), _o3[0], _o3[1]);
18789 : 0 : tem_op.resimplify (lseq, valueize);
18790 : 0 : _r3 = maybe_push_res_to_seq (&tem_op, lseq);
18791 : 0 : if (!_r3) goto next_after_fail2611;
18792 : 0 : _o2[0] = _r3;
18793 : : }
18794 : 0 : _o2[1] = swap_p ? captures[2] : captures[4];
18795 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18796 : 0 : tem_op.resimplify (lseq, valueize);
18797 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18798 : 0 : if (!_r2) goto next_after_fail2611;
18799 : 0 : _o1[0] = _r2;
18800 : : }
18801 : 0 : if (sizetype != TREE_TYPE (_o1[0])
18802 : 0 : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18803 : : {
18804 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18805 : 0 : tem_op.resimplify (lseq, valueize);
18806 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18807 : 0 : if (!_r1) goto next_after_fail2611;
18808 : : }
18809 : : else
18810 : : _r1 = _o1[0];
18811 : 0 : res_op->ops[0] = _r1;
18812 : : }
18813 : 0 : res_op->ops[1] = rhs_tree;
18814 : 0 : res_op->resimplify (lseq, valueize);
18815 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1068, __FILE__, __LINE__, true);
18816 : 0 : return true;
18817 : : }
18818 : 0 : next_after_fail2611:;
18819 : : }
18820 : : }
18821 : : }
18822 : : }
18823 : : }
18824 : : }
18825 : : }
18826 : : }
18827 : : }
18828 : : break;
18829 : : }
18830 : : default:;
18831 : : }
18832 : : }
18833 : : break;
18834 : : default:;
18835 : : }
18836 : : break;
18837 : : }
18838 : 0 : case GE_EXPR:
18839 : 0 : {
18840 : 0 : tree _q70 = gimple_assign_rhs1 (_a3);
18841 : 0 : _q70 = do_valueize (valueize, _q70);
18842 : 0 : tree _q71 = gimple_assign_rhs2 (_a3);
18843 : 0 : _q71 = do_valueize (valueize, _q71);
18844 : 0 : if ((_q70 == _q40 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q40, 0) && types_match (_q70, _q40)))
18845 : : {
18846 : 0 : switch (TREE_CODE (_q71))
18847 : : {
18848 : 0 : case SSA_NAME:
18849 : 0 : if (gimple *_d4 = get_def (valueize, _q71))
18850 : : {
18851 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
18852 : 0 : switch (gimple_assign_rhs_code (_a4))
18853 : : {
18854 : 0 : case POINTER_PLUS_EXPR:
18855 : 0 : {
18856 : 0 : tree _q90 = gimple_assign_rhs1 (_a4);
18857 : 0 : _q90 = do_valueize (valueize, _q90);
18858 : 0 : tree _q91 = gimple_assign_rhs2 (_a4);
18859 : 0 : _q91 = do_valueize (valueize, _q91);
18860 : 0 : if ((_q90 == _q20 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q20, 0) && types_match (_q90, _q20)))
18861 : : {
18862 : 0 : if ((_q91 == _q41 && ! TREE_SIDE_EFFECTS (_q91)) || (operand_equal_p (_q91, _q41, 0) && types_match (_q91, _q41)))
18863 : : {
18864 : 0 : {
18865 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q21, _q40, _q41, _q20, _p1, _q71 };
18866 : 0 : const enum tree_code cmp = LE_EXPR;
18867 : 0 : if (TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[2]))
18868 : 0 : && TYPE_OVERFLOW_WRAPS (sizetype)
18869 : 0 : && TYPE_PRECISION (TREE_TYPE (captures[2])) == TYPE_PRECISION (sizetype)
18870 : : )
18871 : : {
18872 : 0 : {
18873 : 0 : offset_int off = wi::to_offset (captures[3]) - (cmp == LE_EXPR ? 1 : 0);
18874 : 0 : offset_int rhs = off * 2;
18875 : 0 : if (wi::min_precision (rhs, UNSIGNED) <= TYPE_PRECISION (sizetype)
18876 : : )
18877 : : {
18878 : 0 : {
18879 : 0 : bool swap_p = tree_swap_operands_p (captures[2], captures[4]);
18880 : 0 : tree rhs_tree = wide_int_to_tree (sizetype, rhs);
18881 : 0 : if (cmp == LT_EXPR
18882 : : )
18883 : : {
18884 : : gimple_seq *lseq = seq;
18885 : : if (lseq
18886 : : && (!single_use (captures[0])
18887 : : || !single_use (captures[5])))
18888 : : lseq = NULL;
18889 : : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2612;
18890 : : {
18891 : : res_op->set_op (GT_EXPR, type, 2);
18892 : : {
18893 : : tree _o1[1], _r1;
18894 : : {
18895 : : tree _o2[2], _r2;
18896 : : _o2[0] = swap_p ? captures[6] : captures[1];
18897 : : _o2[1] = swap_p ? captures[2] : captures[4];
18898 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18899 : : tem_op.resimplify (lseq, valueize);
18900 : : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18901 : : if (!_r2) goto next_after_fail2612;
18902 : : _o1[0] = _r2;
18903 : : }
18904 : : if (sizetype != TREE_TYPE (_o1[0])
18905 : : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18906 : : {
18907 : : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18908 : : tem_op.resimplify (lseq, valueize);
18909 : : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18910 : : if (!_r1) goto next_after_fail2612;
18911 : : }
18912 : : else
18913 : : _r1 = _o1[0];
18914 : : res_op->ops[0] = _r1;
18915 : : }
18916 : : res_op->ops[1] = rhs_tree;
18917 : : res_op->resimplify (lseq, valueize);
18918 : : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1067, __FILE__, __LINE__, true);
18919 : 0 : return true;
18920 : : }
18921 : : next_after_fail2612:;
18922 : : }
18923 : : else
18924 : : {
18925 : 0 : gimple_seq *lseq = seq;
18926 : 0 : if (lseq
18927 : 0 : && (!single_use (captures[0])
18928 : 0 : || !single_use (captures[5])))
18929 : 0 : lseq = NULL;
18930 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2613;
18931 : 0 : {
18932 : 0 : res_op->set_op (GT_EXPR, type, 2);
18933 : 0 : {
18934 : 0 : tree _o1[1], _r1;
18935 : 0 : {
18936 : 0 : tree _o2[2], _r2;
18937 : 0 : {
18938 : 0 : tree _o3[2], _r3;
18939 : 0 : _o3[0] = swap_p ? captures[4] : captures[2];
18940 : 0 : _o3[1] = wide_int_to_tree (sizetype, off);
18941 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_PLUS_EXPR, TREE_TYPE (_o3[0]), _o3[0], _o3[1]);
18942 : 0 : tem_op.resimplify (lseq, valueize);
18943 : 0 : _r3 = maybe_push_res_to_seq (&tem_op, lseq);
18944 : 0 : if (!_r3) goto next_after_fail2613;
18945 : 0 : _o2[0] = _r3;
18946 : : }
18947 : 0 : _o2[1] = swap_p ? captures[2] : captures[4];
18948 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
18949 : 0 : tem_op.resimplify (lseq, valueize);
18950 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
18951 : 0 : if (!_r2) goto next_after_fail2613;
18952 : 0 : _o1[0] = _r2;
18953 : : }
18954 : 0 : if (sizetype != TREE_TYPE (_o1[0])
18955 : 0 : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
18956 : : {
18957 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
18958 : 0 : tem_op.resimplify (lseq, valueize);
18959 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
18960 : 0 : if (!_r1) goto next_after_fail2613;
18961 : : }
18962 : : else
18963 : : _r1 = _o1[0];
18964 : 0 : res_op->ops[0] = _r1;
18965 : : }
18966 : 0 : res_op->ops[1] = rhs_tree;
18967 : 0 : res_op->resimplify (lseq, valueize);
18968 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1068, __FILE__, __LINE__, true);
18969 : 0 : return true;
18970 : : }
18971 : 0 : next_after_fail2613:;
18972 : : }
18973 : : }
18974 : : }
18975 : : }
18976 : : }
18977 : : }
18978 : : }
18979 : : }
18980 : : break;
18981 : : }
18982 : : default:;
18983 : : }
18984 : : }
18985 : : break;
18986 : : default:;
18987 : : }
18988 : : }
18989 : : break;
18990 : : }
18991 : : default:;
18992 : : }
18993 : : }
18994 : : break;
18995 : : default:;
18996 : : }
18997 : : break;
18998 : : }
18999 : : default:;
19000 : : }
19001 : : break;
19002 : : }
19003 : : default:;
19004 : : }
19005 : : }
19006 : : break;
19007 : : default:;
19008 : : }
19009 : : break;
19010 : : }
19011 : 0 : case GT_EXPR:
19012 : 0 : {
19013 : 0 : tree _q20 = gimple_assign_rhs1 (_a1);
19014 : 0 : _q20 = do_valueize (valueize, _q20);
19015 : 0 : tree _q21 = gimple_assign_rhs2 (_a1);
19016 : 0 : _q21 = do_valueize (valueize, _q21);
19017 : 0 : switch (TREE_CODE (_q21))
19018 : : {
19019 : 0 : case SSA_NAME:
19020 : 0 : if (gimple *_d2 = get_def (valueize, _q21))
19021 : : {
19022 : 0 : if (gassign *_a2 = dyn_cast <gassign *> (_d2))
19023 : 0 : switch (gimple_assign_rhs_code (_a2))
19024 : : {
19025 : 0 : case POINTER_PLUS_EXPR:
19026 : 0 : {
19027 : 0 : tree _q40 = gimple_assign_rhs1 (_a2);
19028 : 0 : _q40 = do_valueize (valueize, _q40);
19029 : 0 : tree _q41 = gimple_assign_rhs2 (_a2);
19030 : 0 : _q41 = do_valueize (valueize, _q41);
19031 : 0 : switch (TREE_CODE (_q41))
19032 : : {
19033 : 0 : case INTEGER_CST:
19034 : 0 : {
19035 : 0 : switch (TREE_CODE (_p1))
19036 : : {
19037 : 0 : case SSA_NAME:
19038 : 0 : if (gimple *_d3 = get_def (valueize, _p1))
19039 : : {
19040 : 0 : if (gassign *_a3 = dyn_cast <gassign *> (_d3))
19041 : 0 : switch (gimple_assign_rhs_code (_a3))
19042 : : {
19043 : 0 : case LT_EXPR:
19044 : 0 : {
19045 : 0 : tree _q70 = gimple_assign_rhs1 (_a3);
19046 : 0 : _q70 = do_valueize (valueize, _q70);
19047 : 0 : tree _q71 = gimple_assign_rhs2 (_a3);
19048 : 0 : _q71 = do_valueize (valueize, _q71);
19049 : 0 : switch (TREE_CODE (_q70))
19050 : : {
19051 : 0 : case SSA_NAME:
19052 : 0 : if (gimple *_d4 = get_def (valueize, _q70))
19053 : : {
19054 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
19055 : 0 : switch (gimple_assign_rhs_code (_a4))
19056 : : {
19057 : 0 : case POINTER_PLUS_EXPR:
19058 : 0 : {
19059 : 0 : tree _q80 = gimple_assign_rhs1 (_a4);
19060 : 0 : _q80 = do_valueize (valueize, _q80);
19061 : 0 : tree _q81 = gimple_assign_rhs2 (_a4);
19062 : 0 : _q81 = do_valueize (valueize, _q81);
19063 : 0 : if ((_q80 == _q20 && ! TREE_SIDE_EFFECTS (_q80)) || (operand_equal_p (_q80, _q20, 0) && types_match (_q80, _q20)))
19064 : : {
19065 : 0 : if ((_q81 == _q41 && ! TREE_SIDE_EFFECTS (_q81)) || (operand_equal_p (_q81, _q41, 0) && types_match (_q81, _q41)))
19066 : : {
19067 : 0 : if ((_q71 == _q40 && ! TREE_SIDE_EFFECTS (_q71)) || (operand_equal_p (_q71, _q40, 0) && types_match (_q71, _q40)))
19068 : : {
19069 : 0 : {
19070 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q21, _q40, _q41, _q20, _p1, _q70 };
19071 : 0 : const enum tree_code cmp = LT_EXPR;
19072 : 0 : if (TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[2]))
19073 : 0 : && TYPE_OVERFLOW_WRAPS (sizetype)
19074 : 0 : && TYPE_PRECISION (TREE_TYPE (captures[2])) == TYPE_PRECISION (sizetype)
19075 : : )
19076 : : {
19077 : 0 : {
19078 : 0 : offset_int off = wi::to_offset (captures[3]) - (cmp == LE_EXPR ? 1 : 0);
19079 : 0 : offset_int rhs = off * 2;
19080 : 0 : if (wi::min_precision (rhs, UNSIGNED) <= TYPE_PRECISION (sizetype)
19081 : : )
19082 : : {
19083 : 0 : {
19084 : 0 : bool swap_p = tree_swap_operands_p (captures[2], captures[4]);
19085 : 0 : tree rhs_tree = wide_int_to_tree (sizetype, rhs);
19086 : 0 : if (cmp == LT_EXPR
19087 : : )
19088 : : {
19089 : 0 : gimple_seq *lseq = seq;
19090 : 0 : if (lseq
19091 : 0 : && (!single_use (captures[0])
19092 : 0 : || !single_use (captures[5])))
19093 : 0 : lseq = NULL;
19094 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2614;
19095 : 0 : {
19096 : 0 : res_op->set_op (GT_EXPR, type, 2);
19097 : 0 : {
19098 : 0 : tree _o1[1], _r1;
19099 : 0 : {
19100 : 0 : tree _o2[2], _r2;
19101 : 0 : _o2[0] = swap_p ? captures[6] : captures[1];
19102 : 0 : _o2[1] = swap_p ? captures[2] : captures[4];
19103 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
19104 : 0 : tem_op.resimplify (lseq, valueize);
19105 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
19106 : 0 : if (!_r2) goto next_after_fail2614;
19107 : 0 : _o1[0] = _r2;
19108 : : }
19109 : 0 : if (sizetype != TREE_TYPE (_o1[0])
19110 : 0 : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
19111 : : {
19112 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
19113 : 0 : tem_op.resimplify (lseq, valueize);
19114 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
19115 : 0 : if (!_r1) goto next_after_fail2614;
19116 : : }
19117 : : else
19118 : : _r1 = _o1[0];
19119 : 0 : res_op->ops[0] = _r1;
19120 : : }
19121 : 0 : res_op->ops[1] = rhs_tree;
19122 : 0 : res_op->resimplify (lseq, valueize);
19123 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1067, __FILE__, __LINE__, true);
19124 : 0 : return true;
19125 : : }
19126 : 0 : next_after_fail2614:;
19127 : : }
19128 : : else
19129 : : {
19130 : : gimple_seq *lseq = seq;
19131 : : if (lseq
19132 : : && (!single_use (captures[0])
19133 : : || !single_use (captures[5])))
19134 : : lseq = NULL;
19135 : : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2615;
19136 : : {
19137 : : res_op->set_op (GT_EXPR, type, 2);
19138 : : {
19139 : : tree _o1[1], _r1;
19140 : : {
19141 : : tree _o2[2], _r2;
19142 : : {
19143 : : tree _o3[2], _r3;
19144 : : _o3[0] = swap_p ? captures[4] : captures[2];
19145 : : _o3[1] = wide_int_to_tree (sizetype, off);
19146 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_PLUS_EXPR, TREE_TYPE (_o3[0]), _o3[0], _o3[1]);
19147 : : tem_op.resimplify (lseq, valueize);
19148 : : _r3 = maybe_push_res_to_seq (&tem_op, lseq);
19149 : : if (!_r3) goto next_after_fail2615;
19150 : : _o2[0] = _r3;
19151 : : }
19152 : : _o2[1] = swap_p ? captures[2] : captures[4];
19153 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
19154 : : tem_op.resimplify (lseq, valueize);
19155 : : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
19156 : : if (!_r2) goto next_after_fail2615;
19157 : : _o1[0] = _r2;
19158 : : }
19159 : : if (sizetype != TREE_TYPE (_o1[0])
19160 : : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
19161 : : {
19162 : : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
19163 : : tem_op.resimplify (lseq, valueize);
19164 : : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
19165 : : if (!_r1) goto next_after_fail2615;
19166 : : }
19167 : : else
19168 : : _r1 = _o1[0];
19169 : : res_op->ops[0] = _r1;
19170 : : }
19171 : : res_op->ops[1] = rhs_tree;
19172 : : res_op->resimplify (lseq, valueize);
19173 : : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1068, __FILE__, __LINE__, true);
19174 : : return true;
19175 : : }
19176 : : next_after_fail2615:;
19177 : : }
19178 : : }
19179 : : }
19180 : : }
19181 : : }
19182 : : }
19183 : : }
19184 : : }
19185 : : }
19186 : : break;
19187 : : }
19188 : : default:;
19189 : : }
19190 : : }
19191 : : break;
19192 : : default:;
19193 : : }
19194 : : break;
19195 : : }
19196 : 0 : case GT_EXPR:
19197 : 0 : {
19198 : 0 : tree _q70 = gimple_assign_rhs1 (_a3);
19199 : 0 : _q70 = do_valueize (valueize, _q70);
19200 : 0 : tree _q71 = gimple_assign_rhs2 (_a3);
19201 : 0 : _q71 = do_valueize (valueize, _q71);
19202 : 0 : if ((_q70 == _q40 && ! TREE_SIDE_EFFECTS (_q70)) || (operand_equal_p (_q70, _q40, 0) && types_match (_q70, _q40)))
19203 : : {
19204 : 0 : switch (TREE_CODE (_q71))
19205 : : {
19206 : 0 : case SSA_NAME:
19207 : 0 : if (gimple *_d4 = get_def (valueize, _q71))
19208 : : {
19209 : 0 : if (gassign *_a4 = dyn_cast <gassign *> (_d4))
19210 : 0 : switch (gimple_assign_rhs_code (_a4))
19211 : : {
19212 : 0 : case POINTER_PLUS_EXPR:
19213 : 0 : {
19214 : 0 : tree _q90 = gimple_assign_rhs1 (_a4);
19215 : 0 : _q90 = do_valueize (valueize, _q90);
19216 : 0 : tree _q91 = gimple_assign_rhs2 (_a4);
19217 : 0 : _q91 = do_valueize (valueize, _q91);
19218 : 0 : if ((_q90 == _q20 && ! TREE_SIDE_EFFECTS (_q90)) || (operand_equal_p (_q90, _q20, 0) && types_match (_q90, _q20)))
19219 : : {
19220 : 0 : if ((_q91 == _q41 && ! TREE_SIDE_EFFECTS (_q91)) || (operand_equal_p (_q91, _q41, 0) && types_match (_q91, _q41)))
19221 : : {
19222 : 0 : {
19223 : 0 : tree captures[7] ATTRIBUTE_UNUSED = { _p0, _q21, _q40, _q41, _q20, _p1, _q71 };
19224 : 0 : const enum tree_code cmp = LT_EXPR;
19225 : 0 : if (TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (captures[2]))
19226 : 0 : && TYPE_OVERFLOW_WRAPS (sizetype)
19227 : 0 : && TYPE_PRECISION (TREE_TYPE (captures[2])) == TYPE_PRECISION (sizetype)
19228 : : )
19229 : : {
19230 : 0 : {
19231 : 0 : offset_int off = wi::to_offset (captures[3]) - (cmp == LE_EXPR ? 1 : 0);
19232 : 0 : offset_int rhs = off * 2;
19233 : 0 : if (wi::min_precision (rhs, UNSIGNED) <= TYPE_PRECISION (sizetype)
19234 : : )
19235 : : {
19236 : 0 : {
19237 : 0 : bool swap_p = tree_swap_operands_p (captures[2], captures[4]);
19238 : 0 : tree rhs_tree = wide_int_to_tree (sizetype, rhs);
19239 : 0 : if (cmp == LT_EXPR
19240 : : )
19241 : : {
19242 : 0 : gimple_seq *lseq = seq;
19243 : 0 : if (lseq
19244 : 0 : && (!single_use (captures[0])
19245 : 0 : || !single_use (captures[5])))
19246 : 0 : lseq = NULL;
19247 : 0 : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2616;
19248 : 0 : {
19249 : 0 : res_op->set_op (GT_EXPR, type, 2);
19250 : 0 : {
19251 : 0 : tree _o1[1], _r1;
19252 : 0 : {
19253 : 0 : tree _o2[2], _r2;
19254 : 0 : _o2[0] = swap_p ? captures[6] : captures[1];
19255 : 0 : _o2[1] = swap_p ? captures[2] : captures[4];
19256 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
19257 : 0 : tem_op.resimplify (lseq, valueize);
19258 : 0 : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
19259 : 0 : if (!_r2) goto next_after_fail2616;
19260 : 0 : _o1[0] = _r2;
19261 : : }
19262 : 0 : if (sizetype != TREE_TYPE (_o1[0])
19263 : 0 : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
19264 : : {
19265 : 0 : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
19266 : 0 : tem_op.resimplify (lseq, valueize);
19267 : 0 : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
19268 : 0 : if (!_r1) goto next_after_fail2616;
19269 : : }
19270 : : else
19271 : : _r1 = _o1[0];
19272 : 0 : res_op->ops[0] = _r1;
19273 : : }
19274 : 0 : res_op->ops[1] = rhs_tree;
19275 : 0 : res_op->resimplify (lseq, valueize);
19276 : 0 : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1067, __FILE__, __LINE__, true);
19277 : 0 : return true;
19278 : : }
19279 : 0 : next_after_fail2616:;
19280 : : }
19281 : : else
19282 : : {
19283 : : gimple_seq *lseq = seq;
19284 : : if (lseq
19285 : : && (!single_use (captures[0])
19286 : : || !single_use (captures[5])))
19287 : : lseq = NULL;
19288 : : if (UNLIKELY (!dbg_cnt (match))) goto next_after_fail2617;
19289 : : {
19290 : : res_op->set_op (GT_EXPR, type, 2);
19291 : : {
19292 : : tree _o1[1], _r1;
19293 : : {
19294 : : tree _o2[2], _r2;
19295 : : {
19296 : : tree _o3[2], _r3;
19297 : : _o3[0] = swap_p ? captures[4] : captures[2];
19298 : : _o3[1] = wide_int_to_tree (sizetype, off);
19299 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_PLUS_EXPR, TREE_TYPE (_o3[0]), _o3[0], _o3[1]);
19300 : : tem_op.resimplify (lseq, valueize);
19301 : : _r3 = maybe_push_res_to_seq (&tem_op, lseq);
19302 : : if (!_r3) goto next_after_fail2617;
19303 : : _o2[0] = _r3;
19304 : : }
19305 : : _o2[1] = swap_p ? captures[2] : captures[4];
19306 : : gimple_match_op tem_op (res_op->cond.any_else (), POINTER_DIFF_EXPR, ssizetype, _o2[0], _o2[1]);
19307 : : tem_op.resimplify (lseq, valueize);
19308 : : _r2 = maybe_push_res_to_seq (&tem_op, lseq);
19309 : : if (!_r2) goto next_after_fail2617;
19310 : : _o1[0] = _r2;
19311 : : }
19312 : : if (sizetype != TREE_TYPE (_o1[0])
19313 : : && !useless_type_conversion_p (sizetype, TREE_TYPE (_o1[0])))
19314 : : {
19315 : : gimple_match_op tem_op (res_op->cond.any_else (), NOP_EXPR, sizetype, _o1[0]);
19316 : : tem_op.resimplify (lseq, valueize);
19317 : : _r1 = maybe_push_res_to_seq (&tem_op, lseq);
19318 : : if (!_r1) goto next_after_fail2617;
19319 : : }
19320 : : else
19321 : : _r1 = _o1[0];
19322 : : res_op->ops[0] = _r1;
19323 : : }
19324 : : res_op->ops[1] = rhs_tree;
19325 : : res_op->resimplify (lseq, valueize);
19326 : : if (UNLIKELY (debug_dump)) gimple_dump_logs ("match.pd", 1068, __FILE__, __LINE__, true);
19327 : : return true;
19328 : : }
19329 : : next_after_fail2617:;
19330 : : }
19331 : : }
19332 : : }
19333 : : }
19334 : : }
19335 : : }
19336 : : }
19337 : : }
19338 : : break;
19339 : : }
19340 : : default:;
19341 : : }
19342 : : }
19343 : : break;
19344 : : default:;
19345 : : }
19346 : : }
19347 : : break;
19348 : : }
19349 : : default:;
19350 : : }
19351 : : }
19352 : : break;
19353 : : default:;
19354 : : }
19355 : : break;
19356 : : }
19357 : : default:;
19358 : : }
19359 : : break;
19360 : : }
19361 : : default:;
19362 : : }
19363 : : }
19364 : : break;
19365 : : default:;
19366 : : }
19367 : : break;
19368 : : }
19369 : : default:;
19370 : : }
19371 : : }
19372 : : break;
19373 : : default:;
19374 : : }
19375 : : return false;
19376 : : }
19377 : : #pragma GCC diagnostic pop
|