call.c (standard_conversion): Opaque pointers interconvert.
authorAldy Hernandez <aldyh@redhat.com>
Tue, 12 Aug 2003 14:38:39 +0000 (14:38 +0000)
committerAldy Hernandez <aldyh@gcc.gnu.org>
Tue, 12 Aug 2003 14:38:39 +0000 (14:38 +0000)
2003-08-11  Aldy Hernandez  <aldyh@redhat.com>

        * cp/call.c (standard_conversion): Opaque pointers interconvert.

        * testsuite/g++.dg/other/opaque-3.C: New.

From-SVN: r70371

gcc/cp/ChangeLog
gcc/cp/call.c
gcc/testsuite/g++.dg/other/opaque-3.C [new file with mode: 0644]

index 00412d447ddb69f0dcfa2884771e67ae9791e964..d493d655a5cfa68ee424a2f961fe517427d6bb55 100644 (file)
@@ -1,3 +1,9 @@
+2003-08-11  Aldy Hernandez  <aldyh@redhat.com>
+        * call.c (standard_conversion): Opaque pointers interconvert.
+        * testsuite/g++.dg/other/opaque-3.C: New.
+
 2003-08-11  Mark Mitchell  <mark@codesourcery.com>
 
        * typeck.c (merge_types): Handle cv-qualified pointer-to-member
index 73c8c44ea79ecb498fd42809d42f210d65758af1..9ece67ff52e6d311f2cc817878831638311f4cb2 100644 (file)
@@ -647,6 +647,12 @@ standard_conversion (tree to, tree from, tree expr)
   if ((tcode == POINTER_TYPE || TYPE_PTR_TO_MEMBER_P (to))
       && expr && null_ptr_cst_p (expr))
     conv = build_conv (STD_CONV, to, conv);
+  else if (tcode == POINTER_TYPE && fcode == POINTER_TYPE
+          && TREE_CODE (TREE_TYPE (to)) == VECTOR_TYPE
+          && TREE_CODE (TREE_TYPE (from)) == VECTOR_TYPE
+          && ((*targetm.vector_opaque_p) (TREE_TYPE (to))
+              || (*targetm.vector_opaque_p) (TREE_TYPE (from))))
+    conv = build_conv (STD_CONV, to, conv);
   else if ((tcode == INTEGER_TYPE && fcode == POINTER_TYPE)
           || (tcode == POINTER_TYPE && fcode == INTEGER_TYPE))
     {
diff --git a/gcc/testsuite/g++.dg/other/opaque-3.C b/gcc/testsuite/g++.dg/other/opaque-3.C
new file mode 100644 (file)
index 0000000..18ed0be
--- /dev/null
@@ -0,0 +1,11 @@
+/* { dg-do compile { target powerpc-*-eabi* } } */
+/* { dg-options "-mcpu=8540 -mabi=spe" } */
+
+__ev64_opaque__ o;
+#define v __attribute__((vector_size(8)))
+v unsigned int *p;
+
+void m()
+{
+  o = __builtin_spe_evldd(p, 5);
+}