https://gcc.gnu.org/g:271745bafafbf3316d01ceb6430d67b894129a4c

commit r15-8964-g271745bafafbf3316d01ceb6430d67b894129a4c
Author: Hu, Lin1 <lin1...@intel.com>
Date:   Mon Mar 24 15:36:13 2025 +0800

    i386: Set attr "addr" as "gpr16" for constraint "jm". [PR 119425]
    
    "jm" should with "gpr16", otherwise maybe raise ICE in reload pass.
    
    gcc/ChangeLog:
    
            PR target/119425
            * config/i386/sse.md:
            (vec_set<mode>_0): Set the alternative with constraint "jm"'s
            attribute "addr" to "gpr16".
            (<mask_codefor>avx512dq_shuf_<shuffletype>64x2_1<mask_name>):
            Ditto.
            (avx512vl_shuf_<shuffletype>32x4_1<mask_name>): Ditto.
            (avx2_pblendd<mode>): Ditto.
            (aesenc): Ditto.
            (aesenclast): Ditto.
            (aesdec): Ditto.
            (aesdeclast): Ditto.
            (vaesdec_<mode>): Ditto.
            (vaesdeclast_<mode>): Ditto.
            (vaesenc_<mode>):: Ditto.
            (vaesenclast_<mode>):: Ditto.
            (aes<aesklvariant>u8): Ditto.
            (*aes<aeswideklvariant>u8): Ditto.
    
    gcc/testsuite/ChangeLog:
    
            PR target/119425
            * gcc.target/i386/pr119425.c: New test.
    
            Co-authered-by: Hongyu Wang <hongyu.w...@intel.com>

Diff:
---
 gcc/config/i386/sse.md                   | 31 ++++++++++++++++----------
 gcc/testsuite/gcc.target/i386/pr119425.c | 37 ++++++++++++++++++++++++++++++++
 2 files changed, 57 insertions(+), 11 deletions(-)

diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md
index ee2a482fb509..ed5ac1abe80d 100644
--- a/gcc/config/i386/sse.md
+++ b/gcc/config/i386/sse.md
@@ -11904,7 +11904,7 @@
           ]
           (const_string "ssemov")))
    (set (attr "addr")
-     (if_then_else (eq_attr "alternative" "8,9")
+     (if_then_else (eq_attr "alternative" "9,10")
                   (const_string "gpr16")
                   (const_string "*")))
    (set (attr "prefix_extra")
@@ -20173,6 +20173,7 @@
   return "vshuf<shuffletype>64x2\t{%3, %2, %1, 
%0<mask_operand7>|%0<mask_operand7>, %1, %2, %3}";
 }
   [(set_attr "type" "sselog")
+   (set_attr "addr" "gpr16,*")
    (set_attr "length_immediate" "1")
    (set_attr "prefix" "evex")
    (set_attr "mode" "XI")])
@@ -20334,6 +20335,7 @@
   return "vshuf<shuffletype>32x4\t{%3, %2, %1, 
%0<mask_operand11>|%0<mask_operand11>, %1, %2, %3}";
 }
   [(set_attr "type" "sselog")
+   (set_attr "addr" "gpr16,*")
    (set_attr "length_immediate" "1")
    (set_attr "prefix" "evex")
    (set_attr "mode" "<sseinsnmode>")])
