Skip to content
Snippets Groups Projects
Commit c3a9599d authored by Basile Desloges's avatar Basile Desloges
Browse files

[eacsl:codegen] Move `Memory_translate.exp_to_base_and_baseaddr` to `Misc.ptr_base`

parent c9e1c224
No related branches found
No related tags found
No related merge requests found
...@@ -257,19 +257,6 @@ let term_to_ptr_and_size ~loc kf env t = ...@@ -257,19 +257,6 @@ let term_to_ptr_and_size ~loc kf env t =
let sizeof = Smart_exp.ptr_sizeof ~loc ty in let sizeof = Smart_exp.ptr_sizeof ~loc ty in
e, sizeof, env e, sizeof, env
(* Take an expression [e] and return a tuple [(base, base_addr)] where [base]
is the address [p] if [e] is of the form [p + i] and [e] otherwise, and
[base_addr] is the address [&p] if [e] is of the form [p + i] and 0
otherwise. *)
let exp_to_base_and_baseaddr ~loc e =
let base, _ = Misc.ptr_index ~loc e in
let base_addr = match base.enode with
| AddrOf _ | Const _ -> Cil.zero ~loc
| Lval lv | StartOf lv -> Cil.mkAddrOrStartOf ~loc lv
| _ -> assert false
in
base, base_addr
(* [fname_to_pred name args] returns the memory predicate corresponding to (* [fname_to_pred name args] returns the memory predicate corresponding to
[name] with the given [args]. *) [name] with the given [args]. *)
let fname_to_pred ?loc name args = let fname_to_pred ?loc name args =
...@@ -510,12 +497,12 @@ let call_valid ~loc kf name ctx env t p = ...@@ -510,12 +497,12 @@ let call_valid ~loc kf name ctx env t p =
assert (name = "valid" || name = "valid_read"); assert (name = "valid" || name = "valid_read");
let arg_from_term ~loc kf env rev_args t _p = let arg_from_term ~loc kf env rev_args t _p =
let ptr, size, env = term_to_ptr_and_size ~loc kf env t in let ptr, size, env = term_to_ptr_and_size ~loc kf env t in
let base, base_addr = exp_to_base_and_baseaddr ~loc ptr in let base, base_addr = Misc.ptr_base ~loc ptr in
base_addr :: base :: size :: ptr :: rev_args, env base_addr :: base :: size :: ptr :: rev_args, env
in in
let arg_from_range ~loc kf env rev_args ptr r p = let arg_from_range ~loc kf env rev_args ptr r p =
let ptr, size, env = range_to_ptr_and_size ~loc kf env ptr r p in let ptr, size, env = range_to_ptr_and_size ~loc kf env ptr r p in
let base, base_addr = exp_to_base_and_baseaddr ~loc ptr in let base, base_addr = Misc.ptr_base ~loc ptr in
base_addr :: base :: size :: ptr :: rev_args, env base_addr :: base :: size :: ptr :: rev_args, env
in in
let prepend_n_args = false in let prepend_n_args = false in
......
...@@ -87,6 +87,15 @@ let rec ptr_index ?(loc=Location.unknown) ?(index=(Cil.zero loc)) exp = ...@@ -87,6 +87,15 @@ let rec ptr_index ?(loc=Location.unknown) ?(index=(Cil.zero loc)) exp =
| SizeOf _ | SizeOfE _ | SizeOfStr _ | AlignOf _ | AlignOfE _ | SizeOf _ | SizeOfE _ | SizeOfStr _ | AlignOf _ | AlignOfE _
-> assert false -> assert false
let ptr_base ~loc e =
let base, _ = ptr_index ~loc e in
let base_addr = match base.enode with
| AddrOf _ | Const _ -> Cil.zero ~loc
| Lval lv | StartOf lv -> Cil.mkAddrOrStartOf ~loc lv
| _ -> assert false
in
base, base_addr
(* TODO: should not be in this file *) (* TODO: should not be in this file *)
let term_of_li li = match li.l_body with let term_of_li li = match li.l_body with
| LBterm t -> t | LBterm t -> t
......
...@@ -50,6 +50,12 @@ val ptr_index: ?loc:location -> ?index:exp -> exp ...@@ -50,6 +50,12 @@ val ptr_index: ?loc:location -> ?index:exp -> exp
(** Split pointer-arithmetic expression of the type [p + i] into its (** Split pointer-arithmetic expression of the type [p + i] into its
pointer and integer parts. *) pointer and integer parts. *)
val ptr_base: loc:location -> exp -> exp * exp
(* Takes an expression [e] and return a tuple [(base, base_addr)] where [base]
is the address [p] if [e] is of the form [p + i] and [e] otherwise, and
[base_addr] is the address [&p] if [e] is of the form [p + i] and 0
otherwise. *)
val term_of_li: logic_info -> term val term_of_li: logic_info -> term
(** [term_of_li li] assumes that [li.l_body] matches [LBterm t] (** [term_of_li li] assumes that [li.l_body] matches [LBterm t]
and returns [t]. *) and returns [t]. *)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment