You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

61 lines
1.4 KiB

(*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*)
(** Abstract Domain *)
module type Dom = sig
type t [@@deriving equal, sexp_of]
val pp : t pp
val report_fmt_thunk : t -> Formatter.t -> unit
val init : Global.t vector -> t
val join : t -> t -> t option
val is_false : t -> bool
val dnf : t -> t list
val exec_assume : t -> Exp.t -> t option
val exec_kill : t -> Reg.t -> t
val exec_move : t -> (Reg.t * Exp.t) vector -> t
val exec_inst : t -> Llair.inst -> t option
val exec_intrinsic :
skip_throw:bool
-> t
-> Reg.t option
-> Reg.t
-> Exp.t list
-> t option option
type from_call [@@deriving sexp_of]
val call :
summaries:bool
-> globals:Reg.Set.t
-> actuals:Exp.t list
-> areturn:Reg.t option
-> formals:Reg.t list
-> freturn:Reg.t option
-> locals:Reg.Set.t
-> t
-> t * from_call
val post : Reg.Set.t -> from_call -> t -> t
val retn : Reg.t list -> Reg.t option -> from_call -> t -> t
val resolve_callee :
(string -> Llair.func list) -> Exp.t -> t -> Llair.func list * t
val recursion_beyond_bound : [`skip | `prune]
type summary
val pp_summary : summary pp
val create_summary :
locals:Reg.Set.t -> formals:Reg.Set.t -> t -> summary * t
val apply_summary : t -> summary -> t option
end