diff options
author | Haochen Jiang <haochen.jiang@intel.com> | 2023-11-06 14:34:01 +0800 |
---|---|---|
committer | Haochen Jiang <haochen.jiang@intel.com> | 2023-11-08 13:51:25 +0800 |
commit | 078087d1605060da4f993af83b1bfa351b278d38 (patch) | |
tree | 441598ef70c90d8681536ec955847ec26481fde4 | |
parent | f27246b009636aff4733ccfca1a42c3914d7d9c6 (diff) | |
download | gcc-078087d1605060da4f993af83b1bfa351b278d38.zip gcc-078087d1605060da4f993af83b1bfa351b278d38.tar.gz gcc-078087d1605060da4f993af83b1bfa351b278d38.tar.bz2 |
i386: Fix isa attribute for TI/TF andnot mode
gcc/ChangeLog:
PR target/111907
* config/i386/i386.md (avx_noavx512vl): New definition for isa
attribute.
* config/i386/sse.md (*andnot<mode>3): Change isa attribute from
avx_noavx512f to avx_noavx512vl.
gcc/testsuite/ChangeLog:
PR target/111907
* gcc.target/i386/pr111907.c: New test.
-rw-r--r-- | gcc/config/i386/i386.md | 2 | ||||
-rw-r--r-- | gcc/config/i386/sse.md | 2 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/i386/pr111907.c | 8 |
3 files changed, 11 insertions, 1 deletions
diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md index 97ab693..2fc56e7 100644 --- a/gcc/config/i386/i386.md +++ b/gcc/config/i386/i386.md @@ -919,6 +919,8 @@ (eq_attr "isa" "avx") (symbol_ref "TARGET_AVX") (eq_attr "isa" "avx_noavx512f") (symbol_ref "TARGET_AVX && !TARGET_AVX512F") + (eq_attr "isa" "avx_noavx512vl") + (symbol_ref "TARGET_AVX && !TARGET_AVX512VL") (eq_attr "isa" "noavx") (symbol_ref "!TARGET_AVX") (eq_attr "isa" "avx2") (symbol_ref "TARGET_AVX2") (eq_attr "isa" "noavx2") (symbol_ref "!TARGET_AVX2") diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md index e6a5c79..3319875 100644 --- a/gcc/config/i386/sse.md +++ b/gcc/config/i386/sse.md @@ -5169,7 +5169,7 @@ output_asm_insn (buf, operands); return ""; } - [(set_attr "isa" "noavx,avx_noavx512f,avx512vl,avx512f_512") + [(set_attr "isa" "noavx,avx_noavx512vl,avx512vl,avx512f_512") (set_attr "addr" "*,gpr16,*,*") (set_attr "type" "sselog") (set (attr "prefix_data16") diff --git a/gcc/testsuite/gcc.target/i386/pr111907.c b/gcc/testsuite/gcc.target/i386/pr111907.c new file mode 100644 index 0000000..5275e94 --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/pr111907.c @@ -0,0 +1,8 @@ +/* { dg-do compile } */ +/* { dg-options "-mavx512f -mno-evex512" } */ + +_Float128 +foo (_Float128 d, _Float128 e) +{ + return __builtin_copysignf128 (d, e); +} |