(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.dg/
pr35691-5.c
       1  /* PR middle-end/35691 */
       2  /* { dg-do compile } */
       3  /* { dg-options "-O2 -fdump-tree-reassoc1-details" } */
       4  
       5  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[xyz]1_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[xyz]1_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[xyz]1_\[0-9]*\\(D\\) \\+\\\[0, 0\\\]\[\n\r]" 1 "reassoc1" } } */
       6  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[ghi]1_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[ghi]1_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[ghi]1_\[0-9]*\\(D\\) \\+\\\[0, 0\\\]\[\n\r]" 1 "reassoc1" } } */
       7  
       8  int
       9  f1 (int x1, unsigned int y1, int z1, _Bool d, _Bool e, _Bool f, long long g1, unsigned long long h1, long long i1)
      10  {
      11    int a = x1 == 0;
      12    int b = y1 == 0;
      13    int c = z1 == 0;
      14    int j = g1 == 0;
      15    int k = h1 == 0;
      16    int l = i1 == 0;
      17    return a && d && j && b && e && l && f && c && k;
      18  }
      19  
      20  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[xyz]2_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[xyz]2_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[xyz]2_\[0-9]*\\(D\\) \\+\\\[0, 0\\\]\[\n\r]" 1 "reassoc1" } } */
      21  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[ghi]2_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[ghi]2_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[ghi]2_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\]\[\n\r]" 1 "reassoc1" } } */
      22  
      23  int
      24  f2 (int x2, int y2, unsigned int z2, _Bool d, _Bool e, _Bool f, long long g2, unsigned long long h2, long long i2)
      25  {
      26    int a = x2 == 0;
      27    int b = y2 == 0;
      28    int c = z2 == 0;
      29    int j = g2 == -1LL;
      30    int k = h2 == -1ULL;
      31    int l = i2 == -1LL;
      32    return !a || d || !l || !b || !k || e || f || !c || !j;
      33  }
      34  
      35  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[xyz]3_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[xyz]3_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[xyz]3_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\]\[\n\r]" 1 "reassoc1" } } */
      36  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[ghi]3_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[ghi]3_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[ghi]3_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\]\[\n\r]" 1 "reassoc1" } } */
      37  
      38  int
      39  f3 (unsigned int x3, int y3, int z3, _Bool d, _Bool e, _Bool f, signed char g3, unsigned char h3, signed char i3)
      40  {
      41    int a = x3 == -1U;
      42    int b = y3 == -1;
      43    int c = z3 == -1;
      44    int j = g3 == -1;
      45    int k = h3 == (unsigned char) -1U;
      46    int l = i3 == -1;
      47    return a && d && j && b && k && e && f && c && l;
      48  }
      49  
      50  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[xyz]4_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[xyz]4_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[xyz]4_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\]\[\n\r]" 1 "reassoc1" } } */
      51  
      52  int
      53  f4 (int x4, unsigned int y4, unsigned int z4, _Bool d, _Bool e, _Bool f)
      54  {
      55    int a = x4 == -1U;
      56    int b = y4 == -1U;
      57    int c = z4 == -1;
      58    return !a || d || !b || e || f || !c;
      59  }
      60  
      61  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[xyz]5_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[xyz]5_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[xyz]5_\[0-9]*\\(D\\) \\+\\\[0, 0\\\]\[\n\r]" 1 "reassoc1" } } */
      62  
      63  int
      64  f5 (int x5, int y5, int z5, _Bool d, _Bool e, _Bool f)
      65  {
      66    int a = x5 == 0;
      67    int b = y5 != 0;
      68    int c = z5 != 0;
      69    return a && d && !b && e && f && !c;
      70  }
      71  
      72  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[xyz]6_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[xyz]6_\[0-9]*\\(D\\) \\+\\\[0, 0\\\] and \[xyz]6_\[0-9]*\\(D\\) \\+\\\[0, 0\\\]\[\n\r]" 1 "reassoc1" } } */
      73  
      74  int
      75  f6 (unsigned int x6, unsigned int y6, unsigned int z6, _Bool d, _Bool e, _Bool f)
      76  {
      77    int a = x6 == 0;
      78    int b = y6 != 0;
      79    int c = z6 != 0;
      80    return !a || d || b || e || f || c;
      81  }
      82  
      83  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[xy]7_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[xy]7_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\]\[\n\r]" 1 "reassoc1" } } */
      84  
      85  int
      86  f7 (int x7, int y7, int z7, _Bool d, _Bool e, _Bool f)
      87  {
      88    int a = x7 == -1;
      89    int b = y7 != -1;
      90    int c = z7 == -1;
      91    return a && d && !b && e && f && !c;
      92  }
      93  
      94  /* { dg-final { scan-tree-dump-times "Optimizing range tests \[xy]8_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\] and \[xy]8_\[0-9]*\\(D\\) \\+\\\[\[1-9-]\[0-9]*, \[1-9-]\[0-9]*\\\]\[\n\r]" 1 "reassoc1" } } */
      95  
      96  int
      97  f8 (unsigned int x8, unsigned int y8, unsigned int z8, _Bool d, _Bool e, _Bool f)
      98  {
      99    int a = x8 == -1;
     100    int b = y8 != -1;
     101    int c = z8 == -1;
     102    return !a || d || b || e || f || c;
     103  }
     104  
     105  /* { dg-final { scan-tree-dump-not "Optimizing range tests \[xyz]9_\[0-9]*\\(D\\)" "reassoc1" } } */
     106  
     107  int
     108  f9 (int x9, int y9, int z9, _Bool d, _Bool e, _Bool f)
     109  {
     110    int a = x9 == -1;
     111    int b = y9 == -1;
     112    int c = z9 == -1;
     113    return a || d || b || e || f || c;
     114  }
     115  
     116  /* { dg-final { scan-tree-dump-not "Optimizing range tests \[xyz]0_\[0-9]*\\(D\\)" "reassoc1" } } */
     117  
     118  int
     119  f0 (int x0, int y0, int z0, _Bool d, _Bool e, _Bool f)
     120  {
     121    int a = x0 != 0;
     122    int b = y0 != 0;
     123    int c = z0 != 0;
     124    return a && d && b && e && f && c;
     125  }