diff options
author | J"orn Rennecke <joern.rennecke@st.com> | 2005-09-12 13:49:56 +0000 |
---|---|---|
committer | Joern Rennecke <amylaar@gcc.gnu.org> | 2005-09-12 14:49:56 +0100 |
commit | f439f9a536087071b4593eb0dda40eb5cc592c1c (patch) | |
tree | 649fa30263261ba9370902d07bbae9c92afec4db | |
parent | cd41bae5fde3f26c99c33511c08c523b55e295c8 (diff) | |
download | gcc-f439f9a536087071b4593eb0dda40eb5cc592c1c.zip gcc-f439f9a536087071b4593eb0dda40eb5cc592c1c.tar.gz gcc-f439f9a536087071b4593eb0dda40eb5cc592c1c.tar.bz2 |
re PR middle-end/23290 (Layout changed for structure with single complex field)
PR middle-end/23290
* stor-layout.c (compute_record_mode): For records with a single
field, actually check the field's mode size against the type size.
From-SVN: r104171
-rw-r--r-- | gcc/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/stor-layout.c | 7 |
2 files changed, 8 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 70eb987..7d2a742 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,9 @@ 2005-09-12 J"orn Rennecke <joern.rennecke@st.com> + PR middle-end/23290 + * stor-layout.c (compute_record_mode): For records with a single + field, actually check the field's mode size against the type size. + * sh.h (HARD_REGNO_MODE_OK): Allow V4SFmode in general purpose registers for TARGET_SHMEDIA. (enum reg_class, REG_CLASS_NAMES, REG_CLASS_CONTENTS): Rename diff --git a/gcc/stor-layout.c b/gcc/stor-layout.c index 0ec818d..31d8bec 100644 --- a/gcc/stor-layout.c +++ b/gcc/stor-layout.c @@ -1367,14 +1367,15 @@ compute_record_mode (tree type) #endif /* MEMBER_TYPE_FORCES_BLK */ } - TYPE_MODE (type) = mode_for_size_tree (TYPE_SIZE (type), MODE_INT, 1); - /* If we only have one real field; use its mode if that mode's size matches the type's size. This only applies to RECORD_TYPE. This does not apply to unions. */ if (TREE_CODE (type) == RECORD_TYPE && mode != VOIDmode - && GET_MODE_SIZE (mode) == GET_MODE_SIZE (TYPE_MODE (type))) + && host_integerp (TYPE_SIZE (type), 1) + && GET_MODE_BITSIZE (mode) == TREE_INT_CST_LOW (TYPE_SIZE (type))) TYPE_MODE (type) = mode; + else + TYPE_MODE (type) = mode_for_size_tree (TYPE_SIZE (type), MODE_INT, 1); /* If structure's known alignment is less than what the scalar mode would need, and it matters, then stick with BLKmode. */ |