https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101039

            Bug ID: 101039
           Summary: Some simple fold_cond_expr_with_comparison with CMP 0
                    is not simplified
           Product: gcc
           Version: 12.0
            Status: UNCONFIRMED
          Keywords: missed-optimization
          Severity: enhancement
          Priority: P3
         Component: tree-optimization
          Assignee: unassigned at gcc dot gnu.org
          Reporter: pinskia at gcc dot gnu.org
  Target Milestone: ---

Take at -O2:
int f0(int A)
{
//     A == 0? A : -A    same as -A
  if (A == 0)  return A;
  return -A;
}

int f1(int A)
{
//     A != 0? A : -A    same as A
  if (A != 0)  return A;
  return -A;
}
int f2(int A)
{
//     A >= 0? A : -A    same as abs (A)
  if (A >= 0)  return A;
  return -A;
}
int f3(int A)
{
//     A > 0?  A : -A    same as abs (A)
  if (A > 0)  return A;
  return -A;
}
int f4(int A)
{
//     A <= 0? A : -A    same as -abs (A)
  if (A <= 0)  return A;
  return -A;
}
int f5(int A)
{
//     A < 0?  A : -A    same as -abs (A)
  if (A < 0)  return A;
  return -A;
}

------ CUT -------
Only f1-f3 are optimized at the gimple level.  f0, f4, f5 are not.
With -Dint=float -Ofast, only f0 is not optimized but note f1 takes until
*.phiopt3 be optimized; and unlike int, f4 and f5 are optimized in phiopt2.

Note phiopt1 is still confused by predictor but I think there might be another
bug for that.

Reply via email to