aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2010-02-23 13:31:58 -0500
committerJason Merrill <jason@gcc.gnu.org>2010-02-23 13:31:58 -0500
commita3b20e90b15f4022bbc6851b11e1950b89c3b961 (patch)
tree75de48b522dc558018496443966ad310bcfffa48 /gcc
parent5ead99faadd6b813fb277a87b96a324766b0b3b8 (diff)
downloadgcc-a3b20e90b15f4022bbc6851b11e1950b89c3b961.zip
gcc-a3b20e90b15f4022bbc6851b11e1950b89c3b961.tar.gz
gcc-a3b20e90b15f4022bbc6851b11e1950b89c3b961.tar.bz2
re PR c++/42837 (FAIL: g++.dg/abi/packed1.C execution test)
PR c++/42837 * stor-layout.c (place_field): Don't warn about unnecessary DECL_PACKED if the type is packed. From-SVN: r157013
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/stor-layout.c3
2 files changed, 8 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 7bd2c7b..b148e67 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2010-02-23 Jason Merrill <jason@redhat.com>
+
+ PR c++/42837
+ * stor-layout.c (place_field): Don't warn about unnecessary
+ DECL_PACKED if the type is packed.
+
2010-02-23 Jakub Jelinek <jakub@redhat.com>
PR target/43139
diff --git a/gcc/stor-layout.c b/gcc/stor-layout.c
index 6f08d8c..1806c12 100644
--- a/gcc/stor-layout.c
+++ b/gcc/stor-layout.c
@@ -1100,7 +1100,8 @@ place_field (record_layout_info rli, tree field)
if (STRICT_ALIGNMENT)
warning (OPT_Wattributes, "packed attribute causes "
"inefficient alignment for %q+D", field);
- else
+ /* Don't warn if DECL_PACKED was set by the type. */
+ else if (!TYPE_PACKED (rli->t))
warning (OPT_Wattributes, "packed attribute is "
"unnecessary for %q+D", field);
}