diff options
author | xleroy <xleroy@fca1b0fc-160b-0410-b1d3-a4f43f01ea2e> | 2010-09-24 09:04:51 +0000 |
---|---|---|
committer | xleroy <xleroy@fca1b0fc-160b-0410-b1d3-a4f43f01ea2e> | 2010-09-24 09:04:51 +0000 |
commit | cca95c35a944a994de1daee2462c1b3663b3efd2 (patch) | |
tree | e329e63fcd9bdd182e5a8e967c8bfd8fdb9b6668 /cparser/Bitfields.ml | |
parent | 280f002460e9b7df7f48517ada79d06252c1629c (diff) | |
download | compcert-cca95c35a944a994de1daee2462c1b3663b3efd2.tar.gz compcert-cca95c35a944a994de1daee2462c1b3663b3efd2.zip |
Inconsistent treatment of "lone" zero-width bit fields
(i.e. not preceded by another bit field).
git-svn-id: https://yquem.inria.fr/compcert/svn/compcert/trunk@1516 fca1b0fc-160b-0410-b1d3-a4f43f01ea2e
Diffstat (limited to 'cparser/Bitfields.ml')
-rw-r--r-- | cparser/Bitfields.ml | 32 |
1 files changed, 19 insertions, 13 deletions
diff --git a/cparser/Bitfields.ml b/cparser/Bitfields.ml index a345d975..9452a4f6 100644 --- a/cparser/Bitfields.ml +++ b/cparser/Bitfields.ml @@ -88,19 +88,25 @@ let rec transf_members env id count = function m :: transf_members env id count ms else begin let (nbits, bitfields, ml') = pack_bitfields env id ml in - let carrier = sprintf "__bf%d" count in - let carrier_typ = TInt(unsigned_ikind_for_carrier nbits, []) in - List.iter - (fun (name, pos, sz, signed, signed2) -> - if name <> "" then - Hashtbl.add bitfield_table - (id, name) - {bf_carrier = carrier; bf_carrier_typ = carrier_typ; - bf_pos = pos; bf_size = sz; - bf_signed = signed; bf_signed_res = signed2}) - bitfields; - { fld_name = carrier; fld_typ = carrier_typ; fld_bitfield = None} - :: transf_members env id (count + 1) ml' + if nbits = 0 then + (* Lone zero-size bitfield: just ignore *) + transf_members env id count ml' + else begin + (* Create integer field of sufficient size for this bitfield group *) + let carrier = sprintf "__bf%d" count in + let carrier_typ = TInt(unsigned_ikind_for_carrier nbits, []) in + List.iter + (fun (name, pos, sz, signed, signed2) -> + if name <> "" then + Hashtbl.add bitfield_table + (id, name) + {bf_carrier = carrier; bf_carrier_typ = carrier_typ; + bf_pos = pos; bf_size = sz; + bf_signed = signed; bf_signed_res = signed2}) + bitfields; + { fld_name = carrier; fld_typ = carrier_typ; fld_bitfield = None} + :: transf_members env id (count + 1) ml' + end end let transf_composite env su id ml = |