From bd289f543a9d67eec00fb8993b48da80a9c1634d Mon Sep 17 00:00:00 2001 From: Andrew Pinski Date: Wed, 16 Aug 2006 18:56:47 -0700 Subject: [PATCH] re PR c++/28302 (ICE with bit-complement for vectors) 2006-08-16 Andrew Pinski PR c++/28302 * typeck.c (build_unary_op ): Don't call perform_integral_promotions for non integral type 2006-08-16 Andrew Pinski PR C++/28302 * g++.dg/ext/vector3.C: New test. From-SVN: r116205 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/typeck.c | 2 +- gcc/testsuite/ChangeLog | 7 ++++++- gcc/testsuite/g++.dg/ext/vector3.C | 12 ++++++++++++ 4 files changed, 25 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/g++.dg/ext/vector3.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index f69c4ff..cde739d 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2006-08-16 Andrew Pinski + + PR c++/28302 + * typeck.c (build_unary_op ): Don't call + perform_integral_promotions for non integral type + 2006-08-16 Jason Merrill PR c++/28385 diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c index 0ded718..f337328 100644 --- a/gcc/cp/typeck.c +++ b/gcc/cp/typeck.c @@ -3996,7 +3996,7 @@ build_unary_op (enum tree_code code, tree xarg, int noconvert) else if (!(arg = build_expr_type_conversion (WANT_INT | WANT_ENUM, arg, true))) errstring = "wrong type argument to bit-complement"; - else if (!noconvert) + else if (!noconvert && CP_INTEGRAL_TYPE_P (TREE_TYPE (arg))) arg = perform_integral_promotions (arg); break; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 9a6bf56..28ab165 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,4 +1,9 @@ -2006-08-16 Zdenek Dvorak +2006-08-16 Andrew Pinski + + PR C++/28302 + * g++.dg/ext/vector3.C: New test. + +2006-08-16 Zdenek Dvorak PR gcov/profile/26570 * gcc.dg/pr26570.c: New test. diff --git a/gcc/testsuite/g++.dg/ext/vector3.C b/gcc/testsuite/g++.dg/ext/vector3.C new file mode 100644 index 0000000..1a67cf7 --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/vector3.C @@ -0,0 +1,12 @@ +/* { dg-do compile } */ +/* { dg-options "" } */ + +// PR c++/28302 + +int __attribute__((vector_size(8))) x; + +void foo() +{ + ~x; +} + -- 2.7.4