Module IR__Sil
The Smallfoot Intermediate Language
Programs and Types
type if_kind
=
Kind of prune instruction
type instr_metadata
=
|
Abstract of IBase.Location.t
a good place to apply abstraction, mostly used in the biabduction analysis
|
CatchEntry of
{
try_id : int;
loc : IBase.Location.t;
}
entry of C++ catch blocks
|
ExitScope of IR.Var.t list * IBase.Location.t
remove temporaries and dead program variables
|
Nullify of IR.Pvar.t * IBase.Location.t
nullify stack variable
|
Skip
no-op
|
TryEntry of
{
try_id : int;
loc : IBase.Location.t;
}
entry of C++ try block
|
TryExit of
{
try_id : int;
loc : IBase.Location.t;
}
exit of C++ try block
|
VariableLifetimeBegins of IR.Pvar.t * IR.Typ.t * IBase.Location.t
stack variable declared
val compare_instr_metadata : instr_metadata -> instr_metadata -> int
type instr
=
|
Load of
{
id : IR.Ident.t;
e : IR.Exp.t;
root_typ : IR.Typ.t;
typ : IR.Typ.t;
loc : IBase.Location.t;
}
Load a value from the heap into an identifier.
id = *exp:typ(root_typ)
whereexp
is an expression denoting a heap addresstyp
is typ ofexp
andid
root_typ
is the root type ofexp
The
root_typ
is deprecated: it is broken in C/C++. We are removingroot_typ
in the future, so please usetyp
instead.|
Store of
{
e1 : IR.Exp.t;
root_typ : IR.Typ.t;
typ : IR.Typ.t;
e2 : IR.Exp.t;
loc : IBase.Location.t;
}
Store the value of an expression into the heap.
*exp1:typ(root_typ) = exp2
whereexp1
is an expression denoting a heap addresstyp
is typ of*exp1
andexp2
root_typ
is the root type ofexp1
exp2
is the expression whose value is stored.
The
root_typ
is deprecated: it is broken in C/C++. We are removingroot_typ
in the future, so please usetyp
instead.|
Prune of IR.Exp.t * IBase.Location.t * bool * if_kind
prune the state based on
exp=1
, the boolean indicates whether true branch|
Call of IR.Ident.t * IR.Typ.t * IR.Exp.t * (IR.Exp.t * IR.Typ.t) list * IBase.Location.t * IR.CallFlags.t
Call ((ret_id, ret_typ), e_fun, arg_ts, loc, call_flags)
represents an instructionret_id = e_fun(arg_ts);
|
Metadata of instr_metadata
hints about the program that are not strictly needed to understand its semantics, for instance information about its original syntactic structure
An instruction.
val equal_instr : instr -> instr -> bool
val skip_instr : instr
val instr_is_auxiliary : instr -> bool
Check if an instruction is auxiliary, or if it comes from source instructions.
val location_of_instr : instr -> IBase.Location.t
Get the location of the instruction
val if_kind_to_string : if_kind -> string
Pretty print an if_kind
val pp_instr_metadata : IStdlib.Pp.env -> F.formatter -> instr_metadata -> unit
val pp_instr : print_types:bool -> IStdlib.Pp.env -> F.formatter -> instr -> unit
Pretty print an instruction.
val d_instr : instr -> unit
Dump an instruction.