aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2016-03-09 21:06:59 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2016-03-09 21:06:59 +0100
commit3433b975aeba3214e3ce27bcb4078f5aee771782 (patch)
tree5dc111503a16c0d80b1f6fddfe519c409303f5c5 /gcc
parent2bd8090ff56fdf1ca9ed76a9668a30f4e7d8f949 (diff)
downloadgcc-3433b975aeba3214e3ce27bcb4078f5aee771782.zip
gcc-3433b975aeba3214e3ce27bcb4078f5aee771782.tar.gz
gcc-3433b975aeba3214e3ce27bcb4078f5aee771782.tar.bz2
re PR target/70086 (ICE: in extract_constrain_insn_cached, at recog.c:2202 (insn does not satisfy its constraints) with -mavx512vl -ffloat-store)
PR target/70086 * config/i386/i386.md (truncdfsf2 splitter): Use gen_vec_concatv2df instead of gen_sse2_loadlpd. * config/i386/sse.md (*vec_concatv2df): Rename to... (vec_concatv2df): ... this. * gcc.target/i386/pr70086-1.c: New test. * gcc.target/i386/pr70086-2.c: New test. * gcc.target/i386/pr70086-3.c: New test. From-SVN: r234091
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog8
-rw-r--r--gcc/config/i386/i386.md4
-rw-r--r--gcc/config/i386/sse.md2
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/gcc.target/i386/pr70086-1.c11
-rw-r--r--gcc/testsuite/gcc.target/i386/pr70086-2.c21
-rw-r--r--gcc/testsuite/gcc.target/i386/pr70086-3.c21
7 files changed, 69 insertions, 5 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 1f91bb1..b7140a6 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,4 +1,10 @@
-2016-03-08 Jakub Jelinek <jakub@redhat.com>
+2016-03-09 Jakub Jelinek <jakub@redhat.com>
+
+ PR target/70086
+ * config/i386/i386.md (truncdfsf2 splitter): Use gen_vec_concatv2df
+ instead of gen_sse2_loadlpd.
+ * config/i386/sse.md (*vec_concatv2df): Rename to...
+ (vec_concatv2df): ... this.
PR tree-optimization/70127
* fold-const.c (operand_equal_p): Revert the 2015-10-28 change.
diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md
index cb8bcec..554e623 100644
--- a/gcc/config/i386/i386.md
+++ b/gcc/config/i386/i386.md
@@ -4393,8 +4393,8 @@
emit_insn (gen_vec_dupv2df (operands[4], operands[1]));
}
else
- emit_insn (gen_sse2_loadlpd (operands[4],
- CONST0_RTX (V2DFmode), operands[1]));
+ emit_insn (gen_vec_concatv2df (operands[4], operands[1],
+ CONST0_RTX (DFmode)));
})
;; It's more profitable to split and then extend in the same register.
diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md
index 00e385a..3c521b3 100644
--- a/gcc/config/i386/sse.md
+++ b/gcc/config/i386/sse.md
@@ -8951,7 +8951,7 @@
(set_attr "prefix" "orig,maybe_vex,evex")
(set_attr "mode" "V2DF,DF,DF")])
-(define_insn "*vec_concatv2df"
+(define_insn "vec_concatv2df"
[(set (match_operand:V2DF 0 "register_operand" "=x,x,v,x,v,x,x,v,x,x")
(vec_concat:V2DF
(match_operand:DF 1 "nonimmediate_operand" " 0,x,v,m,m,0,x,m,0,0")
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index e611b29..e2db34d 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,4 +1,9 @@
-2016-03-08 Jakub Jelinek <jakub@redhat.com>
+2016-03-09 Jakub Jelinek <jakub@redhat.com>
+
+ PR target/70086
+ * gcc.target/i386/pr70086-1.c: New test.
+ * gcc.target/i386/pr70086-2.c: New test.
+ * gcc.target/i386/pr70086-3.c: New test.
PR tree-optimization/70127
* gcc.c-torture/execute/pr70127.c: New test.
diff --git a/gcc/testsuite/gcc.target/i386/pr70086-1.c b/gcc/testsuite/gcc.target/i386/pr70086-1.c
new file mode 100644
index 0000000..7289798
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr70086-1.c
@@ -0,0 +1,11 @@
+/* PR target/70086 */
+/* { dg-do compile } */
+/* { dg-options "-mtune=barcelona -mavx512vl -ffloat-store" } */
+
+float
+foo (float a, float b, double c, float d, double e, float f)
+{
+ e -= d;
+ d *= e;
+ return e + d;
+}
diff --git a/gcc/testsuite/gcc.target/i386/pr70086-2.c b/gcc/testsuite/gcc.target/i386/pr70086-2.c
new file mode 100644
index 0000000..b613d54
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr70086-2.c
@@ -0,0 +1,21 @@
+/* PR target/70086 */
+/* { dg-do compile { target { ! ia32 } } } */
+/* { dg-options "-O2 -mtune=barcelona -mavx512vl" } */
+
+float
+foo (double *p)
+{
+ register float xmm16 __asm ("xmm16");
+ xmm16 = *p;
+ asm volatile ("" : "+v" (xmm16));
+ return xmm16;
+}
+
+float
+bar (double x)
+{
+ register float xmm16 __asm ("xmm16");
+ xmm16 = x;
+ asm volatile ("" : "+v" (xmm16));
+ return xmm16;
+}
diff --git a/gcc/testsuite/gcc.target/i386/pr70086-3.c b/gcc/testsuite/gcc.target/i386/pr70086-3.c
new file mode 100644
index 0000000..ae523a9
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr70086-3.c
@@ -0,0 +1,21 @@
+/* PR target/70086 */
+/* { dg-do compile { target { ! ia32 } } } */
+/* { dg-options "-O2 -mtune=barcelona -mavx512f -mno-avx512vl" } */
+
+float
+foo (double *p)
+{
+ register float xmm16 __asm ("xmm16");
+ xmm16 = *p;
+ asm volatile ("" : "+v" (xmm16));
+ return xmm16;
+}
+
+float
+bar (double x)
+{
+ register float xmm16 __asm ("xmm16");
+ xmm16 = x;
+ asm volatile ("" : "+v" (xmm16));
+ return xmm16;
+}