https://gcc.gnu.org/g:b2d21311083aa444ba63492ae109abe3c96b4049

commit b2d21311083aa444ba63492ae109abe3c96b4049
Author: Michael Meissner <[email protected]>
Date:   Wed Mar 11 18:03:57 2026 -0400

    Revert changes

Diff:
---
 gcc/config/rs6000/rs6000.md                        | 14 --------
 .../gcc.target/powerpc/saturate-subtract-1.c       | 38 ----------------------
 .../gcc.target/powerpc/saturate-subtract-2.c       | 38 ----------------------
 3 files changed, 90 deletions(-)

diff --git a/gcc/config/rs6000/rs6000.md b/gcc/config/rs6000/rs6000.md
index 909c817cbe7e..57a239791ee3 100644
--- a/gcc/config/rs6000/rs6000.md
+++ b/gcc/config/rs6000/rs6000.md
@@ -2397,20 +2397,6 @@
   ""
 )
 
-;; Saturating subtract
-(define_code_iterator gtu_geu [gtu geu])
-
-(define_insn "*subfus<mode>3_<code>"
-  [(set (match_operand:GPR 0 "gpc_reg_operand" "=r")
-       (if_then_else:GPR (gtu_geu (match_operand:GPR 2 "gpc_reg_operand" "r")
-                                  (match_operand:GPR 1 "gpc_reg_operand" "r"))
-                         (minus:GPR (match_dup 2)
-                                    (match_dup 1))
-                         (const_int 0)))]
-  "TARGET_FUTURE"
-  "sub<wd>us %0,%1,%2"
-  [(set_attr "type" "add")])
-
 (define_insn "@neg<mode>2"
   [(set (match_operand:GPR 0 "gpc_reg_operand" "=r")
        (neg:GPR (match_operand:GPR 1 "gpc_reg_operand" "r")))]
diff --git a/gcc/testsuite/gcc.target/powerpc/saturate-subtract-1.c 
b/gcc/testsuite/gcc.target/powerpc/saturate-subtract-1.c
deleted file mode 100644
index 5b3bd2ba0633..000000000000
--- a/gcc/testsuite/gcc.target/powerpc/saturate-subtract-1.c
+++ /dev/null
@@ -1,38 +0,0 @@
-/* { dg-do compile } */
-/* { dg-options "-mdejagnu-cpu=future -O2" } */
-
-/* Check that saturating subtract (subfus) is generated.  Check that all
-   combinations of >, >=, <, and <= are optimized.  */
-
-#ifndef TYPE
-#define TYPE   unsigned int
-#endif
-
-void
-saturated_subtract_gt (TYPE a, TYPE b, TYPE *p)
-{
-  *p = (a > b) ? a - b : 0;
-}
-
-void
-saturated_subtract_ge (TYPE a, TYPE b, TYPE *p)
-{
-  *p = (a >= b) ? a - b : 0;
-}
-
-void
-saturated_subtract_lt (TYPE a, TYPE b, TYPE *p)
-{
-  *p = (a < b) ? 0 : a - b;
-}
-
-void
-saturated_subtract_le (TYPE a, TYPE b, TYPE *p)
-{
-  *p = (a <= b) ? 0 : a - b;
-}
-
-/* { dg-final { scan-assembler-times {\msubfus\M} 4 } } */
-/* { dg-final { scan-assembler-not   {\mcmplw\M}    } } */
-/* { dg-final { scan-assembler-not   {\misel\M}     } } */
-/* { dg-final { scan-assembler-not   {\msubf\M}     } } */
diff --git a/gcc/testsuite/gcc.target/powerpc/saturate-subtract-2.c 
b/gcc/testsuite/gcc.target/powerpc/saturate-subtract-2.c
deleted file mode 100644
index fa8fba2a6339..000000000000
--- a/gcc/testsuite/gcc.target/powerpc/saturate-subtract-2.c
+++ /dev/null
@@ -1,38 +0,0 @@
-/* { dg-do compile } */
-/* { dg-options "-mdejagnu-cpu=future -O2" } */
-
-/* Check that saturating subtract (subfus) is generated.  Check that all
-   combinations of >, >=, <, and <= are optimized.  */
-
-#ifndef TYPE
-#define TYPE   unsigned long
-#endif
-
-void
-saturated_subtract_gt (TYPE a, TYPE b, TYPE *p)
-{
-  *p = (a > b) ? a - b : 0;
-}
-
-void
-saturated_subtract_ge (TYPE a, TYPE b, TYPE *p)
-{
-  *p = (a >= b) ? a - b : 0;
-}
-
-void
-saturated_subtract_lt (TYPE a, TYPE b, TYPE *p)
-{
-  *p = (a < b) ? 0 : a - b;
-}
-
-void
-saturated_subtract_le (TYPE a, TYPE b, TYPE *p)
-{
-  *p = (a <= b) ? 0 : a - b;
-}
-
-/* { dg-final { scan-assembler-times {\msubdus\M} 4 } } */
-/* { dg-final { scan-assembler-not   {\mcmpld\M}    } } */
-/* { dg-final { scan-assembler-not   {\misel\M}     } } */
-/* { dg-final { scan-assembler-not   {\msubf\M}     } } */

Reply via email to