From 033aa0555a209fa3e825b1eeb8a5fc00ff8163e3 Mon Sep 17 00:00:00 2001 From: xleroy Date: Sun, 1 Nov 2009 09:55:35 +0000 Subject: Support Clight initializers of the form "int * x = &y;". git-svn-id: https://yquem.inria.fr/compcert/svn/compcert/trunk@1162 fca1b0fc-160b-0410-b1d3-a4f43f01ea2e --- cfrontend/Cil2Csyntax.ml | 23 ++++++++++++++++------- cfrontend/PrintCsyntax.ml | 5 +++++ 2 files changed, 21 insertions(+), 7 deletions(-) (limited to 'cfrontend') diff --git a/cfrontend/Cil2Csyntax.ml b/cfrontend/Cil2Csyntax.ml index 85380038..b8a88deb 100644 --- a/cfrontend/Cil2Csyntax.ml +++ b/cfrontend/Cil2Csyntax.ml @@ -1003,6 +1003,7 @@ let rec initDataLen accu = function | Init_float32 _ -> 4l | Init_float64 _ -> 8l | Init_space n -> camlint_of_z n + | Init_addrof(_, _) -> 4l | Init_pointer _ -> 4l in initDataLen (Int32.add sz accu) il @@ -1013,16 +1014,21 @@ type init_constant = | ICint of int64 * intsize | ICfloat of float * floatsize | ICstring of string + | ICaddrof of string | ICnone let extract_constant e = - try - match eval_expr e with - | CInt64(n, ikind, _) -> ICint(n, fst (convertIkind ikind)) - | CReal(n, fkind, _) -> ICfloat(n, convertFkind fkind) - | CStr s -> ICstring s - | _ -> ICnone - with NotConst -> ICnone + match e with + | AddrOf(Var v, NoOffset) -> ICaddrof v.vname + | StartOf(Var v, NoOffset) -> ICaddrof v.vname + | _ -> + try + match eval_expr e with + | CInt64(n, ikind, _) -> ICint(n, fst (convertIkind ikind)) + | CReal(n, fkind, _) -> ICfloat(n, convertFkind fkind) + | CStr s -> ICstring s + | _ -> ICnone + with NotConst -> ICnone let init_data_of_string s = let id = ref [] in @@ -1068,6 +1074,9 @@ let convertInit init = | ICfloat(n, F64) -> check_align 8; emit 8 (Init_float64 n) + | ICaddrof id -> + check_align 4; + emit 4 (Init_addrof(intern_string id, coqint_of_camlint 0l)) | ICstring s -> check_align 4; emit 4 (Init_pointer(init_data_of_string s)) diff --git a/cfrontend/PrintCsyntax.ml b/cfrontend/PrintCsyntax.ml index 88e24eed..fa1d0482 100644 --- a/cfrontend/PrintCsyntax.ml +++ b/cfrontend/PrintCsyntax.ml @@ -378,6 +378,11 @@ let print_init p = function | Init_float32 n -> fprintf p "%F,@ " n | Init_float64 n -> fprintf p "%F,@ " n | Init_space n -> fprintf p "/* skip %ld, */@ " (camlint_of_coqint n) + | Init_addrof(symb, ofs) -> + let ofs = camlint_of_coqint ofs in + if ofs = 0l + then fprintf p "&%s,@ " (extern_atom symb) + else fprintf p "(void *)((char *)&%s + %ld),@ " (extern_atom symb) ofs | Init_pointer id -> match string_of_init id with | None -> fprintf p "/* pointer to other init*/,@ " -- cgit