aboutsummaryrefslogtreecommitdiff
path: root/gcc/c-family
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2019-10-01 18:19:04 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2019-10-01 18:19:04 +0200
commit7552c36afa1f9058bb39f336ae84f019621885a0 (patch)
tree3ec5a38c3f5514c422be560bab1c6dba4a5ef479 /gcc/c-family
parent04bf300e86bc88617a709bebe29787f95aec59cc (diff)
downloadgcc-7552c36afa1f9058bb39f336ae84f019621885a0.zip
gcc-7552c36afa1f9058bb39f336ae84f019621885a0.tar.gz
gcc-7552c36afa1f9058bb39f336ae84f019621885a0.tar.bz2
re PR c++/91925 (-fpack-struct causes a decltype with template to ICE)
PR c++/91925 * c-warn.c (check_alignment_of_packed_member): Ignore FIELD_DECLs with NULL DECL_FIELD_OFFSET. * g++.dg/conversion/packed2.C: New test. From-SVN: r276415
Diffstat (limited to 'gcc/c-family')
-rw-r--r--gcc/c-family/ChangeLog6
-rw-r--r--gcc/c-family/c-warn.c2
2 files changed, 8 insertions, 0 deletions
diff --git a/gcc/c-family/ChangeLog b/gcc/c-family/ChangeLog
index eaea04b..811947a 100644
--- a/gcc/c-family/ChangeLog
+++ b/gcc/c-family/ChangeLog
@@ -1,3 +1,9 @@
+2019-10-01 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/91925
+ * c-warn.c (check_alignment_of_packed_member): Ignore FIELD_DECLs
+ with NULL DECL_FIELD_OFFSET.
+
2019-10-01 Richard Sandiford <richard.sandiford@arm.com>
* c-pretty-print.c (pp_c_specifier_qualifier_list): If a vector type
diff --git a/gcc/c-family/c-warn.c b/gcc/c-family/c-warn.c
index bee5449..8236525 100644
--- a/gcc/c-family/c-warn.c
+++ b/gcc/c-family/c-warn.c
@@ -2798,6 +2798,8 @@ check_alignment_of_packed_member (tree type, tree field, bool rvalue)
/* Check alignment of the data member. */
if (TREE_CODE (field) == FIELD_DECL
&& (DECL_PACKED (field) || TYPE_PACKED (TREE_TYPE (field)))
+ /* Ignore FIELDs not laid out yet. */
+ && DECL_FIELD_OFFSET (field)
&& (!rvalue || TREE_CODE (TREE_TYPE (field)) == ARRAY_TYPE))
{
/* Check the expected alignment against the field alignment. */