From 7d014acc1ea263df7ed44aa6cb7f75bb8e512aed Mon Sep 17 00:00:00 2001 From: Uros Bizjak Date: Wed, 27 May 2020 21:02:51 +0200 Subject: [PATCH] i386: Remove %q modifier from two pmov insn templates [PR95355] MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit 2020-05-27 Uroš Bizjak gcc/ChangeLog: PR target/95355 * config/i386/sse.md (avx512f_v16qiv16si2): Remove %q operand modifier from insn template. (avx512f_v8hiv8di2): Ditto. gcc/testsuite/ChangeLog: PR target/95355 * gcc.target/i386/pr95355.c: New test. --- gcc/config/i386/sse.md | 4 ++-- gcc/testsuite/gcc.target/i386/pr95355.c | 20 ++++++++++++++++++++ 2 files changed, 22 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/gcc.target/i386/pr95355.c diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md index fde6539..1cf1b8c 100644 --- a/gcc/config/i386/sse.md +++ b/gcc/config/i386/sse.md @@ -17559,7 +17559,7 @@ (any_extend:V16SI (match_operand:V16QI 1 "nonimmediate_operand" "vm")))] "TARGET_AVX512F" - "vpmovbd\t{%1, %0|%0, %q1}" + "vpmovbd\t{%1, %0|%0, %1}" [(set_attr "type" "ssemov") (set_attr "prefix" "evex") (set_attr "mode" "XI")]) @@ -17935,7 +17935,7 @@ (any_extend:V8DI (match_operand:V8HI 1 "nonimmediate_operand" "vm")))] "TARGET_AVX512F" - "vpmovwq\t{%1, %0|%0, %q1}" + "vpmovwq\t{%1, %0|%0, %1}" [(set_attr "type" "ssemov") (set_attr "prefix" "evex") (set_attr "mode" "XI")]) diff --git a/gcc/testsuite/gcc.target/i386/pr95355.c b/gcc/testsuite/gcc.target/i386/pr95355.c new file mode 100644 index 0000000..3e4faba --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/pr95355.c @@ -0,0 +1,20 @@ +/* PR target/95355 */ +/* { dg-do assemble { target avx512dq } } */ +/* { dg-require-effective-target int128 } */ +/* { dg-require-effective-target masm_intel } */ +/* { dg-options "-O -fno-tree-dominator-opts -fno-tree-fre -ftree-slp-vectorize -fno-tree-ter -mavx512dq -masm=intel" } */ + +typedef int __attribute__((__vector_size__(64))) U; +typedef __int128 __attribute__((__vector_size__(32))) V; + +U i; +V j; + +int +foo(unsigned char l) +{ + V m = j % 999; + U n = l <= i; + V o = ((union { U a; V b[2]; }) n).b[0] + m; + return o[0]; +} -- 2.7.4