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.