re PR target/23575 (ICE: output_operand: unterminated assembly dialect alternative)
authorRichard Guenther <rguenther@suse.de>
Sat, 27 Aug 2005 12:04:28 +0000 (12:04 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Sat, 27 Aug 2005 12:04:28 +0000 (12:04 +0000)
2005-08-27  Richard Guenther  <rguenther@gcc.gnu.org>

PR target/23575
* config/i386/sse.md (sse2_movsd): Add missing closing
braces.

* gcc.target/i386/pr23575.c: New testcase.

From-SVN: r103559

gcc/ChangeLog
gcc/config/i386/sse.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/pr23575.c [new file with mode: 0644]

index 911b188df4ba0dbf0b53f986f5cfbb8955364025..c8123f27dc25d53c04c92d1bba648408607fa0da 100644 (file)
@@ -1,3 +1,9 @@
+2005-08-27  Richard Guenther  <rguenther@suse.de>
+
+       PR target/23575
+       * config/i386/sse.md (sse2_movsd): Add missing closing
+       braces.
+
 2005-08-27  Paul Brook  <paul@codesourcery.com>
 
        * genrecog.c (enum decision_type): Add DT_num_insns.
index 0e0a7d3001359c10165f681f6c21bd20e6876732..4bd10400473d6bd212225f91c5321ea69bd81131 100644 (file)
    movlpd\t{%2, %0|%0, %2}
    movlpd\t{%2, %0|%0, %2}
    shufpd\t{$2, %2, %0|%0, %2, 2}
-   movhps\t{%H1, %0|%0, %H1
-   movhps\t{%1, %H0|%H0, %1"
+   movhps\t{%H1, %0|%0, %H1}
+   movhps\t{%1, %H0|%H0, %1}"
   [(set_attr "type" "ssemov,ssemov,ssemov,sselog,ssemov,ssemov")
    (set_attr "mode" "DF,V1DF,V1DF,V2DF,V1DF,V1DF")])
 
index c29bcc020ac1b7f89b50a8f38a591e3e2c32f89e..be6077d61638a77a563890613cd89face43d7ecc 100644 (file)
@@ -1,3 +1,8 @@
+2005-08-27  Richard Guenther  <rguenther@suse.de>
+
+       PR target/23575
+       * gcc.target/i386/pr23575.c: New testcase.
+
 2005-08-26  Jakub Jelinek  <jakub@redhat.com>
 
        PR rtl-optimization/23561
diff --git a/gcc/testsuite/gcc.target/i386/pr23575.c b/gcc/testsuite/gcc.target/i386/pr23575.c
new file mode 100644 (file)
index 0000000..d148dcb
--- /dev/null
@@ -0,0 +1,20 @@
+/* { dg-do compile } */
+/* { dg-options "-march=pentium4 -O2" } */
+
+/* We used to ICE because of a bogous pattern.  */
+
+typedef double __v2df __attribute__ ((__vector_size__ (16)));
+typedef __v2df __m128d;
+static __inline __m128d __attribute__((__always_inline__)) _mm_set1_pd (double __F) {
+  return __extension__ (__m128d){__F, __F};
+}
+static __inline __m128d __attribute__((__always_inline__)) _mm_move_sd (__m128d __A, __m128d __B) {
+  return (__m128d) __builtin_ia32_movsd ((__v2df)__A, (__v2df)__B);
+}
+void g(__m128d b);
+__m128d cross(__m128d tmp9)
+{
+  __m128d t1 = _mm_set1_pd(1.0);
+  __m128d tmp10 = _mm_move_sd(t1, tmp9);
+  return tmp10;
+}