aboutsummaryrefslogtreecommitdiff
path: root/gcc/stor-layout.c
diff options
context:
space:
mode:
authorUros Bizjak <ubizjak@gmail.com>2010-03-27 14:40:08 +0100
committerUros Bizjak <uros@gcc.gnu.org>2010-03-27 14:40:08 +0100
commitfb6807b860ac9bdb2cb345a43b9c3bf398aca013 (patch)
tree5a1ae82114fa77231dcb17d53972ed4cd313b459 /gcc/stor-layout.c
parenta9deb2560c097bfe2484127ee09342a128835061 (diff)
downloadgcc-fb6807b860ac9bdb2cb345a43b9c3bf398aca013.zip
gcc-fb6807b860ac9bdb2cb345a43b9c3bf398aca013.tar.gz
gcc-fb6807b860ac9bdb2cb345a43b9c3bf398aca013.tar.bz2
re PR tree-optimization/43528 (ICE: in tree_low_cst, at tree.c:6198 with -mms-bitfields at x86_64-linux)
PR tree-optimization/43528 * stor-layout.c (place_field): Check that constant fits into unsigned HWI when skipping calculation of MS bitfield layout. testsuite/ChangeLog: PR tree-optimization/43528 * gcc.target/i386/pr43528.c: New test. From-SVN: r157776
Diffstat (limited to 'gcc/stor-layout.c')
-rw-r--r--gcc/stor-layout.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/gcc/stor-layout.c b/gcc/stor-layout.c
index 1806c12..18c74cb 100644
--- a/gcc/stor-layout.c
+++ b/gcc/stor-layout.c
@@ -1346,11 +1346,12 @@ place_field (record_layout_info rli, tree field)
until we see a bitfield (and come by here again) we just skip
calculating it. */
if (DECL_SIZE (field) != NULL
- && host_integerp (TYPE_SIZE (TREE_TYPE (field)), 0)
- && host_integerp (DECL_SIZE (field), 0))
+ && host_integerp (TYPE_SIZE (TREE_TYPE (field)), 1)
+ && host_integerp (DECL_SIZE (field), 1))
{
- HOST_WIDE_INT bitsize = tree_low_cst (DECL_SIZE (field), 1);
- HOST_WIDE_INT typesize
+ unsigned HOST_WIDE_INT bitsize
+ = tree_low_cst (DECL_SIZE (field), 1);
+ unsigned HOST_WIDE_INT typesize
= tree_low_cst (TYPE_SIZE (TREE_TYPE (field)), 1);
if (typesize < bitsize)