https://gcc.gnu.org/g:76887290ab16f09902023939705489cb7a63b8be

commit 76887290ab16f09902023939705489cb7a63b8be
Author: Michael Meissner <meiss...@linux.ibm.com>
Date:   Sun Nov 17 19:05:35 2024 -0500

    Revert changes

Diff:
---
 gcc/config/rs6000/rs6000.md                 | 47 -----------------------
 gcc/testsuite/gcc.target/powerpc/pr108958.c | 58 -----------------------------
 2 files changed, 105 deletions(-)

diff --git a/gcc/config/rs6000/rs6000.md b/gcc/config/rs6000/rs6000.md
index e3ac69430f39..d266f93ff2e4 100644
--- a/gcc/config/rs6000/rs6000.md
+++ b/gcc/config/rs6000/rs6000.md
@@ -1026,53 +1026,6 @@
    (set_attr "dot" "yes")
    (set_attr "length" "4,8")])
 
-(define_insn_and_split "zero_extendditi2"
-  [(set (match_operand:TI 0 "gpc_reg_operand" "=r,r,wa,wa,?&wa")
-       (zero_extend:TI
-        (match_operand:DI 1 "reg_or_mem_operand" "r,m,r,Z,wa")))]
-  "TARGET_DIRECT_MOVE_64BIT"
-  "@
-  #
-  #
-  mtvsrdd %x0,0,%1
-  lxvrdx %x0,%y1
-  #"
-  "&& reload_completed
-   && (int_reg_operand (operands[0], TImode)
-       || (vsx_register_operand (operands[0], TImode)
-           && vsx_register_operand (operands[1], DImode)))"
-  [(set (match_dup 2)
-       (match_dup 3))
-   (set (match_dup 4)
-       (match_dup 5))]
-{
-  rtx op0 = operands[0];
-  rtx op1 = operands[1];
-
-  if (int_reg_operand (op0, TImode))
-    {
-      operands[2] = gen_lowpart (DImode, op0);
-      operands[3] = op1;
-      operands[4] = gen_highpart (DImode, op0);
-      operands[5] = const0_rtx;
-    }
-  else
-    {
-      int op0_r = reg_or_subregno (op0);
-      rtx op0_di = gen_rtx_REG (DImode, op0_r);
-      rtx op0_v2di = gen_rtx_REG (V2DImode, op0_r);
-      rtx lo = WORDS_BIG_ENDIAN ? op0_di : op1;
-      rtx hi = WORDS_BIG_ENDIAN ? op1 : op0_di;
-
-      operands[2] = op0_v2di;
-      operands[3] = CONST0_RTX (V2DImode);
-      operands[4] = op0_v2di;
-      operands[5] = gen_rtx_VEC_CONCAT (V2DImode, hi, lo);
-    }
-}
-  [(set_attr "type" "*,load,mtvsr,vecload,vecperm")
-   (set_attr "length" "8,8,*,*,8")
-   (set_attr "isa" "*,*,*,p10,*")])
 
 (define_insn "extendqi<mode>2"
   [(set (match_operand:EXTQI 0 "gpc_reg_operand" "=r,?*v")
diff --git a/gcc/testsuite/gcc.target/powerpc/pr108958.c 
b/gcc/testsuite/gcc.target/powerpc/pr108958.c
deleted file mode 100644
index 863b3dbabc79..000000000000
--- a/gcc/testsuite/gcc.target/powerpc/pr108958.c
+++ /dev/null
@@ -1,58 +0,0 @@
-/* { dg-do compile } */
-/* { dg-require-effective-target int128 } */
-/* { dg-require-effective-target lp64 } */
-/* { dg-require-effective-target power10_ok } */
-/* { dg-options "-mdejagnu-cpu=power10 -O2" } */
-
-/* PR target/108958, use mtvsrdd to zero extend gpr to vsx register.  */
-
-void
-arg_to_vsx (unsigned long long x, __uint128_t *p)
-{
-  /* mtvsrdd vsx,0,gpr.  */
-  __uint128_t y = x;
-  __asm__ (" # %x0" : "+wa" (y));
-  *p = y;
-}
-
-void
-mem_to_vsx (unsigned long long *p, __uint128_t *q)
-{
-  /* lxrdx vsx,0,ptr.  */
-  __uint128_t y = *p;
-  __asm__ (" # %x0" : "+wa" (y));
-  *q = y;
-}
-
-
-void
-vsx_to_vsx (double d, __uint128_t *p)
-{
-  /* xxspltib + xxpermdir.  */
-  unsigned long long ull = d;
-  __uint128_t x = ull;
-  __asm__ (" # %x0" : "+wa" (x));
-  *p = x;
-}
-
-void
-arg_to_gpr (unsigned long long x, __uint128_t *p)
-{
-  /* mr gpr1_lo,gpr2; li gpr1_hi,0.  */
-  __uint128_t y = x;
-  __asm__ (" # %0" : "+r" (y));
-  *p = y;
-}
-
-void
-mem_to_gpr (unsigned long long *p, __uint128_t *q)
-{
-  /* ld gpr1_lo,addr; li gpr1_hi,0.  */
-  __uint128_t y = *p;
-  __asm__ (" # %0" : "+r" (y));
-  *q = y;
-}
-
-/* { dg-final { scan-assembler-times {\mmtvsrdd .*,0,.*\M} 1 } } */
-/* { dg-final { scan-assembler-times {\mlxvrdx\M}          1 } } */
-/* { dg-final { scan-assembler-times {\mxxpermdi\M}        1 } } */

Reply via email to