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;

Reply via email to