---
gcc/ChangeLog:

        * config/i386/avx10_v2_auxintrin.h (__attribute__):
        (_mm_cvtbf8_bf6s):
        (_mm256_cvtbf8_bf6s):
        (_mm512_cvtbf8_bf6s):
        (_mm_cvthf8_hf6s):
        (_mm256_cvthf8_hf6s):
        (_mm512_cvthf8_hf6s):
        (_mm_cvtbf6_hf8):
        (_mm_mask_cvtbf6_hf8):
        (_mm_maskz_cvtbf6_hf8):
        (_mm256_cvtbf6_hf8):
        (_mm256_mask_cvtbf6_hf8):
        (_mm256_maskz_cvtbf6_hf8):
        (_mm512_cvtbf6_hf8):
        (_mm512_mask_cvtbf6_hf8):
        (_mm512_maskz_cvtbf6_hf8):
        (_mm_cvthf6_hf8):
        (_mm_mask_cvthf6_hf8):
        (_mm_maskz_cvthf6_hf8):
        (_mm256_cvthf6_hf8):
        (_mm256_mask_cvthf6_hf8):
        (_mm256_maskz_cvthf6_hf8):
        (_mm512_cvthf6_hf8):
        (_mm512_mask_cvthf6_hf8):
        (_mm512_maskz_cvthf6_hf8):
        * config/i386/i386-builtin.def (BDESC):
        * config/i386/sse.md (vcvt<convertfp82fp6><mode>):
        (vcvt<convertfp62hf8><mode>):
        (vcvt<convertfp62hf8><mode>_mask):
        (*vcvt<convertfp62hf8><mode>_mask):

gcc/testsuite/ChangeLog:

        * gcc.target/i386/avx10_2-v2-aux-convert-7.c: New test.
        * gcc.target/i386/avx10_2-v2-aux-convert-8.c: New test.

 gcc/config/i386/avx10_v2_auxintrin.h          | 196 ++++++++++++++++++
 gcc/config/i386/i386-builtin.def              |  12 ++
 gcc/config/i386/sse.md                        |  72 +++++++
 .../i386/avx10_2-v2-aux-convert-7.c           |  18 ++
 .../i386/avx10_2-v2-aux-convert-8.c           |  46 ++++
 5 files changed, 344 insertions(+)
 create mode 100644 gcc/testsuite/gcc.target/i386/avx10_2-v2-aux-convert-7.c
 create mode 100644 gcc/testsuite/gcc.target/i386/avx10_2-v2-aux-convert-8.c

diff --git a/gcc/config/i386/avx10_v2_auxintrin.h 
b/gcc/config/i386/avx10_v2_auxintrin.h
index 0570fe9a738..c53ecf3f3d7 100644
--- a/gcc/config/i386/avx10_v2_auxintrin.h
+++ b/gcc/config/i386/avx10_v2_auxintrin.h
@@ -1271,6 +1271,202 @@ _mm512_maskz_cvtbf4_hf8(__mmask64 __U, __m256i __A) {
                                                 (__mmask64) __U);
 }
 
