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

            Bug ID: 94786
           Summary: Missed min/max pattern using xor+and+less
           Product: gcc
           Version: 10.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: tree-optimization
          Assignee: unassigned at gcc dot gnu.org
          Reporter: gabravier at gmail dot com
  Target Milestone: ---

int r1(int x, int y)
{
    return y ^ ((x ^ y) & -(x < y));
}

int r2(int x, int y)
{
    return x ^ ((x ^ y) & -(x < y));
}

`r1` can be optimized to `min` and `r2` to `max`. This transformation is done
by LLVM, but not by GCC.

Comparison here: https://godbolt.org/z/hNhkqM

Reply via email to