diff options
author | aoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-02-05 17:56:34 +0000 |
---|---|---|
committer | aoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-02-05 17:56:34 +0000 |
commit | f04f096ba67176fc3527ae02aa7c350d8389ccb3 (patch) | |
tree | 3a2fa33e655d88a836f10525dd980faa2d69aff9 /gcc/tree.h | |
parent | c6d86b637864267dc54d3943ee86572dc2c7fbcf (diff) | |
download | gcc-f04f096ba67176fc3527ae02aa7c350d8389ccb3.tar.gz |
* target.h (struct gcc_target): Added ms_bitfield_layout_p.
* target-def.h (TARGET_MS_BITFIELD_LAYOUT_P): New. Added to...
(TARGET_INITIALIZER): this.
* doc/tm.texi (TARGET_MS_BITFIELD_LAYOUT_P): Document.
(BITFIELD_NBYTES_LIMITED): Markup fix.
* tree.h (default_ms_bitfield_layout_p): Declare.
(record_layout_info): Added prev_field.
* tree.c (default_ms_bitfield_layout_p): New fn.
* c-decl.c (finish_struct): Disregard EMPTY_FIELD_BOUNDARY and
PCC_BITFIELD_TYPE_MATTERS for MS bit-field layout.
* stor-layout.c: Include target.h.
(start_record_layout): Initialize prev_field.
(place_field): Handle MS bit-field layout, and disregard
EMPTY_FIELD_BOUNDARY, BITFIELD_NBYTES_LIMITED and
PCC_BITFIELD_TYPE_MATTERS in this case. Update prev_field.
* Makefile.in (stor-layout.o): Adjust dependencies.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@49526 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree.h')
-rw-r--r-- | gcc/tree.h | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/gcc/tree.h b/gcc/tree.h index 842c0a9924f..6c07f5b1ebc 100644 --- a/gcc/tree.h +++ b/gcc/tree.h @@ -2234,6 +2234,7 @@ extern int default_comp_type_attributes PARAMS ((tree, tree)); extern void default_set_default_type_attributes PARAMS ((tree)); extern void default_insert_attributes PARAMS ((tree, tree *)); extern bool default_function_attribute_inlinable_p PARAMS ((tree)); +extern bool default_ms_bitfield_layout_p PARAMS ((tree)); /* Split a list of declspecs and attributes into two. */ @@ -2323,6 +2324,8 @@ typedef struct record_layout_info_s /* The alignment of the record so far, allowing for the record to be padded only at the end, in bits. */ unsigned int unpadded_align; + /* The previous field layed out. */ + tree prev_field; /* The static variables (i.e., class variables, as opposed to instance variables) encountered in T. */ tree pending_statics; |