aboutsummaryrefslogtreecommitdiffstats
path: root/cparser/Bitfields.ml
diff options
context:
space:
mode:
authorxleroy <xleroy@fca1b0fc-160b-0410-b1d3-a4f43f01ea2e>2010-09-24 09:04:51 +0000
committerxleroy <xleroy@fca1b0fc-160b-0410-b1d3-a4f43f01ea2e>2010-09-24 09:04:51 +0000
commitcca95c35a944a994de1daee2462c1b3663b3efd2 (patch)
treee329e63fcd9bdd182e5a8e967c8bfd8fdb9b6668 /cparser/Bitfields.ml
parent280f002460e9b7df7f48517ada79d06252c1629c (diff)
downloadcompcert-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.ml32
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 =