+// VCVTBF82BF6S
+
+extern __inline __m128i 
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm_cvtbf8_bf6s(__m128i __A) {
+  return (__m128i) __builtin_ia32_vcvtbf82bf6s128((__v16qi)__A);
+}
+
+extern __inline __m256i 
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm256_cvtbf8_bf6s(__m256i __A) {
+  return (__m256i) __builtin_ia32_vcvtbf82bf6s256((__v32qi)__A);
+}
+
+extern __inline __m512i 
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm512_cvtbf8_bf6s(__m512i __A) {
+  return (__m512i) __builtin_ia32_vcvtbf82bf6s512((__v64qi)__A);
+}
+
+// VCVTHF82HF6S
+
+extern __inline __m128i 
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm_cvthf8_hf6s(__m128i __A) {
+  return (__m128i) __builtin_ia32_vcvthf82hf6s128((__v16qi)__A);
+}
+
+extern __inline __m256i 
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm256_cvthf8_hf6s(__m256i __A) {
+  return (__m256i) __builtin_ia32_vcvthf82hf6s256((__v32qi)__A);
+}
+
+extern __inline __m512i 
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm512_cvthf8_hf6s(__m512i __A) {
+  return (__m512i) __builtin_ia32_vcvthf82hf6s512((__v64qi)__A);
+}
+
+// VCVTBF62HF8 - 128-bit
+
+extern __inline __m128i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm_cvtbf6_hf8(__m128i __A) {
+  return (__m128i) __builtin_ia32_vcvtbf62hf8128_mask((__v16qi)__A,
+                                                (__v16qi) _mm_undefined_si128 
(),
+                                                (__mmask16) -1);
+}
+
+extern __inline __m128i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm_mask_cvtbf6_hf8(__m128i __W, __mmask16 __U, __m128i __A) {
+  return (__m128i) __builtin_ia32_vcvtbf62hf8128_mask((__v16qi)__A,
+                                                (__v16qi) __W,
+                                                (__mmask16) __U);
+}
+
+extern __inline __m128i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm_maskz_cvtbf6_hf8(__mmask16 __U, __m128i __A) {
+  return (__m128i) __builtin_ia32_vcvtbf62hf8128_mask((__v16qi)__A,
+                                                (__v16qi) _mm_setzero_si128 (),
+                                                (__mmask16) __U);
+}
+
+// VCVTBF62HF8 - 256-bit
+
+extern __inline __m256i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm256_cvtbf6_hf8(__m256i __A) {
+  return (__m256i) __builtin_ia32_vcvtbf62hf8256_mask((__v32qi)__A,
+                                                (__v32qi) 
_mm256_undefined_si256 (),
+                                                (__mmask32) -1);
+}
+
+extern __inline __m256i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm256_mask_cvtbf6_hf8(__m256i __W, __mmask32 __U, __m256i __A) {
+  return (__m256i) __builtin_ia32_vcvtbf62hf8256_mask((__v32qi)__A,
+                                                (__v32qi) __W,
+                                                (__mmask32) __U);
+}
+
+extern __inline __m256i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm256_maskz_cvtbf6_hf8(__mmask32 __U, __m256i __A) {
+  return (__m256i) __builtin_ia32_vcvtbf62hf8256_mask((__v32qi)__A,
+                                                (__v32qi) _mm256_setzero_si256 
(),
+                                                (__mmask32) __U);
+}
+
+// VCVTBF62HF8 - 512-bit
+
+extern __inline __m512i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm512_cvtbf6_hf8(__m512i __A) {
+  return (__m512i) __builtin_ia32_vcvtbf62hf8512_mask((__v64qi)__A,
+                                                (__v64qi) 
_mm512_undefined_epi32 (),
+                                                (__mmask64) -1);
+}
+
+extern __inline __m512i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm512_mask_cvtbf6_hf8(__m512i __W, __mmask64 __U, __m512i __A) {
+  return (__m512i) __builtin_ia32_vcvtbf62hf8512_mask((__v64qi)__A,
+                                                (__v64qi) __W,
+                                                (__mmask64) __U);
+}
+
+extern __inline __m512i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm512_maskz_cvtbf6_hf8(__mmask64 __U, __m512i __A) {
+  return (__m512i) __builtin_ia32_vcvtbf62hf8512_mask((__v64qi)__A,
+                                                (__v64qi) _mm512_setzero_si512 
(),
+                                                (__mmask64) __U);
+}
+
+// VCVTHF62HF8 - 128-bit
+
+extern __inline __m128i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm_cvthf6_hf8(__m128i __A) {
+  return (__m128i) __builtin_ia32_vcvthf62hf8128_mask((__v16qi)__A,
+                                                (__v16qi) _mm_undefined_si128 
(),
+                                                (__mmask16) -1);
+}
+
+extern __inline __m128i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm_mask_cvthf6_hf8(__m128i __W, __mmask16 __U, __m128i __A) {
+  return (__m128i) __builtin_ia32_vcvthf62hf8128_mask((__v16qi)__A,
+                                                (__v16qi) __W,
+                                                (__mmask16) __U);
+}
+
+extern __inline __m128i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm_maskz_cvthf6_hf8(__mmask16 __U, __m128i __A) {
+  return (__m128i) __builtin_ia32_vcvthf62hf8128_mask((__v16qi)__A,
+                                                (__v16qi) _mm_setzero_si128 (),
+                                                (__mmask16) __U);
+}
+
+// VCVTHF62HF8 - 256-bit
+
+extern __inline __m256i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm256_cvthf6_hf8(__m256i __A) {
+  return (__m256i) __builtin_ia32_vcvthf62hf8256_mask((__v32qi)__A,
+                                                (__v32qi) 
_mm256_undefined_si256 (),
+                                                (__mmask32) -1);
+}
+
+extern __inline __m256i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm256_mask_cvthf6_hf8(__m256i __W, __mmask32 __U, __m256i __A) {
+  return (__m256i) __builtin_ia32_vcvthf62hf8256_mask((__v32qi)__A,
+                                                (__v32qi) __W,
+                                                (__mmask32) __U);
+}
+
+extern __inline __m256i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm256_maskz_cvthf6_hf8(__mmask32 __U, __m256i __A) {
+  return (__m256i) __builtin_ia32_vcvthf62hf8256_mask((__v32qi)__A,
+                                                (__v32qi) _mm256_setzero_si256 
(),
+                                                (__mmask32) __U);
+}
+
+// VCVTHF62HF8 - 512-bit
+
+extern __inline __m512i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm512_cvthf6_hf8(__m512i __A) {
+  return (__m512i) __builtin_ia32_vcvthf62hf8512_mask((__v64qi)__A,
+                                                (__v64qi) 
_mm512_undefined_epi32 (),
+                                                (__mmask64) -1);
+}
+
+extern __inline __m512i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm512_mask_cvthf6_hf8(__m512i __W, __mmask64 __U, __m512i __A) {
+  return (__m512i) __builtin_ia32_vcvthf62hf8512_mask((__v64qi)__A,
+                                                (__v64qi) __W,
+                                                (__mmask64) __U);
+}
+
+extern __inline __m512i
+__attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
+_mm512_maskz_cvthf6_hf8(__mmask64 __U, __m512i __A) {
+  return (__m512i) __builtin_ia32_vcvthf62hf8512_mask((__v64qi)__A,
+                                                (__v64qi) _mm512_setzero_si512 
(),
+                                                (__mmask64) __U);
+}
+
 #ifdef __DISABLE_AVX10_V2_AUX__
 #undef __DISABLE_AVX10_V2_AUX__
 #pragma GCC pop_options
