From e8f97b70cbd45c8916af5a2ed44b61abf0c30e16 Mon Sep 17 00:00:00 2001 From: Andrew Pinski Date: Wed, 3 Sep 2008 19:27:35 +0000 Subject: [PATCH] re PR middle-end/36445 (ICE in expand_expr_real_1 with -O1 with vector registers) 2008-09-03 Andrew Pinski PR middle-end/36445 * g++.dg/torture/pr36445.C: New test. From-SVN: r139947 --- gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/torture/pr36445.C | 22 ++++++++++++++++++++++ 2 files changed, 27 insertions(+) create mode 100644 gcc/testsuite/g++.dg/torture/pr36445.C diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 3120d1c9e74..70f7eb7b034 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2008-09-03 Andrew Pinski + + PR middle-end/36445 + * g++.dg/torture/pr36445.C: New test. + 2008-09-03 Andrew Pinski PR middle-end/37293 diff --git a/gcc/testsuite/g++.dg/torture/pr36445.C b/gcc/testsuite/g++.dg/torture/pr36445.C new file mode 100644 index 00000000000..39a7a553afd --- /dev/null +++ b/gcc/testsuite/g++.dg/torture/pr36445.C @@ -0,0 +1,22 @@ +/* { dg-do compile } */ +// This used to fail as we would try to expand a VCE where one side had +// a mode of BLKmode and the other side was a vector mode. +#define vector __attribute__((vector_size(16) )) +struct struct1 { + union { float a[3]; } vmx; + struct struct2 { + struct2(const struct2& r) {} + } w; +} __attribute__((aligned(16))); +struct struct3 { + vector float vmx; + operator const struct1& () const{ + return *reinterpret_cast(this); + } +}; +struct3 func3( struct3 V1); +struct3 func2( void ); +void func1( ) { + struct1 vVec = func2() ; + func3 ( (struct3&)vVec ); +}