package goblint
Static analysis framework for C
Install
Dune Dependency
Authors
Maintainers
Sources
goblint-2.1.0.tbz
sha256=bfc412ec2e447eaef6f4f83892e3511ebf305593cb00561c1406be3ae8bf48e9
sha512=5f2a162e5f36bffafc9836b0d18b5b2808cecfa6bf68f83bb7d1e8b9947ac74cf07776eb09274b4b29d55c897a45a10768f0d9ed25810cf6ba2409c525e4cd4d
doc/goblint.lib/Goblint_lib/AccessAnalysis/Spec/index.html
Module AccessAnalysis.Spec
Access analyzer without base --- this is the new standard
include module type of struct include Analyses.DefaultSpec end
val vdecl : ('a, 'b, 'c, 'd) Analyses.ctx -> 'e -> 'a
val asm : ('a, 'b, 'c, 'd) Analyses.ctx -> 'a
val skip : ('a, 'b, 'c, 'd) Analyses.ctx -> 'a
val sync : ('a, 'b, 'c, 'd) Analyses.ctx -> 'e -> 'a
module A = Goblint_lib.Analyses.DefaultSpec.A
module D = Lattice.Unit
module C = Lattice.Unit
module V : sig ... end
module G = AccessDomain.EventSet
val collect_local : bool Prelude.Ana.ref
val do_access :
(D.t, G.t, C.t, V.t) Analyses.ctx ->
AccessKind.t ->
bool ->
Prelude.Ana.exp ->
unit
val access_one_top :
?force:bool ->
?deref:bool ->
(D.t, G.t, C.t, V.t) Analyses.ctx ->
AccessKind.t ->
bool ->
Prelude.Ana.exp ->
unit
Three access levels:
deref=false
,reach=false
- Accessexp
without dereferencing, used for all normal reads and all function call arguments.deref=true
,reach=false
- Accessexp
by dereferencing once (may-point-to), used for lval writes and shallow special accesses.deref=true
,reach=true
- Accessexp
by dereferencing transitively (reachable), used for deep special accesses.
Transfer functions:
val assign :
(D.t, G.t, C.t, V.t) Analyses.ctx ->
Prelude.Ana.lval ->
Prelude.Ana.exp ->
D.t
val branch : (D.t, G.t, C.t, V.t) Analyses.ctx -> Prelude.Ana.exp -> 'a -> D.t
val return :
(D.t, G.t, C.t, V.t) Analyses.ctx ->
Prelude.Ana.exp option ->
'a ->
D.t
val body : (D.t, 'a, 'b, 'c) Analyses.ctx -> 'd -> D.t
val special :
(D.t, G.t, C.t, V.t) Analyses.ctx ->
Prelude.Ana.lval option ->
GoblintCil.Cil.varinfo ->
Prelude.Ana.exp list ->
D.t
val enter :
(D.t, 'a, 'b, 'c) Analyses.ctx ->
'd ->
'e ->
'f ->
(D.t * D.t) list
val combine :
(D.t, G.t, C.t, V.t) Analyses.ctx ->
Prelude.Ana.lval option ->
Prelude.Ana.exp ->
'a ->
Prelude.Ana.exp list ->
'b ->
'c ->
'c
val threadspawn :
(D.t, G.t, C.t, V.t) Analyses.ctx ->
Prelude.Ana.lval option ->
'a ->
'b ->
'c ->
D.t
val query :
('b, G.t, 'c, MyCFG.node) Analyses.ctx ->
'a Queries.t ->
'a Queries.result
val event : (unit, G.t, 'a, MyCFG.node) Analyses.ctx -> Events.t -> 'b -> unit
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>