diff --git a/gcc/config/i386/i386-builtin.def b/gcc/config/i386/i386-builtin.def
index 1f50fde62e0..865e5a57b6e 100644
--- a/gcc/config/i386/i386-builtin.def
+++ b/gcc/config/i386/i386-builtin.def
@@ -3415,6 +3415,18 @@ BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, 
CODE_FOR_vcvthf82bf4sv64qi, "__builtin_
 BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf42hf8v16qi_mask, 
"__builtin_ia32_vcvtbf42hf8128_mask", IX86_BUILTIN_VCVTBF42HF8128_MASK, 
UNKNOWN, (int) V16QI_FTYPE_V16QI_V16QI_UHI)
 BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf42hf8v32qi_mask, 
"__builtin_ia32_vcvtbf42hf8256_mask", IX86_BUILTIN_VCVTBF42HF8256_MASK, 
UNKNOWN, (int) V32QI_FTYPE_V16QI_V32QI_USI)
 BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf42hf8v64qi_mask, 
"__builtin_ia32_vcvtbf42hf8512_mask", IX86_BUILTIN_VCVTBF42HF8512_MASK, 
UNKNOWN, (int) V64QI_FTYPE_V32QI_V64QI_UDI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf82bf6sv16qi, 
"__builtin_ia32_vcvtbf82bf6s128", IX86_BUILTIN_VCVTBF82BF6S128, UNKNOWN, (int) 
V16QI_FTYPE_V16QI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf82bf6sv32qi, 
"__builtin_ia32_vcvtbf82bf6s256", IX86_BUILTIN_VCVTBF82BF6S256, UNKNOWN, (int) 
V32QI_FTYPE_V32QI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf82bf6sv64qi, 
"__builtin_ia32_vcvtbf82bf6s512", IX86_BUILTIN_VCVTBF82BF6S512, UNKNOWN, (int) 
V64QI_FTYPE_V64QI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvthf82hf6sv16qi, 
"__builtin_ia32_vcvthf82hf6s128", IX86_BUILTIN_VCVTHF82HF6S128, UNKNOWN, (int) 
V16QI_FTYPE_V16QI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvthf82hf6sv32qi, 
"__builtin_ia32_vcvthf82hf6s256", IX86_BUILTIN_VCVTHF82HF6S256, UNKNOWN, (int) 
V32QI_FTYPE_V32QI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvthf82hf6sv64qi, 
"__builtin_ia32_vcvthf82hf6s512", IX86_BUILTIN_VCVTHF82HF6S512, UNKNOWN, (int) 
V64QI_FTYPE_V64QI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf62hf8v16qi_mask, 
"__builtin_ia32_vcvtbf62hf8128_mask", IX86_BUILTIN_VCVTBF62HF8128_MASK, 
UNKNOWN, (int) V16QI_FTYPE_V16QI_V16QI_UHI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf62hf8v32qi_mask, 
"__builtin_ia32_vcvtbf62hf8256_mask", IX86_BUILTIN_VCVTBF62HF8256_MASK, 
UNKNOWN, (int) V32QI_FTYPE_V32QI_V32QI_USI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvtbf62hf8v64qi_mask, 
"__builtin_ia32_vcvtbf62hf8512_mask", IX86_BUILTIN_VCVTBF62HF8512_MASK, 
UNKNOWN, (int) V64QI_FTYPE_V64QI_V64QI_UDI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvthf62hf8v16qi_mask, 
"__builtin_ia32_vcvthf62hf8128_mask", IX86_BUILTIN_VCVTHF62HF8128_MASK, 
UNKNOWN, (int) V16QI_FTYPE_V16QI_V16QI_UHI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvthf62hf8v32qi_mask, 
"__builtin_ia32_vcvthf62hf8256_mask", IX86_BUILTIN_VCVTHF62HF8256_MASK, 
UNKNOWN, (int) V32QI_FTYPE_V32QI_V32QI_USI)
+BDESC (0, OPTION_MASK_ISA2_AVX10_V2_AUX, CODE_FOR_vcvthf62hf8v64qi_mask, 
"__builtin_ia32_vcvthf62hf8512_mask", IX86_BUILTIN_VCVTHF62HF8512_MASK, 
UNKNOWN, (int) V64QI_FTYPE_V64QI_V64QI_UDI)
 
 /* Builtins with rounding support.  */
 BDESC_END (ARGS, ROUND_ARGS)
diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md
index 0e3bcc8db37..3db68d0b117 100644
--- a/gcc/config/i386/sse.md
+++ b/gcc/config/i386/sse.md
@@ -275,6 +275,10 @@
   UNSPEC_VCVTBF82BF4S
   UNSPEC_VCVTHF82BF4S
   UNSPEC_VCVTBF42HF8
+  UNSPEC_VCVTBF82BF6S
+  UNSPEC_VCVTHF82HF6S
+  UNSPEC_VCVTBF62HF8
+  UNSPEC_VCVTHF62HF8
 ])
 
 (define_c_enum "unspecv" [
@@ -34064,3 +34068,71 @@
   "vcvtbf42hf8\t{%1, %0%{%3%}%N2|%0%{%3%}%N2, %1}"
   [(set_attr "prefix" "evex")
    (set_attr "mode" "<sseinsnmode>")])
+
+;; FP8 to FP6 converts (VCVTBF82BF6S, VCVTHF82HF6S) - no masking
+
+(define_int_iterator UNSPEC_CONVERTFP82FP6
+  [UNSPEC_VCVTBF82BF6S UNSPEC_VCVTHF82HF6S])
+
+(define_int_attr convertfp82fp6
+  [(UNSPEC_VCVTBF82BF6S "bf82bf6s")
+   (UNSPEC_VCVTHF82HF6S "hf82hf6s")])
+
+(define_insn "vcvt<convertfp82fp6><mode>"
+  [(set (match_operand:VI1_AVX512VL 0 "register_operand" "=v")
+       (unspec:VI1_AVX512VL
+         [(match_operand:VI1_AVX512VL 1 "register_operand" "v")]
+         UNSPEC_CONVERTFP82FP6))]
+  "TARGET_AVX10_V2_AUX"
+  "vcvt<convertfp82fp6>\t{%1, %0|%0, %1}"
+  [(set_attr "prefix" "evex")
+   (set_attr "mode" "<sseinsnmode>")])
+
+;; FP6 to FP8 converts (VCVTBF62HF8, VCVTHF62HF8) with masking
+
+(define_int_iterator UNSPEC_CONVERTFP62HF8
+  [UNSPEC_VCVTBF62HF8 UNSPEC_VCVTHF62HF8])
+
+(define_int_attr convertfp62hf8
+  [(UNSPEC_VCVTBF62HF8 "bf62hf8")
+   (UNSPEC_VCVTHF62HF8 "hf62hf8")])
+
+(define_insn "vcvt<convertfp62hf8><mode>"
+  [(set (match_operand:VI1_AVX512VL 0 "register_operand" "=v")
+       (unspec:VI1_AVX512VL
+         [(match_operand:VI1_AVX512VL 1 "register_operand" "v")]
+         UNSPEC_CONVERTFP62HF8))]
+  "TARGET_AVX10_V2_AUX"
+  "vcvt<convertfp62hf8>\t{%1, %0|%0, %1}"
+  [(set_attr "prefix" "evex")
+   (set_attr "mode" "<sseinsnmode>")])
+
+(define_expand "vcvt<convertfp62hf8><mode>_mask"
+  [(set (match_operand:VI1_AVX512VL 0 "register_operand")
+       (vec_merge:VI1_AVX512VL
+         (unspec:VI1_AVX512VL
+           [(match_operand:VI1_AVX512VL 1 "register_operand")]
+           UNSPEC_CONVERTFP62HF8)
+         (match_operand:VI1_AVX512VL 2 "nonimm_or_0_operand")
+         (match_operand:<avx512fmaskmode> 3 "register_or_constm1_operand")))]
+  "TARGET_AVX10_V2_AUX"
+{
+  if (CONST_INT_P (operands[3]))
+    {
+      emit_insn (gen_vcvt<convertfp62hf8><mode> (operands[0], operands[1]));
+      DONE;
+    }
+})
+
+(define_insn "*vcvt<convertfp62hf8><mode>_mask"
+  [(set (match_operand:VI1_AVX512VL 0 "register_operand" "=v")
+       (vec_merge:VI1_AVX512VL
+         (unspec:VI1_AVX512VL
+           [(match_operand:VI1_AVX512VL 1 "register_operand" "v")]
+           UNSPEC_CONVERTFP62HF8)
+         (match_operand:VI1_AVX512VL 2 "nonimm_or_0_operand" "0C")
+         (match_operand:<avx512fmaskmode> 3 "register_operand" "Yk")))]
+  "TARGET_AVX10_V2_AUX"
+  "vcvt<convertfp62hf8>\t{%1, %0%{%3%}%N2|%0%{%3%}%N2, %1}"
+  [(set_attr "prefix" "evex")
+   (set_attr "mode" "<sseinsnmode>")])
diff --git a/gcc/testsuite/gcc.target/i386/avx10_2-v2-aux-convert-7.c 
b/gcc/testsuite/gcc.target/i386/avx10_2-v2-aux-convert-7.c
new file mode 100644
index 00000000000..6bcecf9ee68
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/avx10_2-v2-aux-convert-7.c
@@ -0,0 +1,18 @@
+/* { dg-do compile } */
+/* { dg-options "-mavx10-v2-aux -O2" } */
+/* { dg-final { scan-assembler-times "vcvtbf82bf6s\[ 
\\t\]+\[^\{\n\]*%xmm\[0-9\]+\[^\n\r]*%xmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf82bf6s\[ 
\\t\]+\[^\{\n\]*%ymm\[0-9\]+\[^\n\r]*%ymm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf82bf6s\[ 
\\t\]+\[^\{\n\]*%zmm\[0-9\]+\[^\n\r]*%zmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf82hf6s\[ 
\\t\]+\[^\{\n\]*%xmm\[0-9\]+\[^\n\r]*%xmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf82hf6s\[ 
\\t\]+\[^\{\n\]*%ymm\[0-9\]+\[^\n\r]*%ymm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf82hf6s\[ 
\\t\]+\[^\{\n\]*%zmm\[0-9\]+\[^\n\r]*%zmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+
+#include <immintrin.h>
+
+__m128i test_mm_cvtbf8_bf6s (__m128i a) { return _mm_cvtbf8_bf6s (a); }
+__m256i test_mm256_cvtbf8_bf6s (__m256i a) { return _mm256_cvtbf8_bf6s (a); }
+__m512i test_mm512_cvtbf8_bf6s (__m512i a) { return _mm512_cvtbf8_bf6s (a); }
+
+__m128i test_mm_cvthf8_hf6s (__m128i a) { return _mm_cvthf8_hf6s (a); }
+__m256i test_mm256_cvthf8_hf6s (__m256i a) { return _mm256_cvthf8_hf6s (a); }
+__m512i test_mm512_cvthf8_hf6s (__m512i a) { return _mm512_cvthf8_hf6s (a); }
diff --git a/gcc/testsuite/gcc.target/i386/avx10_2-v2-aux-convert-8.c 
b/gcc/testsuite/gcc.target/i386/avx10_2-v2-aux-convert-8.c
new file mode 100644
index 00000000000..5015e78b27a
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/avx10_2-v2-aux-convert-8.c
@@ -0,0 +1,46 @@
+/* { dg-do compile } */
+/* { dg-options "-mavx10-v2-aux -O2" } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%xmm\[0-9\]+\[^\n\r]*%xmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%xmm\[0-9\]+\[^\n\r]*%xmm\[0-9\]+\{%k\[1-7\]\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%xmm\[0-9\]+\[^\n\r]*%xmm\[0-9\]+\{%k\[1-7\]\}\{z\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%ymm\[0-9\]+\[^\n\r]*%ymm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%ymm\[0-9\]+\[^\n\r]*%ymm\[0-9\]+\{%k\[1-7\]\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%ymm\[0-9\]+\[^\n\r]*%ymm\[0-9\]+\{%k\[1-7\]\}\{z\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%zmm\[0-9\]+\[^\n\r]*%zmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%zmm\[0-9\]+\[^\n\r]*%zmm\[0-9\]+\{%k\[1-7\]\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvtbf62hf8\[ 
\\t\]+\[^\{\n\]*%zmm\[0-9\]+\[^\n\r]*%zmm\[0-9\]+\{%k\[1-7\]\}\{z\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%xmm\[0-9\]+\[^\n\r]*%xmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%xmm\[0-9\]+\[^\n\r]*%xmm\[0-9\]+\{%k\[1-7\]\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%xmm\[0-9\]+\[^\n\r]*%xmm\[0-9\]+\{%k\[1-7\]\}\{z\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%ymm\[0-9\]+\[^\n\r]*%ymm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%ymm\[0-9\]+\[^\n\r]*%ymm\[0-9\]+\{%k\[1-7\]\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%ymm\[0-9\]+\[^\n\r]*%ymm\[0-9\]+\{%k\[1-7\]\}\{z\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%zmm\[0-9\]+\[^\n\r]*%zmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%zmm\[0-9\]+\[^\n\r]*%zmm\[0-9\]+\{%k\[1-7\]\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+/* { dg-final { scan-assembler-times "vcvthf62hf8\[ 
\\t\]+\[^\{\n\]*%zmm\[0-9\]+\[^\n\r]*%zmm\[0-9\]+\{%k\[1-7\]\}\{z\}(?:\n|\[ 
\\t\]+#)" 1 } } */
+
+#include <immintrin.h>
+
+__m128i test_mm_cvtbf6_hf8 (__m128i a) { return _mm_cvtbf6_hf8 (a); }
+__m128i test_mm_mask_cvtbf6_hf8 (__m128i w, __mmask16 u, __m128i a) { return 
_mm_mask_cvtbf6_hf8 (w, u, a); }
+__m128i test_mm_maskz_cvtbf6_hf8 (__mmask16 u, __m128i a) { return 
_mm_maskz_cvtbf6_hf8 (u, a); }
+
+__m256i test_mm256_cvtbf6_hf8 (__m256i a) { return _mm256_cvtbf6_hf8 (a); }
+__m256i test_mm256_mask_cvtbf6_hf8 (__m256i w, __mmask32 u, __m256i a) { 
return _mm256_mask_cvtbf6_hf8 (w, u, a); }
+__m256i test_mm256_maskz_cvtbf6_hf8 (__mmask32 u, __m256i a) { return 
_mm256_maskz_cvtbf6_hf8 (u, a); }
+
+__m512i test_mm512_cvtbf6_hf8 (__m512i a) { return _mm512_cvtbf6_hf8 (a); }
+__m512i test_mm512_mask_cvtbf6_hf8 (__m512i w, __mmask64 u, __m512i a) { 
return _mm512_mask_cvtbf6_hf8 (w, u, a); }
+__m512i test_mm512_maskz_cvtbf6_hf8 (__mmask64 u, __m512i a) { return 
_mm512_maskz_cvtbf6_hf8 (u, a); }
+
+__m128i test_mm_cvthf6_hf8 (__m128i a) { return _mm_cvthf6_hf8 (a); }
+__m128i test_mm_mask_cvthf6_hf8 (__m128i w, __mmask16 u, __m128i a) { return 
_mm_mask_cvthf6_hf8 (w, u, a); }
+__m128i test_mm_maskz_cvthf6_hf8 (__mmask16 u, __m128i a) { return 
_mm_maskz_cvthf6_hf8 (u, a); }
+
+__m256i test_mm256_cvthf6_hf8 (__m256i a) { return _mm256_cvthf6_hf8 (a); }
+__m256i test_mm256_mask_cvthf6_hf8 (__m256i w, __mmask32 u, __m256i a) { 
return _mm256_mask_cvthf6_hf8 (w, u, a); }
+__m256i test_mm256_maskz_cvthf6_hf8 (__mmask32 u, __m256i a) { return 
_mm256_maskz_cvthf6_hf8 (u, a); }
+
+__m512i test_mm512_cvthf6_hf8 (__m512i a) { return _mm512_cvthf6_hf8 (a); }
+__m512i test_mm512_mask_cvthf6_hf8 (__m512i w, __mmask64 u, __m512i a) { 
return _mm512_mask_cvthf6_hf8 (w, u, a); }
+__m512i test_mm512_maskz_cvthf6_hf8 (__mmask64 u, __m512i a) { return 
_mm512_maskz_cvthf6_hf8 (u, a); }
-- 
2.34.1

Reply via email to