@@ -24076,6 +24078,7 @@
   "TARGET_AVX2"
   "vpblendd\t{%3, %2, %1, %0|%0, %1, %2, %3}"
   [(set_attr "type" "ssemov")
+   (set_attr "addr" "gpr16")
    (set_attr "prefix_extra" "1")
    (set_attr "length_immediate" "1")
    (set_attr "prefix" "vex")
@@ -27085,7 +27088,7 @@
    vaesenc\t{%2, %1, %0|%0, %1, %2}"
   [(set_attr "isa" "noavx,avx,vaes_avx512vl")
    (set_attr "type" "sselog1")
-   (set_attr "addr" "gpr16,*,*")
+   (set_attr "addr" "gpr16,gpr16,*")
    (set_attr "prefix_extra" "1")
    (set_attr "prefix" "orig,maybe_evex,evex")
    (set_attr "btver2_decode" "double,double,double")
@@ -27103,7 +27106,7 @@
    vaesenclast\t{%2, %1, %0|%0, %1, %2}"
   [(set_attr "isa" "noavx,avx,vaes_avx512vl")
    (set_attr "type" "sselog1")
-   (set_attr "addr" "gpr16,*,*")
+   (set_attr "addr" "gpr16,gpr16,*")
    (set_attr "prefix_extra" "1")
    (set_attr "prefix" "orig,maybe_evex,evex")
    (set_attr "btver2_decode" "double,double,double")
@@ -27121,7 +27124,7 @@
    vaesdec\t{%2, %1, %0|%0, %1, %2}"
   [(set_attr "isa" "noavx,avx,vaes_avx512vl")
    (set_attr "type" "sselog1")
-   (set_attr "addr" "gpr16,*,*")
+   (set_attr "addr" "gpr16,gpr16,*")
    (set_attr "prefix_extra" "1")
    (set_attr "prefix" "orig,maybe_evex,evex")
    (set_attr "btver2_decode" "double,double,double") 
@@ -27138,7 +27141,7 @@
    * return TARGET_AES ? \"vaesdeclast\t{%2, %1, %0|%0, %1, %2}\" : \"%{evex%} 
vaesdeclast\t{%2, %1, %0|%0, %1, %2}\";
    vaesdeclast\t{%2, %1, %0|%0, %1, %2}"
   [(set_attr "isa" "noavx,avx,vaes_avx512vl")
-   (set_attr "addr" "gpr16,*,*")
+   (set_attr "addr" "gpr16,gpr16,*")
    (set_attr "type" "sselog1")
    (set_attr "prefix_extra" "1")
    (set_attr "prefix" "orig,maybe_evex,evex")
@@ -30841,7 +30844,8 @@
     return "%{evex%} vaesdec\t{%2, %1, %0|%0, %1, %2}";
   else
     return "vaesdec\t{%2, %1, %0|%0, %1, %2}";
-})
+}
+[(set_attr "addr" "gpr16,*")])
 
 (define_insn "vaesdeclast_<mode>"
   [(set (match_operand:VI1_AVX512VL_F 0 "register_operand" "=x,v")
@@ -30855,7 +30859,8 @@
     return "%{evex%} vaesdeclast\t{%2, %1, %0|%0, %1, %2}";
   else
     return "vaesdeclast\t{%2, %1, %0|%0, %1, %2}";
-})
+}
+[(set_attr "addr" "gpr16,*")])
 
 (define_insn "vaesenc_<mode>"
   [(set (match_operand:VI1_AVX512VL_F 0 "register_operand" "=x,v")
@@ -30869,7 +30874,8 @@
     return "%{evex%} vaesenc\t{%2, %1, %0|%0, %1, %2}";
   else
     return "vaesenc\t{%2, %1, %0|%0, %1, %2}";
-})
+}
+[(set_attr "addr" "gpr16,*")])
 
 (define_insn "vaesenclast_<mode>"
   [(set (match_operand:VI1_AVX512VL_F 0 "register_operand" "=x,v")
@@ -30883,7 +30889,8 @@
     return "%{evex%} vaesenclast\t{%2, %1, %0|%0, %1, %2}";
   else
     return "vaesenclast\t{%2, %1, %0|%0, %1, %2}";
-})
+}
+[(set_attr "addr" "gpr16,*")])
 
 (define_insn "vpclmulqdq_<mode>"
   [(set (match_operand:VI8_FVL 0 "register_operand" "=v")
@@ -31330,7 +31337,8 @@
        (unspec_volatile:CCZ [(match_dup 1) (match_dup 2)] AESDECENCKL))]
   "TARGET_KL"
   "aes<aesklvariant>\t{%2, %0|%0, %2}"
-  [(set_attr "type" "other")])
+  [(set_attr "type" "other")
+   (set_attr "addr" "gpr16")])
 
 (define_int_iterator AESDECENCWIDEKL
   [UNSPECV_AESDECWIDE128KLU8  UNSPECV_AESDECWIDE256KLU8
@@ -31392,7 +31400,8 @@
            AESDECENCWIDEKL))])]
   "TARGET_WIDEKL"
   "aes<aeswideklvariant>\t%0"
-  [(set_attr "type" "other")])
+  [(set_attr "type" "other")
+   (set_attr "addr" "gpr16")])
 
 ;; Modes handled by broadcast patterns.  NB: Allow V64QI and V32HI with
 ;; TARGET_AVX512F since ix86_expand_vector_init_duplicate can expand
diff --git a/gcc/testsuite/gcc.target/i386/pr119425.c 
b/gcc/testsuite/gcc.target/i386/pr119425.c
new file mode 100644
index 000000000000..b926979dcac3
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr119425.c
@@ -0,0 +1,37 @@
+/* PR target/119425  */
+/* { dg-do compile { target { ! ia32 } } } */
+/* { dg-options "-Os -fno-vect-cost-model -ftree-slp-vectorize -mavxneconvert 
-mapxf" } */
+extern long K512[];
+extern long sha512_block_data_order_ctx[];
+
+#define Ch(x, y, z) ~x &z
+#define ROUND_00_15(i, a, b, c, d, e, f, g, h)                                 
\
+  T1 += ~e & g + K512[i];                                                  \
+h = 0;                                                               \
+d += h += T1
+#define ROUND_16_80(i, j, a, b, c, d, e, f, g, h, X)                           
\
+  ROUND_00_15(i + j, , , , d, e, , g, h)
+
+unsigned sha512_block_data_order_f, sha512_block_data_order_g;
+
+void
+sha512_block_data_order()
+{
+  unsigned a, b, c, d, e, h, T1;
+  int i = 6;
+  for (; i < 80; i += 6) {
+      ROUND_16_80(i, 0, , , , d, e, , , h, );
+      ROUND_16_80(i, 11, , , , a, b, , d, e, );
+      ROUND_16_80(i, 12, , , , h, a, , c, d, );
+      ROUND_16_80(i, 13, , , , sha512_block_data_order_g, h, , b, c, );
+      ROUND_16_80(i, 14, , , , sha512_block_data_order_f,
+                 sha512_block_data_order_g, , a, b, );
+      ROUND_16_80(i, 15, , , , e, sha512_block_data_order_f, , , a, );
+
+  }
+  sha512_block_data_order_ctx[0] += a;
+  sha512_block_data_order_ctx[1] += b;
+  sha512_block_data_order_ctx[2] += c;
+  sha512_block_data_order_ctx[3] += d;
+
+}

Reply via email to