diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 6fea3c6b649..4bab9ff9a23 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2007-04-26 Andrew Pinski + + PR C++/30016 + * typeck.c (build_reinterpret_cast_1): Only allow conversion to + integeral types from vectors types. + 2007-04-26 Jakub Jelinek PR c++/31598 diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c index 7e816f102f7..2b4e065913c 100644 --- a/gcc/cp/typeck.c +++ b/gcc/cp/typeck.c @@ -5341,7 +5341,7 @@ build_reinterpret_cast_1 (tree type, tree expr, bool c_cast_p, } else if (TREE_CODE (type) == VECTOR_TYPE) return fold_if_not_in_template (convert_to_vector (type, expr)); - else if (TREE_CODE (intype) == VECTOR_TYPE) + else if (TREE_CODE (intype) == VECTOR_TYPE && INTEGRAL_TYPE_P (type)) return fold_if_not_in_template (convert_to_integer (type, expr)); else { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8a0172b0dfc..6b7bcc7d67e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2007-04-26 Andrew Pinski + + PR C++/30016 + * g++.dg/ext/vector6.C: New test. + 2007-04-26 Kazu Hirata * gcc.c-torture/execute/ieee/20000320-1.x: New. diff --git a/gcc/testsuite/g++.dg/ext/vector6.C b/gcc/testsuite/g++.dg/ext/vector6.C new file mode 100644 index 00000000000..9caf8c2f69a --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/vector6.C @@ -0,0 +1,12 @@ +// { dg-options "" } +// { dg-do compile } +// C++/30016, we were allowing conversion between vector types +// and union types which is invalid. + +typedef float __v_4F __attribute__ ((vector_size (16))); +typedef union {__v_4F v; float a[4];} __v4F; +void f(void) +{ + __v_4F b; + (reinterpret_cast<__v4F>(b).a)[1] = 1; // { dg-error "" } +}