https://gcc.gnu.org/g:459de017c0d7a2c7e07140371d513999d1b398b5
commit 459de017c0d7a2c7e07140371d513999d1b398b5 Author: Andrew Pinski <[email protected]> Date: Tue Dec 23 13:04:28 2025 -0800 ifcvt: Only allow scalar integral modes for noce_try_cond_zero_arith [PR123276] This is the simple fix for PR 123276 where this code can only handle scalar integral modes. We could in theory handle scalar floating point modes here too but it is not worth the trouble. Pushed as obvious after bootstrap/test on x86_64-linux-gnu. PR rtl-optimization/123276 gcc/ChangeLog: * ifcvt.cc (noce_try_cond_zero_arith): Reject non-scalar integral modes. Signed-off-by: Andrew Pinski <[email protected]> (cherry picked from commit 2680785a6d14d7d78550edb8361f3b47eb5c4cb6) Diff: --- gcc/ifcvt.cc | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/gcc/ifcvt.cc b/gcc/ifcvt.cc index 2627bf7a8789..e305e3b4c575 100644 --- a/gcc/ifcvt.cc +++ b/gcc/ifcvt.cc @@ -3150,6 +3150,13 @@ noce_try_cond_zero_arith (struct noce_if_info *if_info) machine_mode mode = GET_MODE (if_info->x); bool reverse = false; + /* Scalar integral modes are only supported here. + Could support scalar floating point but that + would be only with -ffast-math and might + be worse than a branch. */ + if (!SCALAR_INT_MODE_P (mode)) + return false; + if (!noce_simple_bbs (if_info)) return false;
