aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Bergner <bergner@linux.ibm.com>2022-06-17 23:43:23 -0500
committerMartin Liska <mliska@suse.cz>2022-07-28 14:09:02 +0200
commiteee84fda23eaac131f1efe4c9520e77f769371b4 (patch)
treeb966912cd73f037f7e422f633e209f90c4f66e46
parent1758efd9057bc6d1780b02f3b51e10ede233451e (diff)
downloadgcc-eee84fda23eaac131f1efe4c9520e77f769371b4.zip
gcc-eee84fda23eaac131f1efe4c9520e77f769371b4.tar.gz
gcc-eee84fda23eaac131f1efe4c9520e77f769371b4.tar.bz2
c: Handle initializations of opaque types [PR106016]
The initial commit that added opaque types thought that there couldn't be any valid initializations for variables of these types, but the test case in the bug report shows that isn't true. The solution is to handle OPAQUE_TYPE initializations like the other scalar types. 2022-06-17 Peter Bergner <bergner@linux.ibm.com> gcc/ PR c/106016 * expr.cc (count_type_elements): Handle OPAQUE_TYPE. gcc/testsuite/ PR c/106016 * gcc.target/powerpc/pr106016.c: New test.
-rw-r--r--gcc/expr.cc2
-rw-r--r--gcc/testsuite/gcc.target/powerpc/pr106016.c14
2 files changed, 15 insertions, 1 deletions
diff --git a/gcc/expr.cc b/gcc/expr.cc
index f9753d4..80bb1b8 100644
--- a/gcc/expr.cc
+++ b/gcc/expr.cc
@@ -6462,13 +6462,13 @@ count_type_elements (const_tree type, bool for_ctor_p)
case OFFSET_TYPE:
case REFERENCE_TYPE:
case NULLPTR_TYPE:
+ case OPAQUE_TYPE:
return 1;
case ERROR_MARK:
return 0;
case VOID_TYPE:
- case OPAQUE_TYPE:
case METHOD_TYPE:
case FUNCTION_TYPE:
case LANG_TYPE:
diff --git a/gcc/testsuite/gcc.target/powerpc/pr106016.c b/gcc/testsuite/gcc.target/powerpc/pr106016.c
new file mode 100644
index 0000000..3db8345
--- /dev/null
+++ b/gcc/testsuite/gcc.target/powerpc/pr106016.c
@@ -0,0 +1,14 @@
+/* PR target/106016 */
+/* { dg-require-effective-target power10_ok } */
+/* { dg-options "-O2 -mdejagnu-cpu=power10" } */
+
+/* Make sure we do not ICE on the following test case. */
+
+extern void bar (__vector_quad *);
+
+void
+foo (__vector_quad *a, __vector_quad *b)
+{
+ __vector_quad arr[2] = {*a, *b};
+ bar (&arr[0]);
+}